2 // Class : Ecriture d'un dump python
4 // Copyright (C) 2009-2013 CEA/DEN, EDF R&D
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/
21 // or email : webmaster.salome@opencascade.com
23 #ifndef __DUMP_STUDY_H_
24 #define __DUMP_STUDY_H_
26 #include "Hex_defines.hxx"
27 #include "hexa_base.hxx"
31 #pragma warning ( disable: 4251 )
38 #define DumpStart0(p) bool actif=el_root->glob->dump.start(this, p)
39 #define DumpStart(p,args) bool actif=el_root->glob->dump.start(this, p); if (actif) el_root->glob->dump << args
40 #define DumpEnd el_root->glob->dump.close (actif)
41 #define DumpReturn(v) el_root->glob->dump.close (actif,v)
43 #define DumpLock bool actif=el_root->glob->dump.lock ()
44 #define DumpRestore el_root->glob->dump.restore (actif)
47 class HEXABLOCKENGINE_EXPORT DumpStudy
51 void setWitness (Witness* temoin) { witness = temoin ; }
53 DumpStudy& operator << (int val);
54 DumpStudy& operator << (double val);
55 DumpStudy& operator << (cpchar val);
56 DumpStudy& operator << (EltBase* elt);
57 DumpStudy& operator << (Edges& elt);
58 DumpStudy& operator << (Quads& elt);
59 DumpStudy& operator << (Hexas& elt);
60 DumpStudy& operator << (RealVector& elt);
62 bool start (EltBase* obj, cpchar method);
63 bool start (cpchar obj, cpchar method, bool razmess=true);
64 void close (bool reactive);
65 void close (bool reactive, EltBase* retour);
66 void close (bool reactive, int retour);
67 void close (bool reactive, double retour);
70 void restore (bool reactive);
71 void getBegin (string& begin);
74 cpchar findName (EltBase* elt);
75 void addArgVector (EnumElt type, TabElts& table);
76 void addArgument (cpchar arg);
77 void addArgument (string& arg) { addArgument (arg.c_str()) ; }
78 void declareVectors ();
79 void addVector (cpchar name);
80 void majVector (cpchar value);
84 std::map <EltBase*, std::string> map_name;
85 std::vector <std::string> tab_declar;
87 int tab_count [EL_MAXI];