Compare commits

..

No commits in common. "0c7f30a73dd0854e09fe980e878aba7ff7f49543" and "8bc131c7fea1feadac20b57ca4da4ce9a9df6f61" have entirely different histories.

5 changed files with 33 additions and 67 deletions

13
Cargo.lock generated
View file

@ -127,7 +127,6 @@ dependencies = [
"idmangler-lib", "idmangler-lib",
"serde", "serde",
"serde_json", "serde_json",
"thiserror",
] ]
[[package]] [[package]]
@ -212,9 +211,9 @@ checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f"
[[package]] [[package]]
name = "syn" name = "syn"
version = "2.0.87" version = "2.0.77"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "25aa4ce346d03a6dcd68dd8b4010bcb74e54e62c90c573f394c46eae99aba32d" checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",
@ -223,18 +222,18 @@ dependencies = [
[[package]] [[package]]
name = "thiserror" name = "thiserror"
version = "1.0.68" version = "1.0.63"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "02dd99dc800bbb97186339685293e1cc5d9df1f8fae2d0aecd9ff1c77efea892" checksum = "c0342370b38b6a11b6cc11d6a805569958d54cfa061a29969c3b5ce2ea405724"
dependencies = [ dependencies = [
"thiserror-impl", "thiserror-impl",
] ]
[[package]] [[package]]
name = "thiserror-impl" name = "thiserror-impl"
version = "1.0.68" version = "1.0.63"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a7c61ec9a6f64d2793d8a45faba21efbe3ced62a886d44c36a009b2b519b4c7e" checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",

View file

@ -9,4 +9,3 @@ clap = { version = "4.5.20", features = ["derive"] }
idmangler-lib = "0.3.0" idmangler-lib = "0.3.0"
serde = { version = "1.0", features = ["derive"] } serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0" serde_json = "1.0"
thiserror = "1.0.68"

View file

@ -1,31 +0,0 @@
use thiserror::Error;
/// Errors yep
#[derive(Error, Debug)]
pub enum Errorfr {
/// config json is missing
#[error("Error 1: json config json is missing, obtain it from https://git.frfrnocap.men/endernon/idmangler-cli/raw/branch/main/config.json and move it to this directory. "
)]
JsonMissing,
/// config json is corrupt
#[error("Error 2: json config json is corrupt. Reread config.md or reobtain it from https://git.frfrnocap.men/endernon/idmangler-cli/raw/branch/main/config.json and move it to this diirectory. "
)]
JsonCorrupt,
/// idmap is missing
#[error("Error 3: Identifications hashmap is missing. Get it from https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Reference/id_keys.json and move it to this directory. ")]
IDMapMissing,
/// idmap is corrupt
#[error("Error 4: Identifications hashmap is corrupt. Reobtain it from https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Reference/id_keys.json and move it to this directory. ")]
IDMapCorrupt,
/// shiny data json is missing
#[error("Error 5: Shiny data json is missing. Get it from https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Data-Storage/shiny_stats.json and move it to this directory. ")]
ShinyJsonMissing,
/// shiny data json is corrupt
#[error("Error 6: Shiny data json is corrupt. Get it from https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Data-Storage/shiny_stats.json and move it to this directory. ")]
ShinyJsonCorrupt
}

View file

