-
Notifications
You must be signed in to change notification settings - Fork 25
/
parsecheck.go
93 lines (80 loc) · 2.39 KB
/
parsecheck.go
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package main
import (
"github.com/mogaika/god_of_war_browser/pack/wad/twk"
"github.com/mogaika/god_of_war_browser/pack/wad/twk/twktree"
//"encoding/binary"
"log"
"sort"
"strings"
"github.com/mogaika/god_of_war_browser/pack"
file_wad "github.com/mogaika/god_of_war_browser/pack/wad"
// "github.com/mogaika/god_of_war_browser/pack/wad/mesh"
"github.com/mogaika/god_of_war_browser/vfs"
)
func parseCheck(rootfs vfs.Directory) {
packList, err := rootfs.List()
if err != nil {
log.Fatal(err)
}
sort.Sort(sort.Reverse(sort.StringSlice(packList)))
for _, fname := range packList {
if !strings.HasSuffix(fname, ".WAD") && !strings.HasSuffix(fname, ".wad_psp2") {
continue
}
log.Printf("Parsecheck %q", fname)
data, _ := pack.GetInstanceHandler(rootfs, fname)
if data == nil {
continue
}
switch data.(type) {
case *file_wad.Wad:
wad := data.(*file_wad.Wad)
for _, node := range wad.Nodes {
if node.Parent != file_wad.NODE_INVALID {
continue
}
if strings.HasPrefix(node.Tag.Name, "TWK_") {
// log.Printf("Parsing %s:%s: %v", wad.Name(), node.Tag.Name, err)
fi, _, err := wad.GetInstanceFromNode(node.Id)
if err != nil {
// log.Printf("Failed to parse %s:%s: %v", wad.Name(), node.Tag.Name, err)
} else if tw, ok := fi.(*twk.TWK); !ok {
log.Printf("Failed to get twk from %s:%s", wad.Name(), node.Tag.Name)
} else {
if _, err := twktree.Root().UnmarshalTWK(tw.Tree); err != nil {
log.Printf("Failed to parse abstarct tree for %s:%s: %v", wad.Name(), node.Tag.Name, err)
}
}
}
/*
if strings.HasPrefix(node.Tag.Name, "ESC_") {
log.Printf("Parsing %s:%s: %v", wad.Name(), node.Tag.Name, err)
_, _, err := wad.GetInstanceFromNode(node.Id)
if err != nil {
log.Printf("Failed to parse %s:%s: %v", wad.Name(), node.Tag.Name, err)
}
}
*/
/*
if len(node.Tag.Data) != 0 {
for _, onode := range wad.Nodes {
if onode.Parent != file_wad.NODE_INVALID || len(onode.Tag.Data) == 0 {
continue
}
if onode.Tag.Id >= node.Tag.Id {
break
}
if node.Tag.Name == onode.Tag.Name {
log.Printf("Conflicting name %q [%d:%q:%d] [%d:%q:%d]",
wad.Name(),
node.Tag.Id, node.Tag.Name, node.Tag.Size,
onode.Tag.Id, onode.Tag.Name, node.Tag.Size)
break
}
}
}
*/
}
}
}
}