X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;ds=sidebyside;f=org.simantics.fmil.core%2Fsrc%2Forg%2Fsimantics%2Ffmil%2Fcore%2FFMIL.java;h=0e413afcef29ff63c1cd7c98ee01044d917d7b6d;hb=HEAD;hp=1f1e098d7eade1d37c3edd6a2c5dec8c13acff83;hpb=d6e8999a4b5c9e57d7b22b2f7a703c2d3549eb8c;p=simantics%2Ffmil.git diff --git a/org.simantics.fmil.core/src/org/simantics/fmil/core/FMIL.java b/org.simantics.fmil.core/src/org/simantics/fmil/core/FMIL.java index 1f1e098..0e413af 100644 --- a/org.simantics.fmil.core/src/org/simantics/fmil/core/FMIL.java +++ b/org.simantics.fmil.core/src/org/simantics/fmil/core/FMIL.java @@ -32,11 +32,14 @@ public class FMIL { private static final Logger LOGGER = LoggerFactory.getLogger(FMIL.class); + private static final boolean DEBUG = false; + /** * Static variables */ private static int OK = 0; private static int ERROR = 1; + private static int PENDING = 2; private static String UNSATISFIED_LINK = "Method not found. DLL might not be loaded properly."; public static final String TEMP_FMU_DIRECTORY_NAME = "fmil"; public static String TEMP_FMU_COMMON_DIRECTORY; @@ -120,7 +123,9 @@ public class FMIL { private String[] declaredTypeQuantities; private String[] declaredTypeUnits; - private TObjectIntHashMap variableMap = new TObjectIntHashMap(); + private static int NO_VARIABLE_KEY = -1; + + private TObjectIntHashMap variableMap = new TObjectIntHashMap(10, 0.5f, NO_VARIABLE_KEY); private Set subscriptionSet = new HashSet(); private TIntArrayList subscription = new TIntArrayList(); @@ -134,7 +139,7 @@ public class FMIL { synchronized(syncObject) { // Safety check int vr = variableMap.get(name); - if(vr == 0) return false; + if(vr == NO_VARIABLE_KEY) return false; if(!subscriptionSet.add(name)) return false; subscribedNames.add(name); subscription.add(vr); @@ -181,7 +186,7 @@ public class FMIL { * @throws FMILException */ private int fmuN = 0; - private boolean fmuLoaded = false; + private boolean instantiated = false; public void loadFMUFile(String path) throws FMILException { if (!Files.exists(Paths.get(path))) @@ -226,8 +231,8 @@ public class FMIL { for(int i=0;i