Salome HOME
Merge branch 'master' into cgt/devCEA
[modules/shaper.git] / src / PythonAPI / model / roots.py
index 798f4dac388bce30f7de459b30e0347d14d7504c..31316103e34d389ec447cb48c0fe2e69891d9cc2 100644 (file)
@@ -5,74 +5,30 @@ Copyright (C) 2014-20xx CEA/DEN, EDF R&D
 
 import ModelAPI
 
-from model import tools
-
-
 class Feature(ModelAPI.ModelAPI_Feature):
     """Base class of user-defined Python features."""
 
     def __init__(self):
+        """x.__init__(...) initializes x; see x.__class__.__doc__ for signature"""
         ModelAPI.ModelAPI_Feature.__init__(self)
 
-    def addRealInput (self, inputid):
+    def addRealInput(self, inputid):
+        """F.addRealInput(str) -- add real attribute"""
         self.data().addAttribute(inputid,
                                  ModelAPI.ModelAPI_AttributeDouble_typeId())
 
-    def getRealInput (self, inputid):
+    def getRealInput(self, inputid):
+        """F.getRealInput(str) -- get real value of the attribute"""
         return self.data().real(inputid).value()
 
-    def addResult (self, result):
+    def getTextInput(self, inputid):
+        """F.getTextInput(str) -- get text value of the attribute"""
+        return self.data().real(inputid).text()
+
+    def addResult(self, result):
+        """F.addResult(ModelAPI_Result) -- add ModelAPI_Result shape as a result"""
         shape = result.shape()
         body = self.document().createBody(self.data())
         body.store(shape)
         self.setResult(body)
 
-
-class Interface():
-    """Base class of high level Python interfaces to features."""
-
-    def __init__(self, feature):
-        self._feature = feature
-        self._attribute_white_list = [
-            "getKind", "results", "firstResult", "lastResult",
-            ]
-
-    def __getattr__(self, name):
-        """Process missing attributes.
-
-        Add get*() methods for access feature attributes.
-        Redirect some missing attributes to the feature.
-        """
-        if name.startswith("get"):
-            possible_names = [
-                "_" + name[3:],
-                "_" + tools.convert_to_underscore(name[3:]),
-                ]
-            for possible_name in possible_names:
-                if hasattr(self, possible_name):
-                    def getter():
-                        return getattr(self, possible_name)
-                    return getter
-
-        if name in self._attribute_white_list:
-            return getattr(self._feature, name)
-
-        raise AttributeError()
-
-    def feature(self):
-        """Return ModelAPI_Feature."""
-        return self._feature
-
-    def _fill_attribute(self, attribute, value, *args):
-        """Fill ModelAPI_Attribute* with value."""
-        tools.fill_attribute(attribute, value, *args)
-
-    def setRealInput(self, inputid, value):
-        self._feature.data().real(inputid).setValue(value)
-
-    def areInputValid(self):
-        validators = ModelAPI.ModelAPI_Session.get().validators()
-        return validators.validate(self._feature)
-
-    def execute(self):
-        self._feature.execute()