1 // Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
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.
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.
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
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 // Author : Anthony GEAY (EDF R&D)
21 #include "SALOMESDS_Transaction.hxx"
22 #include "SALOMESDS_Exception.hxx"
23 #include "SALOMESDS_PickelizedPyObjServer.hxx"
24 #include "SALOMESDS_PickelizedPyObjRdWrServer.hxx"
25 #include "SALOMESDS_PickelizedPyObjRdExtServer.hxx"
26 #include "SALOMESDS_TrustTransaction.hxx"
30 using namespace SALOMESDS;
32 void Transaction::FromByteSeqToVB(const SALOME::ByteVec& bsToBeConv, std::vector<unsigned char>& ret)
34 std::size_t sz(bsToBeConv.length());
36 unsigned char *buf(const_cast<unsigned char *>(&ret[0]));
37 for(std::size_t i=0;i<sz;i++)
41 void Transaction::FromVBToByteSeq(const std::vector<unsigned char>& bsToBeConv, SALOME::ByteVec& ret)
43 std::size_t sz(bsToBeConv.size());
45 for(std::size_t i=0;i<sz;i++)
49 Transaction::~Transaction()
53 TransactionVarCreate::TransactionVarCreate(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& constValue):Transaction(dsct,varName)
55 FromByteSeqToVB(constValue,_data);
58 void TransactionVarCreate::prepareRollBackInCaseOfFailure()
60 checkNotAlreadyExisting();
63 void TransactionVarCreate::rollBack()
65 if(_dsct->existVar(_var_name.c_str()))
66 _dsct->deleteVar(_var_name.c_str());
70 * no implementation it is not a bug !
72 void TransactionVarCreate::notify()
76 void TransactionRdOnlyVarCreate::perform()
78 SALOME::ByteVec data2;
79 FromVBToByteSeq(_data,data2);
80 _dsct->createRdOnlyVarInternal(_var_name,data2);
83 void TransactionRdExtVarCreate::perform()
85 SALOME::ByteVec data2;
86 FromVBToByteSeq(_data,data2);
87 _dsct->createRdExtVarInternal(_var_name,data2);
90 TransactionRdExtVarFreeStyleCreate::TransactionRdExtVarFreeStyleCreate(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& constValue, const char *compareFuncContent):_cmp_func_content(compareFuncContent),_cmp_func(nullptr),TransactionRdExtVarCreate(dsct,varName,constValue)
92 constexpr char EXPECTED_COMPARE_FUNC_NAME[]="comptchev";
93 SALOME::AutoPyRef context(PyDict_New());
94 SALOME::AutoPyRef res(PyRun_String(compareFuncContent,Py_file_input,_dsct->getGlobals(),context));
97 std::ostringstream oss; oss << "TransactionRdExtVarFreeStyleCreate ctor : Fail to parse and evaluate \"" << compareFuncContent << "\" as python function !";
98 throw Exception(oss.str());
100 PyObject *func(PyDict_GetItemString(context,EXPECTED_COMPARE_FUNC_NAME));//borrowed
103 std::ostringstream oss; oss << "TransactionRdExtVarFreeStyleCreate ctor : Parsing of func is OK but not func called \"" << EXPECTED_COMPARE_FUNC_NAME << "\" is the given parsed string !";
104 throw Exception(oss.str());
106 _cmp_func = func; Py_XINCREF(func);
107 if(PyDict_DelItemString(context,EXPECTED_COMPARE_FUNC_NAME)!=0)
109 std::ostringstream oss; oss << "TransactionRdExtVarFreeStyleCreate ctor : Internal error during suppression of \"" << EXPECTED_COMPARE_FUNC_NAME << "\" key that exepect to be present ! Smells bad !";
110 throw Exception(oss.str());
114 void TransactionRdExtVarFreeStyleCreate::prepareRollBackInCaseOfFailure()
115 {//nothing it is not a bug
118 void TransactionRdExtVarFreeStyleCreate::perform()
120 SALOME::ByteVec data2;
121 FromVBToByteSeq(_data,data2);
122 _dsct->createRdExtVarFreeStyleInternal(_var_name,data2,std::move(_cmp_func_content),std::move(_cmp_func));
125 void TransactionRdExtInitVarCreate::perform()
127 SALOME::ByteVec data2;
128 FromVBToByteSeq(_data,data2);
129 _dsct->createRdExtInitVarInternal(_var_name,data2);
132 void TransactionRdWrVarCreate::perform()
134 SALOME::ByteVec data2;
135 FromVBToByteSeq(_data,data2);
136 _dsct->createRdWrVarInternal(_var_name,data2);
139 TransactionKillVar::TransactionKillVar(DataScopeServerTransaction *dsct, const std::string& varName):Transaction(dsct,varName)
146 void TransactionKillVar::prepareRollBackInCaseOfFailure()
149 //BasicDataServer *bds(_dsct->retrieveVarInternal2(_var_name);
153 void TransactionKillVar::perform()
155 _dsct->deleteVar(_var_name.c_str());
161 void TransactionKillVar::rollBack()
166 * no implementation it is not a bug ! killVar is not an event.
168 void TransactionKillVar::notify()
172 TransactionDictModify::TransactionDictModify(DataScopeServerTransaction *dsct, const std::string& varName):Transaction(dsct,varName),_varc(0)
174 _varc=checkVarExistingAndDict();
177 void TransactionDictModify::prepareRollBackInCaseOfFailure()
179 _zeDataBefore.clear();
180 PyObject *zeDictPy(_varc->getPyObj());
181 Py_XINCREF(zeDictPy);
182 _zeDataBefore=_varc->pickelize(zeDictPy);
185 void TransactionDictModify::rollBack()
187 PyObject *obj(_varc->getPyObjFromPickled(_zeDataBefore));
188 _varc->setNewPyObj(obj);
189 _zeDataBefore.clear();
192 TransactionAddKeyValue::TransactionAddKeyValue(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value):TransactionDictModify(dsct,varName)
194 std::vector<unsigned char> key2,value2;
195 FromByteSeqToVB(key,key2);
196 FromByteSeqToVB(value,value2);
197 _key=PickelizedPyObjServer::GetPyObjFromPickled(key2,_dsct);
198 _value=PickelizedPyObjServer::GetPyObjFromPickled(value2,_dsct);
201 void TransactionAddKeyValue::prepareRollBackInCaseOfFailure()
203 TransactionDictModify::prepareRollBackInCaseOfFailure();
204 _dsct->pingKey(_key);// check that key is OK with all waiting keys
207 void TransactionAddKeyValue::notify()
209 _dsct->notifyKey(getVarName(),_key,_value);
212 TransactionAddKeyValue::~TransactionAddKeyValue()
218 TransactionAddKeyValueHard::TransactionAddKeyValueHard(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value):TransactionAddKeyValue(dsct,varName,key,value)
222 void TransactionAddKeyValueHard::perform()
224 _varc->addKeyValueHard(_key,_value);
227 TransactionAddKeyValueErrorIfAlreadyExisting::TransactionAddKeyValueErrorIfAlreadyExisting(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& key, const SALOME::ByteVec& value):TransactionAddKeyValue(dsct,varName,key,value)
229 _varc->checkKeyNotAlreadyPresent(_key);
232 void TransactionAddKeyValueErrorIfAlreadyExisting::perform()
234 _varc->addKeyValueErrorIfAlreadyExisting(_key,_value);
237 TransactionRemoveKeyInVarErrorIfNotAlreadyExisting::TransactionRemoveKeyInVarErrorIfNotAlreadyExisting(DataScopeServerTransaction *dsct, const std::string& varName, const SALOME::ByteVec& key):TransactionDictModify(dsct,varName),_key(0)
239 std::vector<unsigned char> key2;
240 FromByteSeqToVB(key,key2);
241 _key=PickelizedPyObjServer::GetPyObjFromPickled(key2,_dsct);
244 void TransactionRemoveKeyInVarErrorIfNotAlreadyExisting::perform()
246 _varc->removeKeyInVarErrorIfNotAlreadyExisting(_key);
250 * no implementation it is not a bug !
252 void TransactionRemoveKeyInVarErrorIfNotAlreadyExisting::notify()
256 TransactionRemoveKeyInVarErrorIfNotAlreadyExisting::~TransactionRemoveKeyInVarErrorIfNotAlreadyExisting()
261 TransactionMorphRdWrIntoRdOnly::TransactionMorphRdWrIntoRdOnly(DataScopeServerTransaction *dsct, const std::string& varName):Transaction(dsct,varName)
265 SALOME::PickelizedPyObjRdWrServer_ptr TransactionMorphRdWrIntoRdOnly::getVar()
267 SALOME::BasicDataServer_var obj(_dsct->retrieveVarInternal(_var_name.c_str()));
268 SALOME::PickelizedPyObjRdWrServer_ptr ret(SALOME::PickelizedPyObjRdWrServer::_narrow(obj));
269 if(CORBA::is_nil(ret))
271 std::ostringstream oss; oss << "TransactionMorphRdWrIntoRdOnly::getVar : var \"" << _var_name << "\" has not expected PickelizedPyObjRdWrServer type !";
272 throw Exception(oss.str());
277 void TransactionMorphRdWrIntoRdOnly::prepareRollBackInCaseOfFailure()
279 BasicDataServer *var(_dsct->retrieveVarInternal2(_var_name));
281 throw Exception("TransactionMorphRdWrIntoRdOnly::prepareRollBackInCaseOfFailure : Returned var is NULL !");
282 PickelizedPyObjRdWrServer *varc(dynamic_cast<PickelizedPyObjRdWrServer *>(var));
284 throw Exception("TransactionMorphRdWrIntoRdOnly::prepareRollBackInCaseOfFailure : Returned var has not expected type !");
287 void TransactionMorphRdWrIntoRdOnly::perform()
289 _dsct->moveStatusOfVarFromRdWrToRdOnly(_var_name);
292 void TransactionMorphRdWrIntoRdOnly::rollBack()
294 _dsct->moveStatusOfVarFromRdOnlyToRdWr(_var_name);
298 * no implementation it is not a bug !
300 void TransactionMorphRdWrIntoRdOnly::notify()
304 TransactionMultiKeyAddSession::TransactionMultiKeyAddSession(DataScopeServerTransaction *dsct, const std::string& varName):Transaction(dsct,varName)
306 _dsct->moveStatusOfVarFromRdExtOrRdExtInitToRdExtInit(_var_name);
309 void TransactionMultiKeyAddSession::addKeyValueInVarErrorIfAlreadyExistingNow(const SALOME::ByteVec& key, const SALOME::ByteVec& value)
311 _dsct->checkVarExistingAndDict(_var_name);
312 TransactionAddKeyValueErrorIfAlreadyExisting ret(_dsct,_var_name,key,value);
315 /*bool mustRollback(true);
317 t.setTransaction(&ret,&mustRollback);
319 mustRollback=false;//important let this line to notify t that everything was OK*/
325 * no implementation it is not a bug !
327 void TransactionMultiKeyAddSession::prepareRollBackInCaseOfFailure()
331 void TransactionMultiKeyAddSession::perform()
333 _dsct->moveStatusOfVarFromRdExtOrRdExtInitToRdExt(_var_name);
337 * no implementation it is not a bug !
339 void TransactionMultiKeyAddSession::rollBack()
344 * no implementation it is not a bug !
346 void TransactionMultiKeyAddSession::notify()