[Uml-devel] [Bug 144788] ActionScript/JavaScript association code generation error

Oliver Kellogg okellogg at users.sourceforge.net
Sat Apr 28 14:10:50 UTC 2007


------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=144788         
okellogg users sourceforge net changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|UNCONFIRMED                 |RESOLVED
         Resolution|                            |FIXED



------- Additional Comments From okellogg users sourceforge net  2007-04-28 16:10 -------
SVN commit 658784 by okellogg:

Apply attachment 20435 by Jose Gutierrez:
> * generate correct type and field name for associations
> * use rolenames for field name associations
> * use attributes in role (AS)
> * insert docs

Thanks Jose for contributing.
BUG:144788


 M  +1 -0      ChangeLog  
 M  +56 -17    umbrello/codegenerators/aswriter.cpp  
 M  +12 -2     umbrello/codegenerators/aswriter.h  
 M  +46 -22    umbrello/codegenerators/jswriter.cpp  
 M  +11 -2     umbrello/codegenerators/jswriter.h  


--- branches/KDE/3.5/kdesdk/umbrello/ChangeLog #658783:658784
 @ -34,6 +34,7  @
 * Sequence diagram crashes during message inserting (144293)
 * No synchronisation of comments when round-tripping (144346)
 * Crash when loading xmi with actor as object of sequence diagram (144442)
+* ActionScript/JavaScript association code generation error (144788)
 
 Version 1.5.61
 
--- branches/KDE/3.5/kdesdk/umbrello/umbrello/codegenerators/aswriter.cpp #658783:658784
 @ -156,30 +156,19  @
     if (forceSections() || !aggregations.isEmpty ())
     {
         as <<  m_endl << m_indentation << "/**Aggregations: */" << m_endl;
-        for (UMLAssociation *a = aggregations.first(); a; a = aggregations.next())
-        {
-            QString nm(cleanName(a->getObject(Uml::A)->getName()));
-            if (a->getMulti(Uml::A).isEmpty())
-                as << m_indentation << "this.m_" << nm << " = new " << nm << " ();" << m_endl;
-            else
-                as << m_indentation << "this.m_" << nm.lower() << " = new Array ();" << m_endl;
-        }
+        writeAssociation(classname, aggregations , as );
+
     }
+
     if( forceSections() || !compositions.isEmpty())
     {
         as <<  m_endl << m_indentation << "/**Compositions: */" << m_endl;
-        for(UMLAssociation *a = compositions.first(); a; a = compositions.next())
-        {
-            QString nm(cleanName(a->getObject(Uml::A)->getName()));
-            if(a->getMulti(Uml::A).isEmpty())
-                as << m_indentation << "this.m_" << nm << " = new " << nm << " ();" << m_endl;
-            else
-                as << m_indentation << "this.m_" << nm.lower() << " = new Array ();" << m_endl;
-        }
+        writeAssociation(classname, compositions , as );
     }
+
     as << m_endl;
+    as << m_indentation << "/**Protected: */" << m_endl;
 
