aboutsummaryrefslogtreecommitdiff
path: root/exporter/src/bin/debug.rs
blob: b1d8d124971f895140876415bfdd08b2f2967f69 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
use std::{env::args, fs::File, io::BufReader};
use unity_tools::{serialized_file::SerializedFile, unityfs::UnityFS};

fn main() -> anyhow::Result<()> {
    env_logger::init_from_env("LOG");
    let file = BufReader::new(File::open(args().nth(1).unwrap())?);
    let fs = UnityFS::open(file)?;

    let node = fs.find_main_file().unwrap().to_owned();
    let mut cab = fs.read(&node)?;
    let file = SerializedFile::read(&mut cab, 0)?;
    let shared_assets = if let Some(n) = file.find_fs_shared_assets(&fs) {
        Some(SerializedFile::read(fs.read(&n)?, 1)?)
    } else {
        None
    };

    for ob in file.objects {
        // eprintln!("{:#?}", ob);
        let typetree = if ob.type_id < 0 {
            unimplemented!()
        } else {
            // file.types
            //     .iter()
            //     .find(|t| t.class_id == ob.type_id)
            //     .expect("unknown type")
            &file.types[ob.type_id as usize]
        };
        // fn print_types(tt: &TypeTreeNode) {
        //     println!("{}", tt.type_string);
        //     for c in &tt.children {
        //         print_types(&c);
        //     }
        // }
        // fn print_crit_types(tt: &TypeTreeNode) {
        //     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
        //     }
        //     if crit {
        //         println!("{}", tt.type_string);
        //     }
        // }
        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)?;

        // if let Value::Object { class, .. } = &value {
        //     println!("{class}")
        // }

        // debug!(
        //     "{}",
        //     serde_json::to_string_pretty(&value.to_json()).unwrap()
        // )
    }
    eprintln!("{:#?}", file.externals);
    if let Some(shared_assets) = shared_assets {
        eprintln!("{:#?}", shared_assets);
        for ob in shared_assets.objects {
            let typetree = if ob.type_id < 0 {
                unimplemented!()
            } else {
                &file.types[ob.type_id as usize]
            };

            if let Some(tree) = &typetree.type_tree {
                println!("{}", tree.type_string);
            }
        }
    }
    Ok(())
}