-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathunity2yaml
98 lines (68 loc) · 3.13 KB
/
unity2yaml
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
94
95
96
97
98
#!/usr/bin/env python
import os
import sys
from collections import OrderedDict
from argparse import ArgumentParser
#import yaml
import oyaml as yaml
import unitypack
from unitypack.asset import Asset
from unitypack.object import ObjectPointer
def handle_asset(asset):
for id, obj in asset.objects.items():
d = obj.read()
print(yaml.dump(d))
#def ordereddict_representer(dumper, data):
# return dumper.represent_dict(data.iteritems())
#return dumper.represent_scalar("!ordereddict", "DICT")
#yaml.add_representer(OrderedDict, ordereddict_representer)
def asset_representer(dumper, data):
return dumper.represent_scalar("!asset", data.name)
yaml.add_representer(Asset, asset_representer)
def objectpointer_representer(dumper, data):
#return yaml.SequenceNode(tag=u'tag:yaml.org,2002:seq', value=[ data.path_id,data.file_id])
#print(data.resolve())
return yaml.SequenceNode(tag=u'tag:yaml.org,2002:seq', value=[ yaml.ScalarNode(tag=u'tag:yaml.org,2002:str', value=str(data.path_id)), yaml.ScalarNode(tag=u'tag:yaml.org,2002:str', value=str(data.file_id))])
#return yaml.ScalarNode(tag=u'tag:yaml.org,2002:str', value="[" + str(data.file_id)+","+ str(data.path_id)+"]")
#return dumper.represent_sequence("!PPtr", [data.file_id, data.path_id])
yaml.add_representer(ObjectPointer, objectpointer_representer)
def unityobj_representer(dumper, data):
return dumper.represent_mapping("!unitypack:%s" % (data.__class__.__name__), data._obj)
def shader_representer(dumper, data):
return dumper.represent_mapping("!unitypack:stripped:Shader", {data.name: None})
def textasset_representer(dumper, data):
return dumper.represent_mapping("!unitypack:stripped:TextAsset", {data.name: None})
def texture2d_representer(dumper, data):
return dumper.represent_mapping("!unitypack:stripped:Texture2D", {data.name: None})
def mesh_representer(dumper, data):
return dumper.represent_mapping("!unitypack:stripped:Mesh", {data.name: None})
def movietexture_representer(dumper, data):
obj = data._obj.copy()
obj["m_MovieData"] = "<stripped>"
return dumper.represent_mapping("!unitypack:stripped:MovieTexture", obj)
def main():
p = ArgumentParser()
p.add_argument("files", nargs="+")
p.add_argument("-s", "--strip", action="store_true", help="Strip extractable data")
args = p.parse_args(sys.argv[1:])
for k, v in unitypack.engine.__dict__.items():
if isinstance(v, type) and issubclass(v, unitypack.engine.object.Object):
yaml.add_representer(v, unityobj_representer)
if args.strip:
yaml.add_representer(unitypack.engine.mesh.Mesh, mesh_representer)
yaml.add_representer(unitypack.engine.movie.MovieTexture, movietexture_representer)
yaml.add_representer(unitypack.engine.text.Shader, shader_representer)
yaml.add_representer(unitypack.engine.text.TextAsset, textasset_representer)
yaml.add_representer(unitypack.engine.texture.Texture2D, texture2d_representer)
for file in args.files:
if file.endswith(".assets"):
with open(file, "rb") as f:
asset = Asset.from_file(f)
handle_asset(asset)
continue
with open(file, "rb") as f:
bundle = unitypack.load(f)
for asset in bundle.assets:
handle_asset(asset)
if __name__ == "__main__":
main()