refactoring. also, add the configpath to commandline arguments. also, call debug from commandline arguments now
This commit is contained in:
parent
1e9d46b6ef
commit
00796f3e98
5 changed files with 538 additions and 62 deletions
213
Cargo.lock
generated
213
Cargo.lock
generated
|
@ -2,12 +2,113 @@
|
|||
# It is not intended for manual editing.
|
||||
version = 3
|
||||
|
||||
[[package]]
|
||||
name = "anstream"
|
||||
version = "0.6.15"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "64e15c1ab1f89faffbf04a634d5e1962e9074f2741eef6d97f3c4e322426d526"
|
||||
dependencies = [
|
||||
"anstyle",
|
||||
"anstyle-parse",
|
||||
"anstyle-query",
|
||||
"anstyle-wincon",
|
||||
"colorchoice",
|
||||
"is_terminal_polyfill",
|
||||
"utf8parse",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "anstyle"
|
||||
version = "1.0.8"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "1bec1de6f59aedf83baf9ff929c98f2ad654b97c9510f4e70cf6f661d49fd5b1"
|
||||
|
||||
[[package]]
|
||||
name = "anstyle-parse"
|
||||
version = "0.2.5"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "eb47de1e80c2b463c735db5b217a0ddc39d612e7ac9e2e96a5aed1f57616c1cb"
|
||||
dependencies = [
|
||||
"utf8parse",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "anstyle-query"
|
||||
version = "1.1.1"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "6d36fc52c7f6c869915e99412912f22093507da8d9e942ceaf66fe4b7c14422a"
|
||||
dependencies = [
|
||||
"windows-sys",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "anstyle-wincon"
|
||||
version = "3.0.4"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "5bf74e1b6e971609db8ca7a9ce79fd5768ab6ae46441c572e46cf596f59e57f8"
|
||||
dependencies = [
|
||||
"anstyle",
|
||||
"windows-sys",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "base64"
|
||||
version = "0.22.1"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6"
|
||||
|
||||
[[package]]
|
||||
name = "clap"
|
||||
version = "4.5.20"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "b97f376d85a664d5837dbae44bf546e6477a679ff6610010f17276f686d867e8"
|
||||
dependencies = [
|
||||
"clap_builder",
|
||||
"clap_derive",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "clap_builder"
|
||||
version = "4.5.20"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "19bc80abd44e4bed93ca373a0704ccbd1b710dc5749406201bb018272808dc54"
|
||||
dependencies = [
|
||||
"anstream",
|
||||
"anstyle",
|
||||
"clap_lex",
|
||||
"strsim",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "clap_derive"
|
||||
version = "4.5.18"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "4ac6a0c7b1a9e9a5186361f67dfa1b88213572f427fb9ab038efb2bd8c582dab"
|
||||
dependencies = [
|
||||
"heck",
|
||||
"proc-macro2",
|
||||
"quote",
|
||||
"syn",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "clap_lex"
|
||||
version = "0.7.2"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "1462739cb27611015575c0c11df5df7601141071f07518d56fcc1be504cbec97"
|
||||
|
||||
[[package]]
|
||||
name = "colorchoice"
|
||||
version = "1.0.2"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "d3fd119d74b830634cea2a0f58bbd0d54540518a14397557951e79340abc28c0"
|
||||
|
||||
[[package]]
|
||||
name = "heck"
|
||||
version = "0.5.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea"
|
||||
|
||||
[[package]]
|
||||
name = "idmangler-lib"
|
||||
version = "0.3.0"
|
||||
|
@ -17,6 +118,23 @@ dependencies = [
|
|||
"thiserror",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "idmanglercli"
|
||||
version = "0.3.1"
|
||||
dependencies = [
|
||||
"base64",
|
||||
"clap",
|
||||
"idmangler-lib",
|
||||
"serde",
|
||||
"serde_json",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "is_terminal_polyfill"
|
||||
version = "1.70.1"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "7943c866cc5cd64cbc25b2e01621d07fa8eb2a1a23160ee81ce38704e97b8ecf"
|
||||
|
||||
[[package]]
|
||||
name = "itoa"
|
||||
version = "1.0.11"
|
||||
|
@ -29,16 +147,6 @@ version = "2.7.4"
|
|||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3"
|
||||
|
||||
[[package]]
|
||||
name = "newestidmangler"
|
||||
version = "0.3.0"
|
||||
dependencies = [
|
||||
"base64",
|
||||
"idmangler-lib",
|
||||
"serde",
|
||||
"serde_json",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "proc-macro2"
|
||||
version = "1.0.86"
|
||||
|
@ -95,6 +203,12 @@ dependencies = [
|
|||
"serde",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "strsim"
|
||||
version = "0.11.1"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f"
|
||||
|
||||
[[package]]
|
||||
name = "syn"
|
||||
version = "2.0.77"
|
||||
|
@ -131,3 +245,82 @@ name = "unicode-ident"
|
|||
version = "1.0.12"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
||||
|
||||
[[package]]
|
||||
name = "utf8parse"
|
||||
version = "0.2.2"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "06abde3611657adf66d383f00b093d7faecc7fa57071cce2578660c9f1010821"
|
||||
|
||||
[[package]]
|
||||
name = "windows-sys"
|
||||
version = "0.52.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
|
||||
dependencies = [
|
||||
"windows-targets",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows-targets"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973"
|
||||
dependencies = [
|
||||
"windows_aarch64_gnullvm",
|
||||
"windows_aarch64_msvc",
|
||||
"windows_i686_gnu",
|
||||
"windows_i686_gnullvm",
|
||||
"windows_i686_msvc",
|
||||
"windows_x86_64_gnu",
|
||||
"windows_x86_64_gnullvm",
|
||||
"windows_x86_64_msvc",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows_aarch64_gnullvm"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3"
|
||||
|
||||
[[package]]
|
||||
name = "windows_aarch64_msvc"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469"
|
||||
|
||||
[[package]]
|
||||
name = "windows_i686_gnu"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b"
|
||||
|
||||
[[package]]
|
||||
name = "windows_i686_gnullvm"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66"
|
||||
|
||||
[[package]]
|
||||
name = "windows_i686_msvc"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66"
|
||||
|
||||
[[package]]
|
||||
name = "windows_x86_64_gnu"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78"
|
||||
|
||||
[[package]]
|
||||
name = "windows_x86_64_gnullvm"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d"
|
||||
|
||||
[[package]]
|
||||
name = "windows_x86_64_msvc"
|
||||
version = "0.52.6"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec"
|
||||
|
|
|
@ -1,10 +1,11 @@
|
|||
[package]
|
||||
name = "newestidmangler"
|
||||
version = "0.3.0"
|
||||
name = "idmanglercli"
|
||||
version = "0.3.1"
|
||||
edition = "2021"
|
||||
|
||||
[dependencies]
|
||||
base64 = "0.22.1"
|
||||
clap = { version = "4.5.20", features = ["derive"] }
|
||||
idmangler-lib = "0.3.0"
|
||||
serde = { version = "1.0", features = ["derive"] }
|
||||
serde_json = "1.0"
|
||||
|
|
267
config.json
267
config.json
|
@ -3,11 +3,10 @@
|
|||
"Refer to config.md to understand how to apply the data shown here.",
|
||||
"There are also some values you cannot increase beyond a limit."
|
||||
],
|
||||
"debug":false,
|
||||
"name":"Singularity",
|
||||
"shiny": {
|
||||
"key": "lootrunsCompleted",
|
||||
"value": 69
|
||||
"key": "playersKilled",
|
||||
"value": 9223372036854775807
|
||||
},
|
||||
"ids": [
|
||||
{"id": "mainAttackDamage","base": 320,"roll": 69},
|
||||
|
@ -21,10 +20,262 @@
|
|||
],
|
||||
"powder_limit": 255,
|
||||
"powders": [
|
||||
{ "type":"T", "tier":6, "amount":5 },
|
||||
{"type":"e","tier":6,"amount":5},
|
||||
{"type":"f", "tier":6,"amount":1},
|
||||
{ "type" : "f" , "tier":6 }
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6},
|
||||
{"type":"E", "tier":6},
|
||||
{"type":"T", "tier":6},
|
||||
{"type":"W", "tier":6},
|
||||
{"type":"F", "tier":6},
|
||||
{"type":"A", "tier":6}
|
||||
|
||||
],
|
||||
"rerolls": 0
|
||||
"rerolls": 255
|
||||
}
|
80
src/main.rs
80
src/main.rs
|
@ -17,54 +17,57 @@ use std::collections::HashMap;
|
|||
use std::fs;
|
||||
use std::panic;
|
||||
use std::env;
|
||||
use std::string::ToString;
|
||||
use serde_json;
|
||||
use serde::Deserialize;
|
||||
mod structures;
|
||||
use crate::structures::*;
|
||||
|
||||
// structs
|
||||
#[derive(Deserialize)]
|
||||
struct Powder {
|
||||
r#type: char,
|
||||
tier: u8,
|
||||
amount: Option<u8>
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
struct Identificationer {
|
||||
id: String,
|
||||
base: i32,
|
||||
roll: Option<u8>
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
struct jsonconfig {
|
||||
debug:Option<bool>,
|
||||
name: String,
|
||||
shiny: Option<shinyjson>,
|
||||
ids: Vec<Identificationer>,
|
||||
powder_limit: u8,
|
||||
powders: Vec<Powder>,
|
||||
rerolls:Option<u8>
|
||||
}
|
||||
|
||||
#[derive(Deserialize)]
|
||||
struct shinystruct{
|
||||
id: u8,
|
||||
key:String
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
struct shinyjson {
|
||||
key: String,
|
||||
value: i64
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
use clap::Parser;
|
||||
|
||||
#[derive(Parser, Debug)]
|
||||
#[command(version, about, long_about = None)]
|
||||
struct Args {
|
||||
/// Path for config path
|
||||
#[arg(short, long)]
|
||||
configpath: Option<String>,
|
||||
|
||||
/// Enable debug mode
|
||||
#[arg(short, long, default_value_t = false)]
|
||||
debugmode: bool,
|
||||
}
|
||||
|
||||
// const fallbackconfigpath: String = "config.json".to_owned();
|
||||
|
||||
fn main() {
|
||||
// enable fancypanic when building for release
|
||||
// fancypanic();
|
||||
let args = Args::parse();
|
||||
|
||||
|
||||
|
||||
let mut debugMode = false;
|
||||
if args.debugmode == true {
|
||||
debugMode = true;
|
||||
println!("Debug mode enabled");
|
||||
};
|
||||
let mut configpath:String = String::from("config.json");
|
||||
if let Some(configpathargs) = args.configpath {
|
||||
configpath = configpathargs;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// newest json reading code
|
||||
let json_config: jsonconfig = serde_json::from_reader(
|
||||
fs::File::open("config.json").expect(ERROR[1]))
|
||||
fs::File::open(configpath).expect(ERROR[1]))
|
||||
.expect(ERROR[2]);
|
||||
let idsmap: HashMap<String, u8> = serde_json::from_reader(
|
||||
fs::File::open("id_keys.json").expect(ERROR[3]))
|
||||
|
@ -74,13 +77,6 @@ fn main() {
|
|||
.expect(ERROR[6]);
|
||||
// println!("{:?}",idsmap.get("airDamage"));
|
||||
|
||||
let mut debugMode = false;
|
||||
if let Some(debuggering) = json_config.debug {
|
||||
if debuggering == true {
|
||||
debugMode = true;
|
||||
println!("Debug mode enabled");
|
||||
}
|
||||
};
|
||||
|
||||
let mut out = Vec::new();
|
||||
let ver = TransformVersion::Version1;
|
||||
|
|
35
src/structures/mod.rs
Normal file
35
src/structures/mod.rs
Normal file
|
@ -0,0 +1,35 @@
|
|||
use serde::Deserialize;
|
||||
// structs
|
||||
#[derive(Deserialize)]
|
||||
pub struct Powder {
|
||||
pub r#type: char,
|
||||
pub tier: u8,
|
||||
pub amount: Option<u8>
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
pub struct Identificationer {
|
||||
pub id: String,
|
||||
pub base: i32,
|
||||
pub roll: Option<u8>
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
pub struct jsonconfig {
|
||||
pub debug: Option<bool>,
|
||||
pub name: String,
|
||||
pub shiny: Option<shinyjson>,
|
||||
pub ids: Vec<Identificationer>,
|
||||
pub powder_limit: u8,
|
||||
pub powders: Vec<Powder>,
|
||||
pub rerolls:Option<u8>
|
||||
}
|
||||
|
||||
#[derive(Deserialize)]
|
||||
pub struct shinystruct{
|
||||
pub id: u8,
|
||||
pub key:String
|
||||
}
|
||||
#[derive(Deserialize)]
|
||||
pub struct shinyjson {
|
||||
pub key: String,
|
||||
pub value: i64
|
||||
}
|
Loading…
Reference in a new issue