@ -10,10 +10,9 @@ use idmangler_lib::{
use std::collections::HashMap; use std::collections::HashMap;
use std::fs; use std::fs;
use std::panic; use std::panic;
use std::string::ToString;
mod structures; mod structures;
use crate::structures::*; use crate::structures::*;
mod errorfr;
use crate::errorfr::Errorfr;
use clap::Parser; use clap::Parser;
@ -31,14 +30,14 @@ struct Args {
// const fallbackconfigpath: String = "config.json".to_owned(); // const fallbackconfigpath: String = "config.json".to_owned();
fn main() -> Result<(), Errors> { fn main() {
// enable fancypanic when building for release // enable fancypanic when building for release
// fancypanic(); // fancypanic();
let args = Args::parse(); let args = Args::parse();
let mut debug_mode = false; let mut debugMode = false;
if args.debugmode == true { if args.debugmode == true {
debug_mode = true; debugMode = true;
println!("Debug mode enabled"); println!("Debug mode enabled");
}; };
let mut configpath: String = String::from("config.json"); let mut configpath: String = String::from("config.json");
@ -47,12 +46,11 @@ fn main() -> Result<(), Errors> {
} }
// newest json reading code // newest json reading code
let json_config: Jsonconfig = serde_json::from_reader(fs::File::open(configpath) let json_config: jsonconfig =
.map_err(|_| Errorfr::JsonMissing)?) serde_json::from_reader(fs::File::open(configpath).expect(ERROR[1])).expect(ERROR[2]);
.map_err(|_| Errorfr::JsonCorrupt)?;
let idsmap: HashMap<String, u8> = let idsmap: HashMap<String, u8> =
serde_json::from_reader(fs::File::open("id_keys.json").expect(ERROR[3])).expect(ERROR[4]); serde_json::from_reader(fs::File::open("id_keys.json").expect(ERROR[3])).expect(ERROR[4]);
let json_shiny: Vec<Shinystruct> = let json_shiny: Vec<shinystruct> =
serde_json::from_reader(fs::File::open("shiny_stats.json").expect(ERROR[5])) serde_json::from_reader(fs::File::open("shiny_stats.json").expect(ERROR[5]))
.expect(ERROR[6]); .expect(ERROR[6]);
// println!("{:?}",idsmap.get("airDamage")); // println!("{:?}",idsmap.get("airDamage"));
@ -111,7 +109,7 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::EARTH, powdertier)) powdervec.push((Powders::EARTH, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Earth"); println!("Powder type: Earth");
} }
} }
@ -119,7 +117,7 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::THUNDER, powdertier)) powdervec.push((Powders::THUNDER, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Thunder"); println!("Powder type: Thunder");
} }
} }
@ -127,7 +125,7 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::WATER, powdertier)) powdervec.push((Powders::WATER, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Water"); println!("Powder type: Water");
} }
} }
@ -135,7 +133,7 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::FIRE, powdertier)) powdervec.push((Powders::FIRE, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Fire"); println!("Powder type: Fire");
} }
} }
@ -143,7 +141,7 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::AIR, powdertier)) powdervec.push((Powders::AIR, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Air"); println!("Powder type: Air");
} }
} }
@ -151,18 +149,18 @@ fn main() -> Result<(), Errors> {
for _i in 0..powderamount { for _i in 0..powderamount {
powdervec.push((Powders::THUNDER, powdertier)) powdervec.push((Powders::THUNDER, powdertier))
} }
if debug_mode { if debugMode {
println!("Powder type: Broken, fallback Thunder"); println!("Powder type: Broken, fallback Thunder");
} }
} }
}; };
if debug_mode { if debugMode {
println!("Powder tier: {}", powdertier); println!("Powder tier: {}", powdertier);
println!("Powder amount: {}", powderamount); println!("Powder amount: {}", powderamount);
} }
} }
if debug_mode { if debugMode {
println!("Powders Vec: {:?}", powdervec); println!("Powders Vec: {:?}", powdervec);
} }
@ -178,7 +176,7 @@ fn main() -> Result<(), Errors> {
Some(i) => { Some(i) => {
if i != 0 { if i != 0 {
RerollData(i).encode(ver, &mut out).unwrap(); RerollData(i).encode(ver, &mut out).unwrap();
if debug_mode { if debugMode {
println!("Rerolls: {}", i) println!("Rerolls: {}", i)
} }
} }
@ -188,21 +186,21 @@ fn main() -> Result<(), Errors> {
let mut realshinykey: u8; let mut realshinykey: u8;
if let Some(shiny) = json_config.shiny { if let Some(shiny) = json_config.shiny {
if let ref _shinykey = shiny.key { if let ref shinykey = shiny.key {
if let shinyvalue = shiny.value { if let shinyvalue = shiny.value {
realshinykey = 1; realshinykey = 1;
for i in json_shiny { for i in json_shiny {
if i.key == shiny.key { if i.key == shiny.key {
realshinykey = i.id; realshinykey = i.id;
if debug_mode { if debugMode {
println!("shiny key {}", shiny.key); println!("shiny key {}", shiny.key);
} }
} }
} }
if debug_mode { if debugMode {
dbg!(&realshinykey); println!("realshinykey: {}", realshinykey);
dbg!(&shinyvalue); println!("shinyvalue: {}", shinyvalue);
} }
ShinyData { ShinyData {
@ -248,7 +246,8 @@ fn fancypanic() {
"{}", "{}",
panic_msg panic_msg
.lines() .lines()
.nth(1) .skip(1)
.next()
.unwrap_or("HOW DID YOU BREAK THE PANIC HANDLER???") .unwrap_or("HOW DID YOU BREAK THE PANIC HANDLER???")
); );
})); }));

View file

@ -13,10 +13,10 @@ pub struct Identificationer {
pub roll: Option<u8>, pub roll: Option<u8>,
} }
#[derive(Deserialize)] #[derive(Deserialize)]
pub struct Jsonconfig { pub struct jsonconfig {
pub debug: Option<bool>, pub debug: Option<bool>,
pub name: String, pub name: String,
pub shiny: Option<Shinyjson>, pub shiny: Option<shinyjson>,
pub ids: Vec<Identificationer>, pub ids: Vec<Identificationer>,
pub powder_limit: u8, pub powder_limit: u8,
pub powders: Vec<Powder>, pub powders: Vec<Powder>,
@ -24,12 +24,12 @@ pub struct Jsonconfig {
} }
#[derive(Deserialize)] #[derive(Deserialize)]
pub struct Shinystruct { pub struct shinystruct {
pub id: u8, pub id: u8,
pub key: String, pub key: String,
} }
#[derive(Deserialize)] #[derive(Deserialize)]
pub struct Shinyjson { pub struct shinyjson {
pub key: String, pub key: String,
pub value: i64, pub value: i64,
} }