|
|
@ -124,6 +124,7 @@ def _MacroRefRe(macro_names): |
|
|
|
return re.compile(r'\b(?P<macro_ref>(?P<name>(%s))\((?P<args>.*?)\))' % |
|
|
|
return re.compile(r'\b(?P<macro_ref>(?P<name>(%s))\((?P<args>.*?)\))' % |
|
|
|
'|'.join(macro_names)) |
|
|
|
'|'.join(macro_names)) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def _MacroArgRefRe(macro_arg_names): |
|
|
|
def _MacroArgRefRe(macro_arg_names): |
|
|
|
# Takes in a list of macro arg names and makes a regex that will match |
|
|
|
# Takes in a list of macro arg names and makes a regex that will match |
|
|
|
# uses of those args. |
|
|
|
# uses of those args. |
|
|
@ -318,6 +319,7 @@ class MacroCollection(object): |
|
|
|
return macro.body |
|
|
|
return macro.body |
|
|
|
assert len(arg_values) == len(macro.args) |
|
|
|
assert len(arg_values) == len(macro.args) |
|
|
|
args = dict(zip(macro.args, arg_values)) |
|
|
|
args = dict(zip(macro.args, arg_values)) |
|
|
|
|
|
|
|
|
|
|
|
def _lookupArg(match): |
|
|
|
def _lookupArg(match): |
|
|
|
val = args[match.group('name')] |
|
|
|
val = args[match.group('name')] |
|
|
|
opt = match.group('option') |
|
|
|
opt = match.group('option') |
|
|
@ -350,6 +352,7 @@ class MacroCollection(object): |
|
|
|
|
|
|
|
|
|
|
|
def _EvalMacrosRefs(self, text, macro_stack): |
|
|
|
def _EvalMacrosRefs(self, text, macro_stack): |
|
|
|
macro_ref_re = _MacroRefRe(self._macros.keys()) |
|
|
|
macro_ref_re = _MacroRefRe(self._macros.keys()) |
|
|
|
|
|
|
|
|
|
|
|
def _resolveMacro(match): |
|
|
|
def _resolveMacro(match): |
|
|
|
return self._Expand(match, macro_stack) |
|
|
|
return self._Expand(match, macro_stack) |
|
|
|
return macro_ref_re.sub(_resolveMacro, text) |
|
|
|
return macro_ref_re.sub(_resolveMacro, text) |
|
|
@ -498,7 +501,8 @@ class SourceFile(object): |
|
|
|
result.append('//%%PDDM-EXPAND-END %s' % |
|
|
|
result.append('//%%PDDM-EXPAND-END %s' % |
|
|
|
captured_lines[0][directive_len:].strip()) |
|
|
|
captured_lines[0][directive_len:].strip()) |
|
|
|
else: |
|
|
|
else: |
|
|
|
result.append('//%%PDDM-EXPAND-END (%s expansions)' % len(captured_lines)) |
|
|
|
result.append('//%%PDDM-EXPAND-END (%s expansions)' % |
|
|
|
|
|
|
|
len(captured_lines)) |
|
|
|
|
|
|
|
|
|
|
|
return result |
|
|
|
return result |
|
|
|
|
|
|
|
|
|
|
@ -669,15 +673,15 @@ def main(args): |
|
|
|
|
|
|
|
|
|
|
|
if src_file.processed_content != src_file.original_content: |
|
|
|
if src_file.processed_content != src_file.original_content: |
|
|
|
if not opts.dry_run: |
|
|
|
if not opts.dry_run: |
|
|
|
print 'Updating for "%s".' % a_path |
|
|
|
print('Updating for "%s".' % a_path) |
|
|
|
with open(a_path, 'w') as f: |
|
|
|
with open(a_path, 'w') as f: |
|
|
|
f.write(src_file.processed_content) |
|
|
|
f.write(src_file.processed_content) |
|
|
|
else: |
|
|
|
else: |
|
|
|
# Special result to indicate things need updating. |
|
|
|
# Special result to indicate things need updating. |
|
|
|
print 'Update needed for "%s".' % a_path |
|
|
|
print('Update needed for "%s".' % a_path) |
|
|
|
result = 1 |
|
|
|
result = 1 |
|
|
|
elif opts.verbose: |
|
|
|
elif opts.verbose: |
|
|
|
print 'No update for "%s".' % a_path |
|
|
|
print('No update for "%s".' % a_path) |
|
|
|
|
|
|
|
|
|
|
|
return result |
|
|
|
return result |
|
|
|
|
|
|
|
|
|
|
|