diff options
Diffstat (limited to 'src/bin')
-rw-r--r-- | src/bin/debug.rs (renamed from src/bin/parse.rs) | 20 | ||||
-rw-r--r-- | src/bin/json.rs | 35 |
2 files changed, 43 insertions, 12 deletions
diff --git a/src/bin/parse.rs b/src/bin/debug.rs index 273cffd..5da7c03 100644 --- a/src/bin/parse.rs +++ b/src/bin/debug.rs @@ -2,13 +2,9 @@ use log::debug; use std::{ env::args, fs::File, - io::{BufReader, Read, Seek, SeekFrom}, -}; -use unity_tools::{ - object::{Value, read_value}, - serialized_file::{TypeTreeNode, read_serialized_file}, - unityfs::UnityFS, + io::{BufReader, Seek, SeekFrom}, }; +use unity_tools::{object::read_value, serialized_file::read_serialized_file, unityfs::UnityFS}; fn main() -> anyhow::Result<()> { env_logger::init_from_env("LOG"); @@ -47,7 +43,7 @@ fn main() -> anyhow::Result<()> { // } // } // fn print_crit_types(tt: &TypeTreeNode) { - // let mut crit = tt.byte_size == -1; + // let mut crit = tt.byte_size == -1 || tt.children.is_empty(); // for c in &tt.children { // print_crit_types(&c); // crit &= c.byte_size != -1 @@ -56,11 +52,11 @@ fn main() -> anyhow::Result<()> { // println!("{}", tt.type_string); // } // } - if let Some(tree) = &typetree.type_tree { - println!("{}", tree.type_string); - // print_crit_types(tree); - // print_types(tree); - } + // if let Some(tree) = &typetree.type_tree { + // println!("{}", tree.type_string); + // print_crit_types(tree); + // print_types(tree); + // } // eprintln!("{typetree:#?}"); let value = read_value(typetree.type_tree.as_ref().unwrap(), e, &mut cab)?; diff --git a/src/bin/json.rs b/src/bin/json.rs new file mode 100644 index 0000000..a9685ed --- /dev/null +++ b/src/bin/json.rs @@ -0,0 +1,35 @@ +use std::{ + env::args, + fs::File, + io::{BufReader, Seek, SeekFrom, stdout}, +}; +use unity_tools::{object::read_value, serialized_file::read_serialized_file, unityfs::UnityFS}; + +fn main() -> anyhow::Result<()> { + env_logger::init_from_env("LOG"); + let file = BufReader::new(File::open(args().nth(1).unwrap())?); + let mut fs = UnityFS::open(file)?; + + for node in fs.nodes().to_vec() { + if node.name.ends_with(".resource") || node.name.ends_with(".resS") { + continue; + } + let mut cab = fs.read(&node)?; + let file = read_serialized_file(&mut cab)?; + let e = file.endianness; + + for ob in file.objects { + cab.seek(SeekFrom::Start(ob.data_offset))?; + let typetree = if ob.type_id < 0 { + unimplemented!() + } else { + &file.types[ob.type_id as usize] + }; + let value = read_value(typetree.type_tree.as_ref().unwrap(), e, &mut cab)?; + serde_json::to_writer(stdout(), &value.to_json()).unwrap(); + println!() + } + } + + Ok(()) +} |