diff options
author | Lars Luthman <lars.luthman@gmail.com> | 2011-03-11 22:26:38 +0000 |
---|---|---|
committer | Lars Luthman <lars.luthman@gmail.com> | 2011-03-11 22:26:38 +0000 |
commit | b98dbcdddff0d758bfeddace5535bdcd4bce174a (patch) | |
tree | a7ffb73ce68ded3bf51c1c1a551d6b6b77b55fe6 /lv2specgen | |
parent | bd4e2d4b86105420c2eed97c37ab9bd7ede0da2b (diff) | |
download | lv2-b98dbcdddff0d758bfeddace5535bdcd4bce174a.tar.xz |
lv2specgen.py creates links for every mention of a header file, preprocessor define, data structure etc
Diffstat (limited to 'lv2specgen')
-rwxr-xr-x | lv2specgen/lv2specgen.py | 31 |
1 files changed, 23 insertions, 8 deletions
diff --git a/lv2specgen/lv2specgen.py b/lv2specgen/lv2specgen.py index 9b9ce1a..e69cb2e 100755 --- a/lv2specgen/lv2specgen.py +++ b/lv2specgen/lv2specgen.py @@ -60,6 +60,7 @@ except ImportError: #global vars classranges = {} classdomains = {} +linkmap = {} spec_url = None spec_ns_str = None spec_ns = None @@ -128,9 +129,14 @@ def getComment(m, urinode): 'struct' + match.replace('_', '__') + '.html') markup = markup.replace('href="urn:struct:' + match + '"', 'href="' + struct_uri + '"') - - return markup - + + rgx = re.compile('([^a-zA-Z0-9_:])(' + \ + '|'.join(map(re.escape, linkmap)) + \ + ')([^a-aA-Z0-9_:])') + def translate(match): + return match.group(1) + linkmap[match.group(2)] + match.group(3) + return rgx.sub(translate, markup) + c = m.find_statements(RDF.Statement(urinode, rdfs.comment, None)) if c.current(): text = c.current().object.literal_value['string'] @@ -662,7 +668,7 @@ def getInstances(model, classes, properties): return instances -def specgen(specloc, docdir, template, instances=False, mode="spec"): +def specgen(specloc, docdir, template, doclinks, instances=False, mode="spec"): """The meat and potatoes: Everything starts here.""" global spec_url @@ -670,7 +676,13 @@ def specgen(specloc, docdir, template, instances=False, mode="spec"): global spec_ns global spec_pre global ns_list - + + # Build a symbol -> link mapping for external links + dlfile = open(doclinks, 'r') + for line in dlfile: + sym, _, url = line.rstrip().partition(' ') + linkmap[sym] = '<a href="%s">%s</a>' % (url, sym) + m = RDF.Model() try: base = specloc[0:specloc.rfind('/')] @@ -913,6 +925,9 @@ if __name__ == "__main__": # Doxygen documentation directory doc_base = args[4] + + # C symbol -> doxygen link mapping + doc_links = args[5] template = template.replace('@STYLE_URI@', os.path.join(doc_base, style_uri)) @@ -920,8 +935,8 @@ if __name__ == "__main__": # Flags instances = False - if len(args) > 4: - flags = args[4:] + if len(args) > 5: + flags = args[5:] i = 0 while i < len(flags): if flags[i] == '-i': @@ -931,5 +946,5 @@ if __name__ == "__main__": i += 1 i += 1 - save(dest, specgen(specloc, docdir, template, instances=instances)) + save(dest, specgen(specloc, docdir, template, doc_links, instances=instances)) |