]> git.llucax.com Git - z.facultad/75.10/miklolife.git/blobdiff - carpeta/scripts/clases2spec.py
bugfixes
[z.facultad/75.10/miklolife.git] / carpeta / scripts / clases2spec.py
index 818d1ddcbcd8e2373d3ab31dd87c83952bd7a78c..c6961b3afc195a2228bb5ac8fbe83cd3df520f3d 100755 (executable)
 from xml.sax import saxutils
 
 # Estados
 from xml.sax import saxutils
 
 # Estados
-E_CLASS         = 1
-E_CLASS_NAME    = 2
-E_CLASS_COMMENT = 3
-E_ATTRS         = 4
-E_ATTR          = 5
-E_ATTR_NAME     = 6
-E_ATTR_COMMENT  = 7
-E_ATTR_TYPE     = 8
-E_OPS           = 9
-E_OP            = 10
-E_OP_NAME       = 11
-E_OP_COMMENT    = 12
-E_OP_TYPE       = 13
+E_CLASS             = 1
+E_CLASS_NAME        = 2
+E_CLASS_COMMENT     = 3
+E_ATTRS             = 4
+E_ATTR              = 5
+E_ATTR_NAME         = 6
+E_ATTR_COMMENT      = 7
+E_ATTR_TYPE         = 8
+E_OPS               = 9
+E_OP                = 10
+E_OP_NAME           = 11
+E_OP_COMMENT        = 12
+E_OP_TYPE           = 13
+E_OP_PARAMS         = 14
+E_OP_PARAM          = 15
+E_OP_PARAM_NAME     = 16
+E_OP_PARAM_COMMENT  = 17
+E_OP_PARAM_TYPE     = 18
 
 # Caracteres a eliminar
 STRIPCHARS = '#\t\n '
 
 
 # Caracteres a eliminar
 STRIPCHARS = '#\t\n '
 
+DEBUG = 0
+
+def dprint(s):
+    if DEBUG: print >>sys.stderr, s.encode('iso-8859-1', 'replace')
+
 class ObjFinder(saxutils.DefaultHandler):
     def __init__(self):
         self.estado = None
         self.clases = []
         self.curr = None
         self.curr_attr = None
 class ObjFinder(saxutils.DefaultHandler):
     def __init__(self):
         self.estado = None
         self.clases = []
         self.curr = None
         self.curr_attr = None
+        self.curr_op = None
+        self.curr_param = None
     def startElement(self, name, attrs):
     def startElement(self, name, attrs):
-        #print " #### Start <%s %s>" % (name, dict(attrs))
         if name == 'dia:object': # Comienzo de una clase
             if attrs.get('type', None) == 'UML - Class':
                 self.curr = {}
                 self.estado = E_CLASS
         if name == 'dia:object': # Comienzo de una clase
             if attrs.get('type', None) == 'UML - Class':
                 self.curr = {}
                 self.estado = E_CLASS
+                dprint("E_CLASS (encontrado dia:object)")
         elif name == 'dia:attribute':
             name = attrs.get('name', None)
             if self.estado == E_CLASS:   # Datos de la clase
                 if name == 'name':     # Nombre de la clase
                     self.curr['name'] = ''
                     self.estado = E_CLASS_NAME
         elif name == 'dia:attribute':
             name = attrs.get('name', None)
             if self.estado == E_CLASS:   # Datos de la clase
                 if name == 'name':     # Nombre de la clase
                     self.curr['name'] = ''
                     self.estado = E_CLASS_NAME
+                    dprint("E_CLASS -> E_CLASS_NAME (encontrado dia:attribute con name)")
                 elif name == 'comment':  # Es la descripción de la clase
                     self.curr['comment'] = ''
                     self.estado = E_CLASS_COMMENT
                 elif name == 'comment':  # Es la descripción de la clase
                     self.curr['comment'] = ''
                     self.estado = E_CLASS_COMMENT
-                elif name == 'attributes': # Paso empezó a encontrar atributos
+                    dprint("E_CLASS -> E_CLASS_COMMENT (encontrado dia:attribute con comment)")
+                elif name == 'attributes': # Paso a encontrar atributos
                     self.curr['attrs'] = []
                     self.estado = E_ATTRS
                     self.curr['attrs'] = []
                     self.estado = E_ATTRS
-                elif name == 'operations': # Paso empezó a encontrar operaciones
+                    dprint("E_CLASS -> E_ATTRS (encontrado dia:attribute con attributes)")
+                elif name == 'operations': # Paso a encontrar operaciones
                     self.curr['ops'] = []
                     self.estado = E_OPS
                     self.curr['ops'] = []
                     self.estado = E_OPS
