X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FMEDCoupling_Swig%2FMEDCouplingRefCountObject.i;h=fa29e6032415beaf0db0e8e00c0dbb70bf39c175;hb=8be544a31d08ec0537eef57b60edd48bc70c22db;hp=cfd9fdfdd40d9d96d40b326c8ab37f4c8aae78d3;hpb=6c3d35ba88b2b922633a39472f53fa5da11f2e8e;p=tools%2Fmedcoupling.git diff --git a/src/MEDCoupling_Swig/MEDCouplingRefCountObject.i b/src/MEDCoupling_Swig/MEDCouplingRefCountObject.i index cfd9fdfdd..fa29e6032 100644 --- a/src/MEDCoupling_Swig/MEDCouplingRefCountObject.i +++ b/src/MEDCoupling_Swig/MEDCouplingRefCountObject.i @@ -1,9 +1,9 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D +// Copyright (C) 2007-2016 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either -// version 2.1 of the License. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -29,14 +29,14 @@ namespace INTERP_KERNEL %extend { std::string __str__() const - { - return std::string(self->what()); - } + { + return std::string(self->what()); + } } }; } -namespace ParaMEDMEM +namespace MEDCoupling { class TimeLabel { @@ -49,7 +49,7 @@ namespace ParaMEDMEM }; } -namespace ParaMEDMEM +namespace MEDCoupling { typedef enum { @@ -68,6 +68,7 @@ namespace ParaMEDMEM public: std::size_t getHeapMemorySize() const throw(INTERP_KERNEL::Exception); std::string getHeapMemorySizeStr() const throw(INTERP_KERNEL::Exception); + bool isObjectInTheProgeny(const BigMemoryObject *obj) const throw(INTERP_KERNEL::Exception); virtual std::size_t getHeapMemorySizeWithoutChildren() const throw(INTERP_KERNEL::Exception); virtual ~BigMemoryObject(); %extend @@ -77,14 +78,23 @@ namespace ParaMEDMEM std::vector c(self->getDirectChildren()); PyObject *ret(PyList_New(c.size())); for(std::size_t i=0;i c(self->getAllTheProgeny()); + PyObject *ret(PyList_New(c.size())); + for(std::size_t i=0;i cppObjs; - convertFromPyObjVectorOfObj(objs,SWIGTYPE_p_ParaMEDMEM__BigMemoryObject,"BigMemoryObject",cppObjs); + convertFromPyObjVectorOfObj(objs,SWIGTYPE_p_MEDCoupling__BigMemoryObject,"BigMemoryObject",cppObjs); return BigMemoryObject::GetHeapMemorySizeOfObjs(cppObjs); } } @@ -96,7 +106,6 @@ namespace ParaMEDMEM bool decrRef() const; void incrRef() const; int getRCValue() const; - RefCountObjectOnly& operator=(const RefCountObjectOnly& other); protected: ~RefCountObjectOnly(); }; @@ -106,6 +115,29 @@ namespace ParaMEDMEM protected: ~RefCountObject(); }; + + class GlobalDict + { + public: + static GlobalDict *GetInstance() throw(INTERP_KERNEL::Exception); + bool hasKey(const std::string& key) const throw(INTERP_KERNEL::Exception); + std::string value(const std::string& key) const throw(INTERP_KERNEL::Exception); + std::vector keys() const throw(INTERP_KERNEL::Exception); + void erase(const std::string& key) throw(INTERP_KERNEL::Exception); + void clear() throw(INTERP_KERNEL::Exception); + void setKeyValue(const std::string& key, const std::string& value) throw(INTERP_KERNEL::Exception); + void setKeyValueForce(const std::string& key, const std::string& value) throw(INTERP_KERNEL::Exception); + private: + GlobalDict(); + public: + %extend + { + std::string __str__() const + { + return self->printSelf(); + } + } + }; } %inline @@ -130,6 +162,15 @@ namespace ParaMEDMEM #endif } + bool MEDCouplingHasSciPyBindings() + { +#ifdef WITH_SCIPY + return true; +#else + return false; +#endif + } + std::string MEDCouplingCompletionScript() throw(INTERP_KERNEL::Exception) { static const char script[]="import rlcompleter,readline\nreadline.parse_and_bind('tab:complete')"; @@ -139,3 +180,12 @@ namespace ParaMEDMEM return std::string(script); } } + +%pythoncode %{ +def INTERPKERNELExceptionReduceFunct(a,b): + ret=InterpKernelException.__new__(a) + ret.__init__(*b) + return ret +def INTERPKERNELExceptionReduce(self): + return INTERPKERNELExceptionReduceFunct,(InterpKernelException,(self.what(),)) +%}