From: lempinen Date: Tue, 17 May 2011 13:46:22 +0000 (+0000) Subject: git-svn-id: https://www.simantics.org/svn/simantics/sysdyn/branches@20987 ac1ea38d... X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=commitdiff_plain;h=a64fef828206d264fcd2be2fe09e214029bf4419;p=simantics%2Fsysdyn.git git-svn-id: https://www.simantics.org/svn/simantics/sysdyn/branches@20987 ac1ea38d-2e2b-0410-8846-a27921b304fc --- diff --git a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/NewEnumerationNodeHandler.java b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/NewEnumerationNodeHandler.java index 8d3212d8..49b3f023 100644 --- a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/NewEnumerationNodeHandler.java +++ b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/NewEnumerationNodeHandler.java @@ -52,8 +52,7 @@ public class NewEnumerationNodeHandler extends AbstractHandler { Resource enumerationIndexes = OrderedSetUtils.create(g, sr.EnumerationIndexes); - String name = NameUtils.findFreshName(g, "Enumeration", configuration, l0.ConsistsOf, "%s%d"); - if("Enumeration".equals(name)) name = "Enumeration1"; + String name = NameUtils.findFreshName(g, "Enum", configuration, l0.ConsistsOf, "%s%d"); GraphUtils.create2(g, sr.Enumeration, diff --git a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/ShowModuleHandler.java b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/ShowModuleHandler.java index 67732e3a..6c289d66 100644 --- a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/ShowModuleHandler.java +++ b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/handlers/ShowModuleHandler.java @@ -23,6 +23,7 @@ import org.simantics.db.ReadGraph; import org.simantics.db.Resource; import org.simantics.db.common.request.ReadRequest; import org.simantics.db.exception.DatabaseException; +import org.simantics.db.layer0.exception.MissingVariableException; import org.simantics.db.layer0.variable.Variable; import org.simantics.db.layer0.variable.Variables; import org.simantics.diagram.stubs.DiagramResource; @@ -71,8 +72,17 @@ public class ShowModuleHandler extends AbstractHandler { final Resource configuration = graph.getPossibleObject(componentType, st.IsDefinedBy); final Resource diagram = ComponentUtils.getPossibleCompositeDiagram(graph, configuration); - Variable variable = parent.browsePossible(graph, component); - final String finalRvi = Variables.getRVI(graph, variable); + Variable variable; + String rvi = ""; + try { + variable = parent.browse(graph, component); + rvi = Variables.getRVI(graph, variable); + } catch (MissingVariableException e ) { + variable = Variables.getVariable(graph, graph.getURI(component)); + } + final String finalRvi = rvi; + + PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() { diff --git a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ModuleOutputEditingSupport.java b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ModuleOutputEditingSupport.java index d8dbd3af..7a69d742 100644 --- a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ModuleOutputEditingSupport.java +++ b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ModuleOutputEditingSupport.java @@ -71,8 +71,9 @@ public class ModuleOutputEditingSupport extends EditingSupport { SysdynResource sr = SysdynResource.getInstance(graph); HashMap result = new HashMap(); for(Resource dependency : graph.syncRequest(new ObjectsWithType(module, sr.IsTailOf, sr.Dependency))) { - if(graph.getPossibleObject(dependency, sr.RefersTo) == null || - graph.getPossibleObject(dependency, sr.RefersTo).equals(outputVariable)) { + if(graph.getPossibleObject(dependency, sr.RefersTo) == null + || !graph.hasStatement(graph.getPossibleObject(dependency, sr.RefersTo), l0.HasName) + || graph.getPossibleObject(dependency, sr.RefersTo).equals(outputVariable)) { Resource input = graph.getSingleObject(dependency, sr.HasHead); result.put((String)graph.getRelatedValue(input, l0.HasName), dependency); } diff --git a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ReferenceRow.java b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ReferenceRow.java index d3ad2718..5aeeaec7 100644 --- a/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ReferenceRow.java +++ b/simantics-1.4/org.simantics.sysdyn.ui/src/org/simantics/sysdyn/ui/properties/widgets/ReferenceRow.java @@ -95,6 +95,8 @@ public class ReferenceRow { SysdynResource sr = SysdynResource.getInstance(graph); if(getDependency() != null && graph.hasStatement(getDependency(), sr.RefersTo)) graph.deny(getDependency(), sr.RefersTo); + if(dependency != null && graph.hasStatement(dependency, sr.RefersTo)) + graph.deny(dependency, sr.RefersTo); setDependency(null); if(dependency != null) { setDependency(dependency); diff --git a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/modelica/ModelicaWriter.java b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/modelica/ModelicaWriter.java index bd462953..d88a02a5 100644 --- a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/modelica/ModelicaWriter.java +++ b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/modelica/ModelicaWriter.java @@ -141,7 +141,7 @@ public class ModelicaWriter { Input variable = (Input)dependency.getHead(); Module module = (Module)dependency.getTail(); Variable reference = (Variable)dependency.refersTo(); - if(reference != null) + if(reference != null && reference.getName() != null) b.append(" " + variable.getName() + " = " + module.getName() + "." + reference.getName() + ";\n"); else b.append(" " + variable.getName() + " = " + variable.getDefaultInputValue() + ";\n"); diff --git a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Module.java b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Module.java index d04bc240..941e0632 100644 --- a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Module.java +++ b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Module.java @@ -51,28 +51,43 @@ public class Module implements IElement { /** * Returns the declaration of a module with possible redeclared enumerations + * + * parameter Integer Enum__size = Enum.size; + * parameter Integer Enum__elements[:] = Enum.elements; + * ModuleType ModuleType1(Enum.size = Enum__size, Enum.elements = Enum__elements); * - * Module m(redeclared.size = enumeration.size, redeclared.elements = enumeration.elements); + * Temporary parameter variables are needed to avoid name conflicts when redeclaring an + * enumeration with the same name. * * @return Declaration of a module instance */ public String getDeclaration() { - StringBuilder sb = new StringBuilder(); - sb.append(" "); - sb.append(getType().getName()); - sb.append(" "); - sb.append(getName()); + + StringBuilder parameters = new StringBuilder(); + StringBuilder redeclarations = new StringBuilder(); + + if(!getRedeclarations().isEmpty()) { - sb.append("("); + redeclarations.append("("); Iterator i = getRedeclarations().iterator(); while(i.hasNext()) { Redeclaration rd = i.next(); - sb.append(rd.getRedeclaration()); + redeclarations.append(rd.getRedeclaration()); + parameters.append(rd.getParameters()); if(i.hasNext()) - sb.append(","); + redeclarations.append(","); } - sb.append(")"); + redeclarations.append(")"); } + + + StringBuilder sb = new StringBuilder(); + sb.append(parameters); + sb.append(" "); + sb.append(getType().getName()); + sb.append(" "); + sb.append(getName()); + sb.append(redeclarations.toString()); sb.append(";\n"); return sb.toString(); } diff --git a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Redeclaration.java b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Redeclaration.java index b048bbdb..cdf33978 100644 --- a/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Redeclaration.java +++ b/simantics-1.4/org.simantics.sysdyn/src/org/simantics/sysdyn/representation/Redeclaration.java @@ -27,18 +27,60 @@ public class Redeclaration { if(replacedEnumeration == null || replacingEnumeration == null) { return ""; } + String separator = getSeparator(); StringBuilder sb = new StringBuilder(); sb.append(replacedEnumeration.getName()); sb.append(".size = "); sb.append(replacingEnumeration.getName()); - sb.append(".size, "); + sb.append(separator + "size, "); sb.append(replacedEnumeration.getName()); sb.append(".elements = "); sb.append(replacingEnumeration.getName()); - sb.append(".elements"); + sb.append(separator + "elements"); return sb.toString(); } + + /** + * Change the name of the re-declaration parameters to enable the use of + * enumerations with same names. + * + * @return + */ + public String getParameters() { + String separator = getSeparator(); + StringBuilder sb = new StringBuilder(); + sb.append(" parameter Integer " + replacingEnumeration.getName() + separator + "size = " + replacingEnumeration.getName() + ".size;\n"); + sb.append(" parameter Integer " + replacingEnumeration.getName() + separator + "elements[:] = " + replacingEnumeration.getName() + ".elements;\n"); + return sb.toString(); + } + + private String getSeparator() { + return getSeparator(this, "_"); + } + + /** + * Add enough separation marks that name conflicts would not exist. + * + * @param redeclaration + * @param separator + * @return + */ + private String getSeparator(Redeclaration redeclaration, String separator) { + for(IElement e : redeclaration.replacedEnumeration.getParentConfiguration().getElements()) { + if(e instanceof Module) { + for(Redeclaration rd : ((Module)e).getRedeclarations()) { + if(rd.replacedEnumeration.name.equals(redeclaration.replacedEnumeration.name) && + rd.replacingEnumeration.equals(redeclaration.replacedEnumeration)) { + String separatorTmp = getSeparator(rd, separator); + if(separatorTmp.length() > separator.length()) + separator = separatorTmp; + } + } + } + } + return separator + "_"; + } public Enumeration getReplacedEnumeration() { return replacedEnumeration;