Salome HOME
Copyright update 2021
[modules/yacs.git] / src / engine / Container.cxx
1 // Copyright (C) 2006-2021  CEA/DEN, EDF R&D
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 //
19
20 #include "Container.hxx"
21 #include "ComponentInstance.hxx"
22
23 //#define _DEVDEBUG_
24 #include "YacsTrace.hxx"
25
26 #include <sstream>
27
28 using namespace std;
29 using namespace YACS::ENGINE;
30
31 const char Container::KIND_ENTRY[]="container_kind";
32
33 const char Container::AOC_ENTRY[]="attached_on_cloning";
34
35 const char Container::USE_PYCACHE_PROPERTY[]="use_py_cache";
36
37 Container::Container():_isAttachedOnCloning(false),_proc(0)
38 {
39 }
40
41 Container::~Container()
42 {
43 }
44
45 std::string Container::getDiscreminantStrOfThis(const Task *askingNode) const
46 {
47   const void *ptr(this);
48   std::ostringstream oss; oss << ptr;
49   return oss.str();
50 }
51
52 void Container::start(const Task *askingNode,
53                       const std::string& resource_name,
54                       const std::string& container_name)
55 {
56   return start(askingNode);
57 }
58
59 bool Container::canAcceptImposedResource()
60 {
61   return false;
62 }
63
64 /*!
65  * If \a val is equal to true the current container 'this' is not destined to be deeply copied on clone call.
66  * If \a val is equal to false the current container 'this' is destined to be deeply copied on clone call.
67  */
68 void Container::setAttachOnCloningStatus(bool val) const
69 {
70   _isAttachedOnCloning=val;
71 }
72
73 /*!
74  * By calling this method the current container 'this' is not destined to be deeply copied on clone call.
75  */
76 void Container::attachOnCloning() const
77 {
78   _isAttachedOnCloning=true;
79 }
80
81 /*!
82  * By calling this method the current container 'this' will be deeply copied on clone call.
83  */
84 void Container::dettachOnCloning() const
85 {
86   _isAttachedOnCloning=false;
87 }
88
89 bool Container::isAttachedOnCloning() const
90 {
91   return _isAttachedOnCloning;
92 }
93
94 /*!
95  * This method informs about the capability of the container to deal with CT an unpredictably number of components.
96  * By default : True
97  */
98 bool Container::isSupportingRTODefNbOfComp() const
99 {
100   return true;
101 }
102
103 void Container::setProperties(const std::map<std::string,std::string>& properties)
104 {
105   for (std::map<std::string,std::string>::const_iterator it=properties.begin();it!=properties.end();++it)
106     setProperty((*it).first,(*it).second);
107 }
108
109 bool Container::isUsingPythonCache()
110 {
111   bool found = false;
112   std::string str_value;
113   str_value = getProperty(USE_PYCACHE_PROPERTY);
114   const char* yes_values[] = {"YES", "Yes", "yes", "TRUE", "True", "true", "1",
115                               "ON", "on", "On"};
116   for(const char* v : yes_values)
117     if(str_value == v)
118     {
119       found = true;
120       break;
121     }
122   return found;
123 }
124
125 void Container::usePythonCache(bool v)
126 {
127   if(v)
128     setProperty(USE_PYCACHE_PROPERTY, "1");
129   else
130     setProperty(USE_PYCACHE_PROPERTY, "0");
131 }
132