// Copyright (C) 2007-2021 CEA/DEN, EDF R&D, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // // 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, 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 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef _SMESH_PYTHONDUMP_HXX_ #define _SMESH_PYTHONDUMP_HXX_ #include "SMESH.hxx" #include #include CORBA_SERVER_HEADER(SMESH_Mesh) #include CORBA_SERVER_HEADER(SMESH_MeshEditor) #include CORBA_SERVER_HEADER(GEOM_Gen) #include CORBA_SERVER_HEADER(SALOMEDS) #include #include #include #include #include #include class SMESH_Gen_i; class SMESH_MeshEditor_i; // =========================================================================================== /*! * \brief Tool converting SMESH engine calls into commands defined in smeshBuilder.py * * Implementation is in SMESH_2smeshpy.cxx */ // =========================================================================================== class SMESH_2smeshpy { public: /*! * \brief Convert a python script using commands of smeshBuilder.py * \param theScript - the Input script to convert * \param theEntry2AccessorMethod - returns method names to access to * objects wrapped with python class * \param theObjectNames - names of objects * \param theRemovedObjIDs - entries of objects whose created commands were removed * \param theHistoricalDump - true means to keep all commands, false means * to exclude commands relating to objects removed from study * \retval TCollection_AsciiString - Conversion result */ static void ConvertScript(std::list< TCollection_AsciiString >& theScriptLines, Resource_DataMapOfAsciiStringAsciiString& theEntry2AccessorMethod, Resource_DataMapOfAsciiStringAsciiString& theObjectNames, std::set< TCollection_AsciiString >& theRemovedObjIDs, const bool theHistoricalDump); /*! * \brief Return the name of the python file wrapping IDL API * \retval const char* - the file name */ static const char* SmeshpyName() { return "smesh"; } static const char* GenName() { return "smesh"; } }; namespace SMESH { class FilterLibrary_i; class FilterManager_i; class Filter_i; class Functor_i; class Measurements_i; // =========================================================================================== /*! * \brief Object used to make TPythonDump know that its held value can be a variable * * TPythonDump substitute TVar with names of notebook variables if any. */ // =========================================================================================== struct SMESH_I_EXPORT TVar { std::vector< std::string > myVals; bool myIsList; TVar(CORBA::Double value); TVar(CORBA::Long value); TVar(CORBA::LongLong value); TVar(CORBA::Short value); TVar(const SMESH::double_array& value); // string used to temporary quote variable names in order // not to confuse variables with string arguments static char Quote() { return '$'; } // string preceding an entry of object storing the attribute holding var names static const char* ObjPrefix() { return " # OBJ: "; } }; // =========================================================================================== /*! * \brief Utility helping in storing SMESH engine calls as python commands */ // =========================================================================================== class SMESH_I_EXPORT TPythonDump { std::ostringstream myStream; static size_t myCounter; int myVarsCounter; // counts stored TVar's SMESH_Gen_i *mySmesh = nullptr; public: TPythonDump(SMESH_Gen_i *smesh); TPythonDump(); virtual ~TPythonDump(); TPythonDump& operator<<(const TVar& theVariableValue); TPythonDump& operator<<(long int theArg); TPythonDump& operator<<(int theArg); TPythonDump& operator<<(long long theArg); TPythonDump& operator<<(double theArg); TPythonDump& operator<<(float theArg); TPythonDump& operator<<(const void* theArg); TPythonDump& operator<<(const char* theArg); TPythonDump& operator<<(const SMESH::ElementType& theArg); TPythonDump& operator<<(const SMESH::GeometryType& theArg); TPythonDump& operator<<(const SMESH::EntityType& theArg); TPythonDump& operator<<(const SMESH::long_array& theArg); TPythonDump& operator<<(const SMESH::smIdType_array& theArg); TPythonDump& operator<<(const SMESH::double_array& theArg); TPythonDump& operator<<(const SMESH::string_array& theArg); TPythonDump& operator<<(const SMESH::nodes_array& theArg); TPythonDump& operator<<(SMESH::SMESH_Hypothesis_ptr theArg); TPythonDump& operator<<(SMESH::SMESH_IDSource_ptr theArg); TPythonDump& operator<<(SALOMEDS::SObject_ptr theArg); TPythonDump& operator<<(CORBA::Object_ptr theArg); TPythonDump& operator<<(SMESH::FilterLibrary_i* theArg); TPythonDump& operator<<(SMESH::FilterManager_i* theArg); TPythonDump& operator<<(SMESH::Filter_i* theArg); TPythonDump& operator<<(SMESH::Functor_i* theArg); TPythonDump& operator<<(SMESH::Measurements_i* theArg); TPythonDump& operator<<(SMESH_Gen_i* theArg); TPythonDump& operator<<(SMESH_MeshEditor_i* theArg); TPythonDump& operator<<(const SMESH::AxisStruct & theAxis); TPythonDump& operator<<(const SMESH::DirStruct & theDir); TPythonDump& operator<<(const SMESH::PointStruct & P); TPythonDump& operator<<(const TCollection_AsciiString & theArg); TPythonDump& operator<<(const SMESH::ListOfGroups& theList); TPythonDump& operator<<(const SMESH::ListOfGroups * theList); TPythonDump& operator<<(const GEOM::ListOfGO& theList); TPythonDump& operator<<(const GEOM::ListOfGBO& theList); TPythonDump& operator<<(const SMESH::ListOfIDSources& theList); TPythonDump& operator<<(const SMESH::submesh_array& theList); TPythonDump& operator<<(const SMESH::ListOfHypothesis& theList); TPythonDump& operator<<(const SMESH::CoincidentFreeBorders& theCFB); TPythonDump& operator<<(const std::string& theArg); template static TStream& DumpArray(const TArray& theArray, TStream & theStream) { if ( theArray.length() == 0 ) { theStream << "[]"; } else { theStream << "[ "; for (CORBA::ULong i = 1; i <= theArray.length(); i++) { theStream << theArray[i-1]; if ( i < theArray.length() ) theStream << ", "; } theStream << " ]"; } return theStream; } static const char* SMESHGenName() { return "smeshgen"; } static const char* MeshEditorName() { return "mesh_editor"; } static const char* NotPublishedObjectName(); /*! * \brief Return marker of long string literal beginning * \param type - a name of functionality producing the string literal * \retval TCollection_AsciiString - the marker string to be written into * a raw python script */ static TCollection_AsciiString LongStringStart(const char* type); /*! * \brief Return marker of long string literal end * \retval TCollection_AsciiString - the marker string to be written into * a raw python script */ static TCollection_AsciiString LongStringEnd(); /*! * \brief Cut out a long string literal from a string * \param theText - text possibly containing string literals * \param theFrom - position in the text to search from * \param theLongString - the retrieved literal * \param theStringType - a name of functionality produced the literal * \retval bool - true if a string literal found * * The literal is removed from theText; theFrom points position right after * the removed literal */ static bool CutoutLongString( TCollection_AsciiString & theText, int & theFrom, TCollection_AsciiString & theLongString, TCollection_AsciiString & theStringType); }; } #endif