Salome HOME
Work in progress : workload manager step 2
[modules/yacs.git] / src / engine / Container.cxx
1 // Copyright (C) 2006-2019  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 Container::Container():_isAttachedOnCloning(false),_proc(0)
36 {
37 }
38
39 Container::~Container()
40 {
41 }
42
43 std::string Container::getDiscreminantStrOfThis(const Task *askingNode) const
44 {
45   const void *ptr(this);
46   std::ostringstream oss; oss << ptr;
47   return oss.str();
48 }
49
50 void Container::start(const Task *askingNode,
51                       const std::string& resource_name,
52                       const std::string& container_name)
53 {
54   return start(askingNode);
55 }
56
57 bool Container::canAcceptImposedResource()
58 {
59   return false;
60 }
61
62 /*!
63  * If \a val is equal to true the current container 'this' is not destined to be deeply copied on clone call.
64  * If \a val is equal to false the current container 'this' is destined to be deeply copied on clone call.
65  */
66 void Container::setAttachOnCloningStatus(bool val) const
67 {
68   _isAttachedOnCloning=val;
69 }
70
71 /*!
72  * By calling this method the current container 'this' is not destined to be deeply copied on clone call.
73  */
74 void Container::attachOnCloning() const
75 {
76   _isAttachedOnCloning=true;
77 }
78
79 /*!
80  * By calling this method the current container 'this' will be deeply copied on clone call.
81  */
82 void Container::dettachOnCloning() const
83 {
84   _isAttachedOnCloning=false;
85 }
86
87 bool Container::isAttachedOnCloning() const
88 {
89   return _isAttachedOnCloning;
90 }
91
92 /*!
93  * This method informs about the capability of the container to deal with CT an unpredictably number of components.
94  * By default : True
95  */
96 bool Container::isSupportingRTODefNbOfComp() const
97 {
98   return true;
99 }
100
101 void Container::setProperties(const std::map<std::string,std::string>& properties)
102 {
103   for (std::map<std::string,std::string>::const_iterator it=properties.begin();it!=properties.end();++it)
104     setProperty((*it).first,(*it).second);
105 }
106