Skip to content

Instantly share code, notes, and snippets.

@brianairb
Created August 31, 2016 02:43
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save brianairb/e68b013d515f24152b0c5c74de74eeaa to your computer and use it in GitHub Desktop.
Save brianairb/e68b013d515f24152b0c5c74de74eeaa to your computer and use it in GitHub Desktop.
#!/usr/bin/env python
#
# Extracts all of the function names from the doxygen XML and generates a
# matching regex to be used for highlighting.
#
import json
import sys
import xml.etree.ElementTree as ET
def description_to_string(node):
return '\n'.join([el.text or '' for el in node]).strip()
def main(path):
tree = ET.parse(path)
builtins = []
for func in tree.findall(".//sectiondef[@kind='func']/memberdef[@kind='function']"):
params = {}
i = 0
for param in func.findall('./param'):
params[param.find('declname').text] = {
'label': '%s %s' % (param.find('type').text, param.find('declname').text),
'order': i,
}
i += 1
for item in func.findall('.//parameteritem'):
params[item.find('.//parametername').text]['documentation'] = description_to_string(item.find('.//parameterdescription'))
builtins += [{
'name': func.find('name').text,
'text': '%s %s' % (func.find('definition').text, func.find('argsstring').text),
'return': func.find('type').text,
'brief': description_to_string(func.find('briefdescription')),
'detailed': description_to_string(func.find('detaileddescription')),
'signature': {
'label': '%s %s' % (func.find('definition').text, func.find('argsstring').text),
'documentation': description_to_string(func.find('briefdescription')),
'parameters': list(sorted(params.values(), key=lambda x: x['order'])),
},
}]
json.dump(builtins, sys.stdout)
if __name__ == '__main__':
if len(sys.argv) < 2:
print 'Usage: %s xml-file' % sys.argv[0]
sys.exit(1)
main(sys.argv[1])
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment