Compare commits

...

3 Commits

Author SHA1 Message Date
iceyrazor 6586da02a2 Merge branch 'long'
fixes to main. idk
2025-02-11 22:48:58 -06:00
iceyrazor 194e394b49 LICENSE 2025-02-10 21:11:31 -06:00
iceyrazor a1f5d5f917 trunic 2025-02-09 17:14:55 -06:00
1 changed files with 79 additions and 85 deletions

View File

@ -1,9 +1,6 @@
#![allow(unused)] //#![allow(unused)]
use toml::{value::Array, Table};
//use std::io; //use std::io;
use std::fs; use std::fs;
use std::option;
use std::any::{Any, TypeId};
use serde::Deserialize; use serde::Deserialize;
use struct_iterable::Iterable; use struct_iterable::Iterable;
@ -111,18 +108,18 @@ fn main() {
} }
} }
let mut i=0; let mut i=0;
for (name) in &toml_data.prof_throws { for name in &toml_data.prof_throws {
dnd_data.prof_throws[i]=name.to_string(); dnd_data.prof_throws[i]=name.to_string();
i=i+1; i=i+1;
} }
i=0; i=0;
for (name) in &toml_data.skill_prof_bonuses{ for name in &toml_data.skill_prof_bonuses{
dnd_data.skill_prof_bonuses[i][0]=name[0].to_string(); dnd_data.skill_prof_bonuses[i][0]=name[0].to_string();
dnd_data.skill_prof_bonuses[i][1]=name[1].to_string(); dnd_data.skill_prof_bonuses[i][1]=name[1].to_string();
i=i+1; i=i+1;
} }
i=0; i=0;
for (name) in &toml_data.prof_throws { for name in &toml_data.prof_throws {
match name.as_str(){ match name.as_str(){
"str" => dnd_data.prof_throws_vec[0]=dnd_data.profiency as i64, "str" => dnd_data.prof_throws_vec[0]=dnd_data.profiency as i64,
"dex" => dnd_data.prof_throws_vec[1]=dnd_data.profiency as i64, "dex" => dnd_data.prof_throws_vec[1]=dnd_data.profiency as i64,
@ -135,12 +132,12 @@ fn main() {
i=i+1; i=i+1;
} }
i=0; i=0;
for (name) in &toml_data.prof_skills { for name in &toml_data.prof_skills {
dnd_data.prof_skills[i]=name.to_string(); dnd_data.prof_skills[i]=name.to_string();
i=i+1; i=i+1;
} }
i=0; i=0;
for (name) in &toml_data.list.skills { for name in &toml_data.list.skills {
dnd_data.skills_names[i][0]=name[0].to_string(); dnd_data.skills_names[i][0]=name[0].to_string();
dnd_data.skills_names[i][1]=name[1].to_string(); dnd_data.skills_names[i][1]=name[1].to_string();
i=i+1; i=i+1;
@ -199,7 +196,6 @@ fn main() {
dnd_data.throws[i]=dnd_data.prof_throws_vec[i] + val; dnd_data.throws[i]=dnd_data.prof_throws_vec[i] + val;
i=i+1 i=i+1
} }
i=0;
fn base_to_num(str: String) -> usize{ fn base_to_num(str: String) -> usize{
match str.as_str(){ match str.as_str(){
"str" => return 0, "str" => return 0,
@ -210,7 +206,8 @@ fn main() {
"charis" => return 5, "charis" => return 5,
_ => return 0, _ => return 0,
} }
}; }
i=0; i=0;
for name in &dnd_data.skills_names{ for name in &dnd_data.skills_names{
let mut modi=0; let mut modi=0;
@ -229,7 +226,6 @@ fn main() {
dnd_data.skills[i].modi=modi as i64; dnd_data.skills[i].modi=modi as i64;
i=i+1; i=i+1;
modi=0;
} }
println!("profiency: {}",dnd_data.profiency); println!("profiency: {}",dnd_data.profiency);
@ -263,42 +259,40 @@ fn main() {
i=i+1 i=i+1
} }
println!("---------"); println!("---------");
i=0;
for val in &dnd_data.skills{ for val in &dnd_data.skills{
if val.name!=""{ if val.name!=""{
println!("{} : {}",val.name,val.modi); println!("{} : {}",val.name,val.modi);
} }
} }
i=0;
} }
// need to convert to hash map // need to convert to hash map
/* /*
// Deserialize the entire TOML data into a HashMap<String, toml::Value> // Deserialize the entire TOML data into a HashMap<String, toml::Value>
let toml_data: HashMap<String, Value> = from_str(toml_str).unwrap(); let toml_data: HashMap<String, Value> = from_str(toml_str).unwrap();
// Accessing base_bonuses as a Table (nested structure) // Accessing base_bonuses as a Table (nested structure)
if let Some(base_bonuses) = toml_data.get("base_bonuses").and_then(Value::as_table) { if let Some(base_bonuses) = toml_data.get("base_bonuses").and_then(Value::as_table) {
// Iterate over the keys and values in the base_bonuses table // Iterate over the keys and values in the base_bonuses table
for (name, val) in base_bonuses.iter() { for (name, val) in base_bonuses.iter() {
// Try to downcast to Option<i64> // Try to downcast to Option<i64>
match val.downcast_ref::<Option<i64>>() { match val.downcast_ref::<Option<i64>>() {
Some(Some(x)) => { Some(Some(x)) => {
// Handle the case where it's an Option<i64> with a value // Handle the case where it's an Option<i64> with a value
println!("{}: {}", name, x); println!("{}: {}", name, x);
}, },
Some(None) => { Some(None) => {
// Handle the case where it's an Option<i64> but the value is None // Handle the case where it's an Option<i64> but the value is None
println!("{}: None", name); println!("{}: None", name);
}, },
None => { None => {
// Handle the case where it's not an Option<i64> // Handle the case where it's not an Option<i64>
println!("{}: Not an Option<i64>", name); println!("{}: Not an Option<i64>", name);
} }
} }
} }
} else { } else {
println!("base_bonuses not found or not a table"); println!("base_bonuses not found or not a table");
} }
*/ */