diff options
author | Bryan Bishop <kanzure@gmail.com> | 2013-12-18 20:20:09 -0600 |
---|---|---|
committer | Bryan Bishop <kanzure@gmail.com> | 2013-12-18 20:20:09 -0600 |
commit | a07c92d3b38898568077da99ec05a82c69ffcc3c (patch) | |
tree | 44c5466fc998a132a358e319a01cd7c3dca954ed /pokemontools/scan_includes.py | |
parent | a077e470b2b24fc00db75aad220cc381f602bb3e (diff) | |
parent | d8f4e687ebc49d4b135f0d8b7f10a643114a0d8a (diff) |
Merge branch 'master' into path-finding
Diffstat (limited to 'pokemontools/scan_includes.py')
-rw-r--r-- | pokemontools/scan_includes.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/pokemontools/scan_includes.py b/pokemontools/scan_includes.py new file mode 100644 index 0000000..7f34e92 --- /dev/null +++ b/pokemontools/scan_includes.py @@ -0,0 +1,36 @@ +# coding: utf-8 + +""" +Recursively scan an asm file for rgbasm INCLUDEs and INCBINs. +Used to generate dependencies for each rgbasm object. +""" + +import os +import sys + +import configuration +conf = configuration.Config() + +def recursive_scan(filename, includes = []): + if (filename[-4:] == '.asm' or filename[-3] == '.tx') and os.path.exists(filename): + lines = open(filename).readlines() + for line in lines: + for directive in ('INCLUDE', 'INCBIN'): + if directive in line: + line = line[:line.find(';')] + if directive in line: + include = line.split('"')[1] + if include not in includes: + includes += [include] + includes = recursive_scan(os.path.join(conf.path, include), includes) + break + return includes + +if __name__ == '__main__': + filenames = sys.argv[1:] + dependencies = [] + for filename in filenames: + dependencies += recursive_scan(os.path.join(conf.path, filename)) + dependencies = list(set(dependencies)) + sys.stdout.write(' '.join(dependencies)) + |