0031307: Modeling Algorithms - Offset algorithm produces incorrect result in mode...
[occt.git] / src / DBRep / DBRep_Debug.cxx
1 // Created on: 1994-07-25
2 // Created by: Remi LEQUETTE
3 // Copyright (c) 1994-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #include <DBRep.hxx>
18 #include <Standard_ErrorHandler.hxx>
19 #include <Standard_Failure.hxx>
20 #include <TopTools_ListOfShape.hxx>
21 #include <TopTools_IndexedMapOfShape.hxx>
22 #include <TopTools_MapOfShape.hxx>
23 #include <TopTools_SequenceOfShape.hxx>
24 #include <TopTools_Array1OfShape.hxx>
25 #include <NCollection_Vector.hxx>
26 #include <TopoDS_Compound.hxx>
27 #include <BRep_Builder.hxx>
28
29 // This file defines global functions not declared in any public header,
30 // intended for use from debugger prompt (Command Window in Visual Studio)
31
32 //! Save shape identified by pointer
33 Standard_EXPORT const char* DBRep_Set (const char* theNameStr, void* theShapePtr)
34 {
35   if (theNameStr == 0 || theShapePtr == 0)
36   {
37     return "Error: name or shape is null";
38   }
39   try {
40     DBRep::Set (theNameStr, *(TopoDS_Shape*)theShapePtr);
41     return theNameStr;
42   }
43   catch (Standard_Failure const& anException)
44   {
45     return anException.GetMessageString();
46   }
47 }
48
49 //=======================================================================
50 //function : fromContainer
51 //purpose  : static function to copy shapes from container into compound
52 //=======================================================================
53 template <class T>
54 static Standard_Boolean fromContainer (void* theContainer,
55                                        TopoDS_Compound& theShape)
56 {
57   try
58   {
59     T *pContainer = (T*) theContainer;
60     for (typename T::Iterator it (*pContainer); it.More(); it.Next())
61     {
62       BRep_Builder().Add (theShape, it.Value());
63     }
64     return true;
65   }
66   catch (Standard_Failure const&)
67   {
68     return false;
69   }
70 }
71
72 //=======================================================================
73 //function : DBRep_SetComp
74 //purpose  : make compound from the given container of shapes
75 //=======================================================================
76 Standard_EXPORT const char* DBRep_SetComp(const char* theNameStr, void* theListPtr)
77 {
78   if (theNameStr == 0 || theListPtr == 0)
79   {
80     return "Error: name or list of shapes is null";
81   }
82
83   TopoDS_Compound aC;
84   BRep_Builder().MakeCompound(aC);
85
86   if (fromContainer<TopTools_ListOfShape>       (theListPtr, aC)
87    || fromContainer<TopTools_MapOfShape>        (theListPtr, aC)
88    || fromContainer<TopTools_IndexedMapOfShape> (theListPtr, aC)
89    || fromContainer<TopTools_SequenceOfShape>   (theListPtr, aC)
90    || fromContainer<TopTools_Array1OfShape>     (theListPtr, aC)
91    || fromContainer<NCollection_Vector<TopoDS_Shape> > (theListPtr, aC))
92   {
93     DBRep::Set (theNameStr, aC);
94     return theNameStr;
95   }
96   else
97   {
98     return "Error: Invalid type";
99   }
100 }
101
102 // MSVC debugger cannot deal correctly with functions whose argunments 
103 // have non-standard types. Here we define alternative to the above functions
104 // with good types with the hope that GDB on Linux or other debugger could
105 // work with them (DBX could, on SUN Solaris).
106 #ifndef _MSC_VER
107
108 const char* DBRep_Set (char* theName, const TopoDS_Shape& theShape)
109 {
110  return DBRep_Set (theName, (void*)&theShape);
111 }
112
113 #endif /* _MSC_VER */
114
115 // old function, perhaps too dangerous to be used
116 /*
117 void DBRep_Get(char* name, TopoDS_Shape& S)
118 {
119   char n[255];
120   strcpy(n,name);
121   Standard_CString cs = (Standard_CString)n;
122   S = DBRep::Get(cs);
123   if (*name == '.')
124     std::cout << "Name : " << n << std::endl;
125 }
126 */