Salome HOME
Implementation of working glob var. Remove memory leak on TestSalomeSDS.py.
[modules/kernel.git] / src / SALOMESDS / SALOMESDS_DataScopeServer.hxx
1 // Copyright (C) 2007-2015  CEA/DEN, EDF R&D, OPEN CASCADE
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 // Author : Anthony GEAY (EDF R&D)
20
21 #ifndef __SALOMESDS_DATASCOPEERVER_HXX__
22 #define __SALOMESDS_DATASCOPEERVER_HXX__
23
24 #include "SALOMEconfig.h"
25 #include CORBA_SERVER_HEADER(SALOME_SDS)
26
27 #include "SALOMESDS_RefCountServ.hxx"
28 #include "SALOMESDS_AutoRefCountPtr.hxx"
29 #include "SALOMESDS_BasicDataServer.hxx"
30 #include "SALOMESDS_Defines.hxx"
31
32 #include <Python.h>
33
34 #include <string>
35 #include <vector>
36 #include <list>
37
38 namespace SALOMESDS
39 {
40   class SALOMESDS_EXPORT DataScopeKiller : public POA_SALOME::DataScopeKiller
41   {
42   public:
43     DataScopeKiller(CORBA::ORB_ptr orb):_orb(CORBA::ORB::_duplicate(orb)) { }
44     void shutdown();
45   private:
46     CORBA::ORB_var _orb;
47   };
48   
49   class KeyWaiter;
50   class PickelizedPyObjServer;
51
52   class SALOMESDS_EXPORT DataScopeServerBase : public virtual POA_SALOME::DataScopeServerBase, public POAHolder
53   {
54   public:
55     DataScopeServerBase(CORBA::ORB_ptr orb, SALOME::DataScopeKiller_var killer, const std::string& scopeName);
56     DataScopeServerBase(const DataScopeServerBase& other);
57     void ping();
58     char *getScopeName();
59     SALOME::StringVec *listVars();
60     CORBA::Boolean existVar(const char *varName);
61     SALOME::BasicDataServer_ptr retrieveVarInternal(const char *varName);
62     void deleteVar(const char *varName);
63     CORBA::Boolean shutdownIfNotHostedByDSM(SALOME::DataScopeKiller_out killer);
64     SALOME::ByteVec *fetchSerializedContent(const char *varName);
65     SALOME::SeqOfByteVec *getAllKeysOfVarWithTypeDict(const char *varName);
66     ~DataScopeServerBase();
67   public:
68     BasicDataServer *retrieveVarInternal2(const std::string& varName);
69     void initializePython(int argc, char *argv[]);
70     void registerToSalomePiDict() const;
71     void setPOA(PortableServer::POA_var poa);
72     void registerInNS(SALOME::DataScopeServerBase_ptr ptr);
73     PyObject *getGlobals() const { return _globals; }
74     PyObject *getLocals() const { return _locals; }
75     PyObject *getPickler() const { return _pickler; }
76     PortableServer::POA_var getPOA() const { return _poa; }
77     CORBA::ORB_var getORB() { return _orb; }
78     std::string getScopeNameCpp() const { return _name; }
79     static std::string BuildTmpVarNameFrom(const std::string& varName);
80   public:
81     std::vector< std::string> getAllVarNames() const;
82     void checkNotAlreadyExistingVar(const std::string& varName) const;
83     void checkExistingVar(const std::string& varName) const;
84     PickelizedPyObjServer *checkVarExistingAndDict(const std::string& varName);
85   public:
86     void moveStatusOfVarFromRdWrToRdOnly(const std::string& varName);
87     void moveStatusOfVarFromRdOnlyToRdWr(const std::string& varName);
88   protected:
89     std::list< std::pair< SALOME::BasicDataServer_var, BasicDataServer * > >::const_iterator retrieveVarInternal3(const std::string& varName) const;
90     std::list< std::pair< SALOME::BasicDataServer_var, BasicDataServer * > >::iterator retrieveVarInternal4(const std::string& varName);
91   protected:
92     PyObject *_globals;
93     PyObject *_locals;
94     PyObject *_pickler;
95     PortableServer::POA_var _poa;
96     CORBA::ORB_var _orb;
97     std::string _name;
98     std::list< std::pair< SALOME::BasicDataServer_var, BasicDataServer * > > _vars;
99     SALOME::DataScopeKiller_var _killer;
100     static std::size_t COUNTER;
101   };
102   
103   class SALOMESDS_EXPORT DataScopeServer : public DataScopeServerBase, public virtual POA_SALOME::DataScopeServer
104   {
105   public:
106     DataScopeServer(CORBA::ORB_ptr orb, SALOME::DataScopeKiller_var killer, const std::string& scopeName);
107     DataScopeServer(const DataScopeServer& other);
108     SALOME::BasicDataServer_ptr retrieveVar(const char *varName) { return retrieveVarInternal(varName); }
109     SALOME::PickelizedPyObjRdOnlyServer_ptr createRdOnlyVar(const char *varName, const SALOME::ByteVec& constValue);
110     SALOME::PickelizedPyObjRdExtServer_ptr createRdExtVar(const char *varName, const SALOME::ByteVec& constValue);
111     SALOME::PickelizedPyObjRdWrServer_ptr createRdWrVar(const char *typeName, const char *varName);
112     ~DataScopeServer();
113   };
114
115   class SALOMESDS_EXPORT DataScopeServerTransaction : public DataScopeServerBase, public virtual POA_SALOME::DataScopeServerTransaction
116   {
117   public://not remotely callable
118     DataScopeServerTransaction(CORBA::ORB_ptr orb, SALOME::DataScopeKiller_var killer, const std::string& scopeName);
119     DataScopeServerTransaction(const DataScopeServerTransaction& other);
120     ~DataScopeServerTransaction();
121     void createRdOnlyVarInternal(const std::string& varName, const SALOME::ByteVec& constValue);
122     void createRdExtVarInternal(const std::string& varName, const SALOME::ByteVec& constValue);
123     void createRdWrVarInternal(const std::string& varName, const SALOME::ByteVec& constValue);
124     PortableServer::POA_var getPOA4KeyWaiter() const { return _poa_for_key_waiter; }
125     void addWaitKey(KeyWaiter *kw);
126     void pingKey(PyObject *keyObj);
127     void notifyKey(PyObject *keyObj, PyObject *valueObj);
128     SALOME::ByteVec *waitForMonoThrRev(SALOME::KeyWaiter_ptr kw);
129   public://remotely callable
130     char *getAccessOfVar(const char *varName);
131     SALOME::Transaction_ptr createRdOnlyVarTransac(const char *varName, const SALOME::ByteVec& constValue);
132     SALOME::Transaction_ptr createRdExtVarTransac(const char *varName, const SALOME::ByteVec& constValue);
133     SALOME::Transaction_ptr createRdWrVarTransac(const char *varName, const SALOME::ByteVec& constValue);
134     SALOME::Transaction_ptr addKeyValueInVarHard(const char *varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value);
135     SALOME::Transaction_ptr addKeyValueInVarErrorIfAlreadyExisting(const char *varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value);
136     void addKeyValueInVarErrorIfAlreadyExistingNow(const char *varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value);
137     SALOME::Transaction_ptr removeKeyInVarErrorIfNotAlreadyExisting(const char *varName, const SALOME::ByteVec& key);
138     SALOME::TransactionRdWrAccess_ptr createWorkingVarTransac(const char *varName, const SALOME::ByteVec& constValue);
139     SALOME::KeyWaiter_ptr waitForKeyInVar(const char *varName, const SALOME::ByteVec& keyVal);
140     SALOME::KeyWaiter_ptr waitForKeyInVarAndKillIt(const char *varName, const SALOME::ByteVec& keyVal, SALOME::Transaction_out transac);
141     void atomicApply(const SALOME::ListOfTransaction& transactions);
142   private:
143     PyObject *getPyCmpFunc();
144   private:
145     PortableServer::POA_var _poa_for_key_waiter;
146     std::list< KeyWaiter * > _waiting_keys;
147   };
148 }
149
150 #endif