Mercurial > libervia-backend
diff src/bridge/bridge_constructor/bridge_contructor.py @ 374:193fd5995430
bridge-constructor: added dbus-xml constructor (used for Qt frontend)
author | Goffi <goffi@goffi.org> |
---|---|
date | Thu, 28 Jul 2011 03:02:31 +0200 (2011-07-28) |
parents | 3ea41a199b36 |
children | 502489e17685 |
line wrap: on
line diff
--- a/src/bridge/bridge_constructor/bridge_contructor.py Thu Jul 28 01:03:22 2011 +0200 +++ b/src/bridge/bridge_constructor/bridge_contructor.py Thu Jul 28 03:02:31 2011 +0200 @@ -35,7 +35,7 @@ This script construct a SàT bridge using the given protocol """ -MANAGED_PROTOCOLES=['dbus','mediawiki'] +MANAGED_PROTOCOLES=['dbus','mediawiki', 'dbus-xml'] DEFAULT_PROTOCOLE='dbus' FLAGS=['deprecated', 'async'] @@ -49,6 +49,7 @@ from ConfigParser import NoOptionError import re from datetime import datetime +from xml.dom import minidom class ParseError(Exception): @@ -132,32 +133,23 @@ if self.bridge_template.has_option(name, "doc"): return self.bridge_template.get(name, "doc") return None - - def getArguments(self, signature, name=None, default=None, unicode_protect=False): - """Return arguments to user given a signature - @param signature: signature in the short form (using s,a,i,b etc) - @param name: dictionary of arguments name like given by getArguments - @param default: dictionary of default values, like given by getDefault - @param unicode_protect: activate unicode protection on strings (return strings as unicode(str)) - @return: list of arguments that correspond to a signature (e.g.: "sss" return "arg1, arg2, arg3")""" + + + def argumentsParser(self, signature): + """Generator which return individual arguments signatures from a global signature""" + start=0 i=0 - idx=0 - attr_string=[] + while i<len(signature): if signature[i] not in ['b','y','n','i','x','q','u','t','d','s','a']: raise ParseError("Unmanaged attribute type [%c]" % signature[i]) - - attr_string.append(("unicode(%(name)s)%(default)s" if (unicode_protect and signature[i]=='s') else "%(name)s%(default)s") % { - 'name':name[idx][0] if (name and name.has_key(idx)) else "arg_%i" % idx, - 'default':"="+default[idx] if (default and default.has_key(idx)) else '' - }) #give arg_1, arg2, etc or name1, name2=default, etc. \ - #give unicode(arg_1), unicode(arg_2), etc. if unicode_protect is set and arg is a string - idx+=1 if signature[i] == 'a': i+=1 if signature[i]!='{' and signature[i]!='(': #FIXME: must manage tuples out of arrays i+=1 + yield signature[start:i] + start=i continue #we have a simple type for the array opening_car = signature[i] assert(opening_car in ['{','(']) @@ -174,6 +166,27 @@ if opening_count == 0: break i+=1 + yield signature[start:i] + start=i + + def getArguments(self, signature, name=None, default=None, unicode_protect=False): + """Return arguments to user given a signature + @param signature: signature in the short form (using s,a,i,b etc) + @param name: dictionary of arguments name like given by getArguments + @param default: dictionary of default values, like given by getDefault + @param unicode_protect: activate unicode protection on strings (return strings as unicode(str)) + @return: list of arguments that correspond to a signature (e.g.: "sss" return "arg1, arg2, arg3")""" + idx=0 + attr_string=[] + + for arg in self.argumentsParser(signature): + attr_string.append(("unicode(%(name)s)%(default)s" if (unicode_protect and arg=='s') else "%(name)s%(default)s") % { + 'name':name[idx][0] if (name and name.has_key(idx)) else "arg_%i" % idx, + 'default':"="+default[idx] if (default and default.has_key(idx)) else '' + }) #give arg_1, arg2, etc or name1, name2=default, etc. \ + #give unicode(arg_1), unicode(arg_2), etc. if unicode_protect is set and arg is a string + idx+=1 + return ", ".join(attr_string) def generateCoreSide(self): @@ -462,6 +475,55 @@ #now we write to final file self.finalWrite(self.frontend_dest, frontend_bridge) +class DbusXmlConstructor(Constructor): + """Constructor for DBus XML syntaxt (used by Qt frontend)""" + + def __init__(self, bridge_template, options): + Constructor.__init__(self, bridge_template, options) + + self.template="dbus_xml_template.xml" + self.core_dest="org.goffi.sat.xml" + + def generateCoreSide(self): + try: + doc = minidom.parse(self.template) + interface_elt = doc.getElementsByTagName('interface')[0] + except IOError: + print ("Can't access template") + sys.exit(1) + except IndexError: + print ("Template error") + sys.exit(1) + + sections = self.bridge_template.sections() + sections.sort() + for section in sections: + function = self.getValues(section) + print ("Adding %s %s" % (section, function["type"])) + new_elt = doc.createElement('method' if function["type"]=='method' else 'signal') + new_elt.setAttribute('name', section) + args_in_str = self.getArguments(function['sig_in']) + + idx=0 + args_doc = self.getArgumentsDoc(section) + for arg in self.argumentsParser(function['sig_in'] or ''): + arg_elt = doc.createElement('arg') + arg_elt.setAttribute('name', args_doc[idx][0] if args_doc.has_key(idx) else "arg_%i" % idx) + arg_elt.setAttribute('type', arg) + arg_elt.setAttribute('direction', 'in' if function["type"]=='method' else 'out') + new_elt.appendChild(arg_elt) + idx+=1 + + if function['sig_out']: + arg_elt = doc.createElement('arg') + arg_elt.setAttribute('type', function['sig_out']) + arg_elt.setAttribute('direction', 'out') + new_elt.appendChild(arg_elt) + + interface_elt.appendChild(new_elt) + + #now we write to final file + self.finalWrite(self.core_dest, [doc.toprettyxml()]) class ConstructorError(Exception): pass @@ -472,6 +534,8 @@ return DbusConstructor(bridge_template, options) elif options.protocole=='mediawiki': return MediawikiConstructor(bridge_template, options) + elif options.protocole=='dbus-xml': + return DbusXmlConstructor(bridge_template, options) raise ConstructorError('Unknown constructor type')