summaryrefslogtreecommitdiff
path: root/pokemontools/scan_includes.py
diff options
context:
space:
mode:
authoryenatch <yenatch@gmail.com>2014-10-02 23:30:28 -0400
committeryenatch <yenatch@gmail.com>2014-10-02 23:30:28 -0400
commit0a68945a485ea3093eec9fc5fa75d3286595b053 (patch)
treeb8e3afb691ab1348737097260ae55561f97145f3 /pokemontools/scan_includes.py
parent5cce99014065cdd2e25551b625b1783d97546abd (diff)
parentc3da5178f542e2f9207f6b99d088db261765749a (diff)
Merge remote-tracking branch 'origin/master' into fix-map-editor
Diffstat (limited to 'pokemontools/scan_includes.py')
-rw-r--r--pokemontools/scan_includes.py79
1 files changed, 54 insertions, 25 deletions
diff --git a/pokemontools/scan_includes.py b/pokemontools/scan_includes.py
index 7f34e92..e8255ac 100644
--- a/pokemontools/scan_includes.py
+++ b/pokemontools/scan_includes.py
@@ -1,36 +1,65 @@
+#!/bin/python
# coding: utf-8
"""
-Recursively scan an asm file for rgbasm INCLUDEs and INCBINs.
-Used to generate dependencies for each rgbasm object.
+Recursively scan an asm file for dependencies.
"""
import os
import sys
+import argparse
-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
+
+class IncludeReader:
+ """
+ Usage:
+ includer = IncludeReader()
+ includer.read(filename)
+ or
+ includer = IncludeReader(filename='filename.asm')
+ includer.read()
+ """
+ path = ''
+ includes = []
+ directives = ['INCLUDE', 'INCBIN']
+ extensions = ['.asm', '.tx']
+
+ def __init__(self, **kwargs):
+ self.__dict__.update(kwargs)
+
+ def read(self, filename=None):
+ """
+ Recursively look for includes in <filename> and add them to self.includes.
+ """
+ if filename is None:
+ if hasattr(self, 'filename'):
+ filename = os.path.join(self.path, self.filename)
+ else:
+ raise Exception, 'no filename given!'
+ if os.path.splitext(filename)[1] in self.extensions and os.path.exists(filename):
+ for line in open(filename).readlines():
+ self.read_line(line)
+
+ def read_line(self, line):
+ """
+ Add any includes in <line> to self.includes, and look for includes in those.
+ """
+ parts = line[:line.find(';')].split()
+ for directive in self.directives:
+ if directive in map(str.upper, parts):
+ include = os.path.join(self.path, parts[parts.index(directive) + 1].split('"')[1])
+ if include not in self.includes:
+ self.includes.append(include)
+ self.read(include)
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))
+ ap = argparse.ArgumentParser()
+ ap.add_argument('-i', default='')
+ ap.add_argument('filenames', nargs='*')
+ args = ap.parse_args()
+
+ includes = IncludeReader(path=args.i)
+ for filename in args.filenames:
+ includes.read(filename)
+ sys.stdout.write(' '.join(includes.includes))