-    as << m_indentation << "/**Protected: */" << m_endl;
     if (isClass) {
         UMLAttributeList atl = c->getAttributeList();
         for (UMLAttribute *at = atl.first(); at ; at = atl.next())
 @ -239,6 +228,56  @
 ////////////////////////////////////////////////////////////////////////////////////
 //  Helper Methods
 
+
+void ASWriter::writeAssociation(QString& classname, UMLAssociationList& assocList , QTextStream &as )
+{
+    for(UMLAssociation *a = assocList.first(); a; a = assocList.next())
+    {
+        // association side
+        Uml::Role_Type role = a->getObject(Uml::A)->getName() == classname ? Uml::B:Uml::A;
+
+        QString roleName(cleanName(a->getRoleName(role)));
+
+        if (!roleName.isEmpty()) {
+
+            // association doc
+            if (forceDoc() || !a->getDoc().isEmpty()) {
+                as << m_indentation << "/**" << m_endl
+                << formatDoc(a->getDoc(), m_indentation + " * ")
+                << m_indentation << " */" << m_endl;
+            }
+
+            // role doc
+            if (forceDoc() || !a->getRoleDoc(role).isEmpty()) {
+                as << m_indentation << "/**" << m_endl
+                << formatDoc(a->getRoleDoc(role), m_indentation + " * ")
+                << m_indentation << " */" << m_endl;
+            }
+
+            bool okCvt;
+            int nMulti = a->getMulti(role).toInt(&okCvt,10);
+            bool isNotMulti = a->getMulti(role).isEmpty() || (okCvt && nMulti == 1);
+
+            QString typeName(cleanName(a->getObject(role)->getName()));
+
+            if (isNotMulti)
+                as << m_indentation << "this.m_" << roleName << " = new " << typeName << "();" << m_endl;
+            else
+                as << m_indentation << "this.m_" << roleName << " = new Array();" << m_endl;
+
+            // role visibility
+            if (a->getVisibility(role) == Uml::Visibility::Private)
+            {
+               as << m_indentation << "ASSetPropFlags (this, \"m_" << roleName << "\", 7);" << m_endl;
+            }
+            else if (a->getVisibility(role)== Uml::Visibility::Protected)
+            {
+                as << m_indentation << "ASSetPropFlags (this, \"m_" << roleName << "\", 1);" << m_endl;
+            }
+        }
+    }
+}
+
 void ASWriter::writeOperations(QString classname, UMLOperationList *opList, QTextStream &as)
 {
     UMLOperation *op;
--- branches/KDE/3.5/kdesdk/umbrello/umbrello/codegenerators/aswriter.h #658783:658784
 @ -20,6 +20,7  @
 
 #include "simplecodegenerator.h"
 #include "../umloperationlist.h"
+#include "../umlassociationlist.h"
 
 /**
   * class ASWriter is a ActionScript code generator for UMLClassifier objects
 @ -63,8 +64,17  @
       *  param opList the list of operations
       *  param as output stream for the AS file
       */
-    void writeOperations(QString classname, UMLOperationList *opList,
-                         QTextStream &as);
+    void writeOperations(QString classname, UMLOperationList *opList, QTextStream &as);
+
+    /**
+     * write a list of associations
+     *
+     *  param classname the name of the class
+     *  param assocList the list of associations
+     *  param as output stream for the AS file
+     */
+    void writeAssociation(QString& classname, UMLAssociationList& assoclist , QTextStream &as);
+
 };
 
 #endif //ASWRITER
--- branches/KDE/3.5/kdesdk/umbrello/umbrello/codegenerators/jswriter.cpp #658783:658784
 @ -153,33 +153,15  @
     if (forceSections() || !aggregations.isEmpty ())
     {
         js << m_endl << m_indentation << "/**Aggregations: */" << m_endl;
-        for (UMLAssociation* a = aggregations.first(); a; a = aggregations.next())
-        {
-            UMLObject *b = a->getObject(Uml::B);
-            if (b == c)
-                continue;   // we need to be at the "A" side and the other guy at "B"
-            QString nm(cleanName(b->getName()));
-            if (a->getMulti(Uml::B).isEmpty())
-                js << m_indentation << "this.m_" << nm << " = new " << nm << " ();" << m_endl;
-            else
-                js << m_indentation << "this.m_" << nm.lower() << " = new Array ();" << m_endl;
-        }
+        writeAssociation(classname, aggregations , js );
+
     }
     UMLAssociationList compositions = c->getCompositions();
     if( forceSections() || !compositions.isEmpty())
     {
         js << m_endl << m_indentation << "/**Compositions: */" << m_endl;
-        for (UMLAssociation *a = compositions.first(); a; a = compositions.next())
-        {
-            UMLObject *b = a->getObject(Uml::B);
-            if (b == c)
-                continue;   // we need to be at the "A" side and the other guy at "B"
-            QString nm(cleanName(b->getName()));
-            if (a->getMulti(Uml::B).isEmpty())
-                js << m_indentation << "this.m_" << nm << " = new "<< nm << " ();" << m_endl;
-            else
-                js << m_indentation << "this.m_" << nm.lower() << " = new Array ();" << m_endl;
-        }
+        writeAssociation(classname, compositions , js );
+
     }
     js << m_endl;
     js << "}" << m_endl;
 @ -201,6 +183,48  @
 ////////////////////////////////////////////////////////////////////////////////////
 //  Helper Methods
 
+void JSWriter::writeAssociation(QString& classname, UMLAssociationList& assocList , QTextStream &js)
+{
+    for (UMLAssociation *a = assocList.first(); a; a = assocList.next()) {
+        // association side
+        Uml::Role_Type role = (a->getObject(Uml::A)->getName() == classname ? Uml::B : Uml::A);
+
+        QString roleName(cleanName(a->getRoleName(role)));
+
+        if (!roleName.isEmpty()) {
+
+            // association doc
+            if (forceDoc() || !a->getDoc().isEmpty())
+            {
+                js << m_indentation << "/**" << m_endl
+                   << formatDoc(a->getDoc(), m_indentation + " * ")
+                   << m_indentation << " */" << m_endl;
+            }
+
+            // role doc
+            if (forceDoc() || !a->getRoleDoc(role).isEmpty())
+            {
+                js << m_indentation << "/**" << m_endl
+                   << formatDoc(a->getRoleDoc(role), m_indentation + " * ")
+                   << m_indentation << " */" << m_endl;
+            }
+
+            bool okCvt;
+            int nMulti = a->getMulti(role).toInt(&okCvt,10);
+            bool isNotMulti = a->getMulti(role).isEmpty() || (okCvt && nMulti == 1);
+
+            QString typeName(cleanName(a->getObject(role)->getName()));
+
+            if (isNotMulti)
+                js << m_indentation << "this.m_" << roleName << " = new " << typeName << "();" << m_endl;
+            else
+                js << m_indentation << "this.m_" << roleName << " = new Array();" << m_endl;
+
+            // role visibility
+        }
+    }
+}
+
 void JSWriter::writeOperations(QString classname, UMLOperationList *opList, QTextStream &js)
 {
     UMLOperation *op;
--- branches/KDE/3.5/kdesdk/umbrello/umbrello/codegenerators/jswriter.h #658783:658784
 @ -20,6 +20,7  @
 
 #include "simplecodegenerator.h"
 #include "../umloperationlist.h"
+#include "../umlassociationlist.h"
 
 /**
   * class JSWriter is a JavaScript code generator for UMLClassifier objects
 @ -62,8 +63,16  @
       *  param opList the list of operations
       *  param js output stream for the JS file
       */
-    void writeOperations(QString classname, UMLOperationList *opList,
-                         QTextStream &js);
+    void writeOperations(QString classname, UMLOperationList *opList, QTextStream &js);
+
+    /**
+     * write a list of associations
+     *
+     *  param classname the name of the class
+     *  param assocList the list of associations
+     *  param as output stream for the AS file
+     */
+    void writeAssociation(QString& classname, UMLAssociationList& assoclist , QTextStream &js);
 };
 
 #endif //JSWRITER




More information about the umbrello-devel mailing list