+                    dprint("E_CLASS -> E_OPS (encontrado dia:attribute con operations)")
             elif self.estado == E_ATTR:  # Datos del atributo
                 if name == 'name':       # Nombre del atributo
                     self.curr_attr['name'] = ''
                     self.estado = E_ATTR_NAME
             elif self.estado == E_ATTR:  # Datos del atributo
                 if name == 'name':       # Nombre del atributo
                     self.curr_attr['name'] = ''
                     self.estado = E_ATTR_NAME
+                    dprint("E_ATTR -> E_ATTR_NAME (encontrado dia:attribute con name)")
                 elif name == 'type':     # Es el tipo del atributo
                     self.curr_attr['type'] = ''
                     self.estado = E_ATTR_TYPE
                 elif name == 'type':     # Es el tipo del atributo
                     self.curr_attr['type'] = ''
                     self.estado = E_ATTR_TYPE
+                    dprint("E_ATTR -> E_ATTR_TYPE (encontrado dia:attribute con type)")
                 elif name == 'comment':  # Es la descripción del atributo
                     self.curr_attr['comment'] = ''
                     self.estado = E_ATTR_COMMENT
                 elif name == 'comment':  # Es la descripción del atributo
                     self.curr_attr['comment'] = ''
                     self.estado = E_ATTR_COMMENT
+                    dprint("E_ATTR -> E_ATTR_COMMENT (encontrado dia:attribute con comment)")
             elif self.estado == E_OP:    # Datos del atributo
                 if name == 'name':       # Nombre del atributo
                     self.curr_op['name'] = ''
                     self.estado = E_OP_NAME
             elif self.estado == E_OP:    # Datos del atributo
                 if name == 'name':       # Nombre del atributo
                     self.curr_op['name'] = ''
                     self.estado = E_OP_NAME
+                    dprint("E_OP -> E_OP_NAME (encontrado dia:attribute con name)")
                 elif name == 'type':     # Es el tipo del atributo
                     self.curr_op['type'] = ''
                     self.estado = E_OP_TYPE
                 elif name == 'type':     # Es el tipo del atributo
                     self.curr_op['type'] = ''
                     self.estado = E_OP_TYPE
+                    dprint("E_OP -> E_OP_TYPE (encontrado dia:attribute con type)")
                 elif name == 'comment':  # Es la descripción del atributo
                     self.curr_op['comment'] = ''
                     self.estado = E_OP_COMMENT
                 elif name == 'comment':  # Es la descripción del atributo
                     self.curr_op['comment'] = ''
                     self.estado = E_OP_COMMENT
-        elif name == 'dia:composite':   # Comienzo de attributos de clase
-            if self.estado == E_ATTRS:  # Si estoy en una clase
+                    dprint("E_OP -> E_OP_COMMENT (encontrado dia:attribute con comment)")
+                elif name == 'parameters': # Paso a encontrar parámetros de operaciones
+                    self.curr_op['params'] = []
+                    self.estado = E_OP_PARAMS
+                    dprint("E_OP -> E_OP_PARAMS (encontrado dia:attribute con parameters)")
+            elif self.estado == E_OP_PARAM:  # Datos del parametro
+                if name == 'name':       # Nombre del parametro
+                    self.curr_param['name'] = ''
+                    self.estado = E_OP_PARAM_NAME
+                    dprint("E_OP_PARAM -> E_OP_PARAM_NAME (encontrado dia:attribute con name)")
+                elif name == 'type':     # Es el tipo del parametro
+                    self.curr_param['type'] = ''
+                    self.estado = E_OP_PARAM_TYPE
+                    dprint("E_OP_PARAM -> E_OP_PARAM_TYPE (encontrado dia:attribute con type)")
+                elif name == 'comment':  # Es la descripción del parametro
+                    self.curr_param['comment'] = ''
+                    self.estado = E_OP_PARAM_COMMENT
+                    dprint("E_OP_PARAM -> E_OP_PARAM_COMMENT (encontrado dia:attribute con comment)")
+        elif name == 'dia:composite':   # Comienza composite
+            if self.estado == E_ATTRS:  # Si estoy en atributos
                 self.curr_attr = {}
                 self.curr_attr = {}
-                self.estado = E_ATTR    # Paso a buscar sus operaciones
-            elif self.estado == E_OPS:  # Si estoy en una clase
+                self.estado = E_ATTR    # Paso a buscar sus atributos
+                dprint("E_ATTRS -> E_ATTR (encontrado dia:composite)")
+            elif self.estado == E_OPS:  # Si estoy en operaciones
                 self.curr_op = {}
                 self.curr_op = {}
