summaryrefslogtreecommitdiff
path: root/test/CheckTexinfo.py
diff options
context:
space:
mode:
authorCraig Earls <enderw88@gmail.com>2015-02-08 12:49:04 -0700
committerCraig Earls <enderw88@gmail.com>2015-02-08 12:49:04 -0700
commitfe48f607be7b9da8d2c4ac1fb30078dea55b8240 (patch)
tree252237bce18eb4a5e27246ea5cd197e58be4d7f4 /test/CheckTexinfo.py
parent204568d5145c77b3cf3bccd49c9ad6780b4b1fe1 (diff)
parentbc487be14bd1a79cbbedb9203921b357ced79ef7 (diff)
downloadfork-ledger-fe48f607be7b9da8d2c4ac1fb30078dea55b8240.tar.gz
fork-ledger-fe48f607be7b9da8d2c4ac1fb30078dea55b8240.tar.bz2
fork-ledger-fe48f607be7b9da8d2c4ac1fb30078dea55b8240.zip
Merge commit 'bc487be14bd1a79cbbedb9203921b357ced79ef7' into next
Diffstat (limited to 'test/CheckTexinfo.py')
-rwxr-xr-xtest/CheckTexinfo.py41
1 files changed, 39 insertions, 2 deletions
diff --git a/test/CheckTexinfo.py b/test/CheckTexinfo.py
index 34d0e153..cd167eba 100755
--- a/test/CheckTexinfo.py
+++ b/test/CheckTexinfo.py
@@ -16,10 +16,47 @@ from CheckOptions import CheckOptions
class CheckTexinfo (CheckOptions):
def __init__(self, args):
CheckOptions.__init__(self, args)
- self.option_pattern = '@item --([-A-Za-z]+).*@c option'
+ self.option_pattern = '^@item\s+--([-A-Za-z]+)'
+ self.function_pattern = '^@defun\s+([-A-Za-z_]+)'
self.source_file = join(self.source, 'doc', 'ledger3.texi')
self.source_type = 'texinfo'
+
+ def find_functions(self, filename):
+ functions = set()
+ state_normal = 0
+ state_function = 1
+ state = state_normal
+ function = None
+ fun_doc = str()
+ fun_example = False
+ item_regex = re.compile(self.function_pattern)
+ itemx_regex = re.compile('^@defunx')
+ example_regex = re.compile('^@smallexample\s+@c\s+command:')
+ fix_regex = re.compile('FIX')
+ comment_regex = re.compile('^\s*@c')
+ for line in open(filename):
+ line = line.strip()
+ if state == state_normal:
+ match = item_regex.match(line)
+ if match:
+ state = state_function
+ function = match.group(1)
+ elif state == state_function:
+ if line == '@end defun':
+ if function and fun_example and len(fun_doc) and not fix_regex.search(fun_doc):
+ functions.add(function)
+ state = state_normal
+ fun_example = None
+ fun_doc = str()
+ elif itemx_regex.match(line):
+ continue
+ elif example_regex.match(line):
+ fun_example = True
+ elif not comment_regex.match(line):
+ fun_doc += line
+ return functions
+
def find_options(self, filename):
options = set()
state_normal = 0
@@ -27,7 +64,7 @@ class CheckTexinfo (CheckOptions):
state = state_normal
option = None
opt_doc = str()
- item_regex = re.compile('^@item --([-A-Za-z]+)')
+ item_regex = re.compile(self.option_pattern)
itemx_regex = re.compile('^@itemx')
fix_regex = re.compile('FIX')
comment_regex = re.compile('^\s*@c')