X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=bindings%2Fswig%2Fdoc.py;h=182f547719eacf5f9538f2b57848b4a2d3e43563;hb=2e199405e53fee2fb3cad72858ebe7af6990bce0;hp=10b0494e0970e098447cda4f950789ced7279854;hpb=5cad31c708b50329a27f31c7df0f67dddea6ce5a;p=libsigrok.git diff --git a/bindings/swig/doc.py b/bindings/swig/doc.py index 10b0494e..182f5477 100644 --- a/bindings/swig/doc.py +++ b/bindings/swig/doc.py @@ -17,17 +17,20 @@ ## along with this program. If not, see . ## +from __future__ import print_function from xml.etree import ElementTree import sys, os -language, input_file = sys.argv[1:] +language, input_file = sys.argv[1:3] +if len(sys.argv) == 4: + mode = sys.argv[3] input_dir = os.path.dirname(input_file) index = ElementTree.parse(input_file) def get_text(node): paras = node.findall('para') - return str.join('\n\n', [p.text.rstrip() for p in paras if p.text]) + return str.join('\n\n', [("".join(l)).rstrip() for l in [list(p.itertext()) for p in paras] if l]) for compound in index.findall('compound'): if compound.attrib['kind'] != 'class': @@ -35,23 +38,28 @@ for compound in index.findall('compound'): class_name = compound.find('name').text if not class_name.startswith('sigrok::'): continue + trimmed_name = class_name.split('::')[1] doc = ElementTree.parse("%s/%s.xml" % (input_dir, compound.attrib['refid'])) cls = doc.find('compounddef') brief = get_text(cls.find('briefdescription')) if brief: if language == 'python': - print '%%feature("docstring") %s "%s";' % (class_name, brief) + print('%%feature("docstring") %s "%s";' % (class_name, brief)) + elif language == 'ruby': + print('%%feature("docstring") %s "Document-class: %s\\n%s\\n";' % (class_name, class_name.replace("sigrok", "Sigrok", 1), brief)) elif language == 'java': - print '%%typemap(javaclassmodifiers) %s "/** %s */\npublic class"' % ( - class_name, brief) + print('%%typemap(javaclassmodifiers) %s "/** %s */\npublic class"' % ( + class_name, brief)) + constants = [] for section in cls.findall('sectiondef'): - if section.attrib['kind'] != 'public-func': + kind = section.attrib['kind'] + if kind not in ('public-func', 'public-static-attrib'): continue - for function in section.findall('memberdef'): - function_name = function.find('name').text - brief = get_text(function.find('briefdescription')) + for member in section.findall('memberdef'): + member_name = member.find('name').text + brief = get_text(member.find('briefdescription')).replace('"', '\\"') parameters = {} - for para in function.find('detaileddescription').findall('para'): + for para in member.find('detaileddescription').findall('para'): paramlist = para.find('parameterlist') if paramlist is not None: for param in paramlist.findall('parameteritem'): @@ -61,15 +69,46 @@ for compound in index.findall('compound'): if description: parameters[name] = description if brief: - if language == 'python': - print str.join('\n', [ + if language == 'python' and kind == 'public-func': + print(str.join('\n', [ '%%feature("docstring") %s::%s "%s' % ( - class_name, function_name, brief)] + [ + class_name, member_name, brief)] + [ '@param %s %s' % (name, desc) - for name, desc in parameters.items()]) + '";' - elif language == 'java': - print str.join('\n', [ - '%%javamethodmodifiers %s::%s "/** %s' % ( - class_name, function_name, brief)] + [ - ' * @param %s %s' % (name, desc) - for name, desc in parameters.items()]) + ' */\npublic"' + for name, desc in parameters.items()]) + '";') + if language == 'ruby' and kind == 'public-func': + print(str.join('\n', [ + '%%feature("docstring") %s::%s "%s' % ( + class_name, member_name, brief)] + [ + '@param %s %s' % (name, desc) + for name, desc in parameters.items()]) + '\\n";') + elif language == 'java' and kind == 'public-func': + print(str.join('\n', [ + '%%javamethodmodifiers %s::%s "/** %s' % ( + class_name, member_name, brief)] + [ + ' * @param %s %s' % (name, desc) + for name, desc in parameters.items()]) + + ' */\npublic"') + elif kind == 'public-static-attrib': + constants.append((member_name, brief)) + if language == 'java' and constants: + print('%%typemap(javacode) %s %%{' % class_name) + for member_name, brief in constants: + print(' /** %s */\n public static final %s %s = new %s(classesJNI.%s_%s_get(), false);\n' % ( + brief, trimmed_name, member_name, trimmed_name, + trimmed_name, member_name)) + print('%}') + elif language == 'python' and constants: + if mode == 'start': + print('%%extend %s {\n%%pythoncode %%{' % class_name) + for member_name, brief in constants: + print(' ## @brief %s\n %s = None' % (brief, member_name)) + print('%}\n}') + elif mode == 'end': + print('%pythoncode %{') + for member_name, brief in constants: + print('%s.%s.__doc__ = """%s"""' % ( + trimmed_name, member_name, brief)) + print('%}') + elif language == 'ruby' and constants: + for member_name, brief in constants: + print('%%feature("docstring") %s::%s "%s\\n";' % (class_name, member_name, brief))