-                self.estado = E_OP   # Paso a buscar sus atributos
+                self.estado = E_OP   # Paso a buscar sus operaciones
+                dprint("E_OPS -> E_OP (encontrado dia:composite)")
+            elif self.estado == E_OP_PARAMS:  # Si estoy en parametros de operaciones
+                self.curr_param = {}
+                self.estado = E_OP_PARAM   # Paso a buscar sus parametros
+                dprint("E_OP_PARAMS -> E_OP_PARAM (encontrado dia:composite)")
     def characters(self, data):
         if self.estado == E_CLASS_NAME:
             self.curr['name'] += data.strip(STRIPCHARS)
     def characters(self, data):
         if self.estado == E_CLASS_NAME:
             self.curr['name'] += data.strip(STRIPCHARS)
+            dprint("E_CLASS_NAME: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_CLASS_COMMENT:
             self.curr['comment'] += data.strip(STRIPCHARS)
         elif self.estado == E_CLASS_COMMENT:
             self.curr['comment'] += data.strip(STRIPCHARS)
+            dprint("E_CLASS_COMMENT: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_ATTR_NAME:
             self.curr_attr['name'] += data.strip(STRIPCHARS)
         elif self.estado == E_ATTR_NAME:
             self.curr_attr['name'] += data.strip(STRIPCHARS)
+            dprint("E_ATTR_NAME: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_ATTR_TYPE:
             self.curr_attr['type'] += data.strip(STRIPCHARS)
         elif self.estado == E_ATTR_TYPE:
             self.curr_attr['type'] += data.strip(STRIPCHARS)
+            dprint("E_ATTR_TYPE: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_ATTR_COMMENT:
             self.curr_attr['comment'] += data.strip(STRIPCHARS)
         elif self.estado == E_ATTR_COMMENT:
             self.curr_attr['comment'] += data.strip(STRIPCHARS)
+            dprint("E_ATTR_COMMENT: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_OP_NAME:
             self.curr_op['name'] += data.strip(STRIPCHARS)
         elif self.estado == E_OP_NAME:
             self.curr_op['name'] += data.strip(STRIPCHARS)
+            dprint("E_OP_NAME: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_OP_TYPE:
             self.curr_op['type'] += data.strip(STRIPCHARS)
         elif self.estado == E_OP_TYPE:
             self.curr_op['type'] += data.strip(STRIPCHARS)
+            dprint("E_OP_TYPE: %s" % data.strip(STRIPCHARS))
         elif self.estado == E_OP_COMMENT:
             self.curr_op['comment'] += data.strip(STRIPCHARS)
         elif self.estado == E_OP_COMMENT:
             self.curr_op['comment'] += data.strip(STRIPCHARS)
+            dprint("E_OP_COMMENT: %s" % data.strip(STRIPCHARS))
+        elif self.estado == E_OP_PARAM_NAME:
+            self.curr_param['name'] += data.strip(STRIPCHARS)
+            dprint("E_OP_PARAM_NAME: %s" % data.strip(STRIPCHARS))
+        elif self.estado == E_OP_PARAM_TYPE:
+            self.curr_param['type'] += data.strip(STRIPCHARS)
+            dprint("E_OP_PARAM_TYPE: %s" % data.strip(STRIPCHARS))
+        elif self.estado == E_OP_PARAM_COMMENT:
+            self.curr_param['comment'] += data.strip(STRIPCHARS)
+            dprint("E_OP_PARAM_COMMENT: %s" % data.strip(STRIPCHARS))
     def endElement(self, name):
     def endElement(self, name):
-        #print " #### Endt </%s>" % name
         if name == 'dia:object':
             if self.estado == E_CLASS:
                 self.clases.append(self.curr)
                 self.estado = None
                 self.curr = None
         if name == 'dia:object':
             if self.estado == E_CLASS:
                 self.clases.append(self.curr)
                 self.estado = None
                 self.curr = None
+                dprint("E_CLASS -> None")
         elif name == 'dia:attribute':
             if self.estado == E_CLASS_NAME:
                 self.estado = E_CLASS
         elif name == 'dia:attribute':
             if self.estado == E_CLASS_NAME:
                 self.estado = E_CLASS
+                dprint("E_CLASS_NAME -> E_CLASS")
             elif self.estado == E_CLASS_COMMENT:
                 self.estado = E_CLASS
             elif self.estado == E_CLASS_COMMENT:
                 self.estado = E_CLASS
+                dprint("E_CLASS_COMMENT -> E_CLASS")
             elif self.estado == E_ATTR_NAME:
                 self.estado = E_ATTR
             elif self.estado == E_ATTR_NAME:
                 self.estado = E_ATTR
+                dprint("E_ATTR_NAME -> E_ATTR")
             elif self.estado == E_ATTR_TYPE:
                 self.estado = E_ATTR
             elif self.estado == E_ATTR_TYPE:
                 self.estado = E_ATTR
+                dprint("E_ATTR_TYPE -> E_ATTR")
             elif self.estado == E_ATTR_COMMENT:
                 self.estado = E_ATTR
             elif self.estado == E_ATTR_COMMENT:
                 self.estado = E_ATTR
+                dprint("E_ATTR_COMMENT -> E_ATTR")
             elif self.estado == E_ATTRS:
                 self.estado = E_CLASS
             elif self.estado == E_ATTRS:
                 self.estado = E_CLASS
+                dprint("E_ATTRS -> E_CLASS")
             elif self.estado == E_OP_NAME:
                 self.estado = E_OP
             elif self.estado == E_OP_NAME:
                 self.estado = E_OP
+                dprint("E_OP_NAME -> E_OP")
             elif self.estado == E_OP_TYPE:
                 self.estado = E_OP
             elif self.estado == E_OP_TYPE:
                 self.estado = E_OP
+                dprint("E_OP_TYPE -> E_OP")
             elif self.estado == E_OP_COMMENT:
                 self.estado = E_OP
             elif self.estado == E_OP_COMMENT:
                 self.estado = E_OP
+                dprint("E_OP_COMMENT -> E_OP")
             elif self.estado == E_OPS:
                 self.estado = E_CLASS
             elif self.estado == E_OPS:
                 self.estado = E_CLASS
+                dprint("E_OPS -> E_CLASS")
+            elif self.estado == E_OP_PARAM_NAME:
+                self.estado = E_OP_PARAM
+                dprint("E_OP_PARAM_NAME -> E_OP_PARAM")
+            elif self.estado == E_OP_PARAM_TYPE:
+                self.estado = E_OP_PARAM
+                dprint("E_OP_PARAM_TYPE -> E_OP_PARAM")
+            elif self.estado == E_OP_PARAM_COMMENT:
+                self.estado = E_OP_PARAM
+                dprint("E_OP_PARAM_COMMENT -> E_OP_PARAM")
+            elif self.estado == E_OP_PARAMS:
+                self.estado = E_OP
+                dprint("E_OP_PARAMS -> E_OP")
         elif name == 'dia:composite':
             if self.estado == E_ATTR:
                 self.curr['attrs'].append(self.curr_attr)
                 self.curr_attr = None
                 self.estado = E_ATTRS
         elif name == 'dia:composite':
             if self.estado == E_ATTR:
                 self.curr['attrs'].append(self.curr_attr)
                 self.curr_attr = None
                 self.estado = E_ATTRS
+                dprint("E_ATTR -> E_ATTRS")
             elif self.estado == E_OP:
                 self.curr['ops'].append(self.curr_op)
                 self.curr_op = None
                 self.estado = E_OPS
             elif self.estado == E_OP:
                 self.curr['ops'].append(self.curr_op)
                 self.curr_op = None
                 self.estado = E_OPS
+                dprint("E_OP -> E_OPS")
+            elif self.estado == E_OP_PARAM:
+                self.curr_op['params'].append(self.curr_param)
+                self.curr_param = None
+                self.estado = E_OP_PARAMS
+                dprint("E_OP_PARAM -> E_OP_PARAMS")
+
+def param2str(params):
+    ret = []
+    for p in params:
+        ret.append('%s: %s' \
+            % (p['name'].encode('iso-8859-1', 'replace'),
+                p['type'].encode('iso-8859-1', 'replace')))
+    return ', '.join(ret)
+
+def to_text(clases):
+    # Recorro clases
+    for c in clases:
+        print c['name'].encode('iso-8859-1', 'replace')
+        print c['comment'].encode('iso-8859-1', 'replace')
+        print 'Atributo\tTipo\tDescripción'
+        for a in c['attrs']:
+            print '%s\t%s\t%s' \
+                % (a['name'].encode('iso-8859-1', 'replace'),
+                    a['type'].encode('iso-8859-1', 'replace'),
+                    a['comment'].encode('iso-8859-1', 'replace'))
+        if metodos and c['ops']:
+            for o in c['ops']:
+                print 'Método %s(%s): %s' \
+                    % (o['name'].encode('iso-8859-1', 'replace'),
+                        param2str(o['params']),
+                        o['type'].encode('iso-8859-1', 'replace'))
+                print o['comment'].encode('iso-8859-1', 'replace')
+                if o['params']:
+                    print 'Parámetro\tTipo\tDescripción'
+                    for p in o['params']:
+                        print '%s\t%s\t%s' \
+                            % (p['name'].encode('iso-8859-1', 'replace'),
+                                p['type'].encode('iso-8859-1', 'replace'),
+                                p['comment'].encode('iso-8859-1', 'replace'))
 
 
+def to_html(clases):
+    print '<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN">'
+    print '<html lang="es"><head><title>Especificación</title></head><body>'
+    # Recorro clases obtenidas
+    for c in dh.clases:
+        print '<table width="100%%" border="1" summary="Especificación de clase %s">' \
+            % c['name'].encode('iso-8859-1', 'replace')
+        print '<tr><th colspan="3">%s</th></tr>' % c['name'].encode('iso-8859-1', 'replace')
+        print '<tr><td colspan="3">%s</td></tr>' % c['comment'].encode('iso-8859-1', 'replace')
+        print '<tr><th>Atributo</th><th>Tipo</th><th>Descripción</th></tr>'
+        for a in c['attrs']:
+            print '<tr><td>%s</td><td>%s</td><td>%s</td></tr>' \
+                % (a['name'].encode('iso-8859-1', 'replace'),
+                    a['type'].encode('iso-8859-1', 'replace'),
+                    a['comment'].encode('iso-8859-1', 'replace'))
+        if metodos and c['ops']:
+            for o in c['ops']:
+                print '<tr><th colspan="3">Método</th></tr>'
+                print '<tr><td colspan="3">%s(%s): %s</td></tr>' \
+                    % (o['name'].encode('iso-8859-1', 'replace'),
+                        param2str(o['params']),
+                        o['type'].encode('iso-8859-1', 'replace'))
+                print '<tr><td colspan="3">%s</td></tr>' % \
+                    o['comment'].encode('iso-8859-1', 'replace')
+                if o['params']:
+                    print '<tr><th>Parámetro</th><th>Tipo</th><th>Descripción</th></tr>'
+                    for p in o['params']:
+                        print '<tr><td>%s</td><td>%s</td><td>%s</td></tr>' \
+                            % (p['name'].encode('iso-8859-1', 'replace'),
+                                p['type'].encode('iso-8859-1', 'replace'),
+                                p['comment'].encode('iso-8859-1', 'replace'))
+        print '</table>'
+    print '</body></html>'
 
 if __name__ == '__main__':
     import sys
 
 if __name__ == '__main__':
     import sys
@@ -162,29 +320,8 @@ if __name__ == '__main__':
     if len(sys.argv) > 2 and sys.argv[2] == '-n':
         metodos = False
 
     if len(sys.argv) > 2 and sys.argv[2] == '-n':
         metodos = False
 
-    print '<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN">'
-    print '<html lang="es"><head><title>Especificación</title></head><body>'
-    # Recorro clases obtenidas
-    for c in dh.clases:
-        print '<table width="100%%" border="1" summary="Especificación de clase %s">' \
-            % c['name'].encode('iso-8859-1', 'replace')
-        print '<tr><th colspan="3">%s</th></tr>' % c['name'].encode('iso-8859-1', 'replace')
-        print '<tr><td colspan="3">%s</td></tr>' % c['comment'].encode('iso-8859-1', 'replace')
-        print '<tr><th>Atributo</th><th>Tipo</th><th>Descripción</th></tr>'
-        for a in c['attrs']:
-            print '<tr><td>%s</td><td>%s</td><td>%s</td></tr>' \
-                % (a['name'].encode('iso-8859-1', 'replace'),
-                    a['type'].encode('iso-8859-1', 'replace'),
-                    a['comment'].encode('iso-8859-1', 'replace'))
-        if metodos:
-            print '<tr><th>Método</th><th>Retorno</th><th>Descripción</th></tr>'
-            for o in c['ops']:
-                print '<tr><td>%s</td><td>%s</td><td>%s</td></tr>' \
-                    % (o['name'].encode('iso-8859-1', 'replace'),
-                        o['type'].encode('iso-8859-1', 'replace'),
-                        o['comment'].encode('iso-8859-1', 'replace'))
-        print '</table>'
-    print '</body></html>'
-
+    # Imprimo como txt feo para convertir a RTF
+    to_text(dh.clases)
+    #to_html(dh.clases)
 
 # vim: set et sw=4 sts=4 :
 
 # vim: set et sw=4 sts=4 :