mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-12 01:30:36 +05:00
Implementation of [bos #35140] [EDF] (2023-T1) Memory communication between SHAPER and GEOM
This commit is contained in:
parent
d617faae6b
commit
1e6d06f174
@ -45,6 +45,9 @@ geompy.ExportVTK(sphere, f_vtk2, 0.1)
|
|||||||
f_xao = os.path.join(tmpdir, "sphere.xao")
|
f_xao = os.path.join(tmpdir, "sphere.xao")
|
||||||
geompy.ExportXAO(sphere, [], [], "author", f_xao)
|
geompy.ExportXAO(sphere, [], [], "author", f_xao)
|
||||||
|
|
||||||
|
# export sphere to XAO format memory buffer (bytes array)
|
||||||
|
buff_xao = geompy.ExportXAOMem(sphere, [], [], "author")
|
||||||
|
|
||||||
# import BREP file
|
# import BREP file
|
||||||
sphere_brep = geompy.ImportBREP(f_brep)
|
sphere_brep = geompy.ImportBREP(f_brep)
|
||||||
|
|
||||||
@ -64,6 +67,9 @@ sphere_stl2 = geompy.ImportSTL(f_stl2)
|
|||||||
# import XAO file
|
# import XAO file
|
||||||
ok, sphere_xao, sub_shapes, groups, fields = geompy.ImportXAO(f_xao)
|
ok, sphere_xao, sub_shapes, groups, fields = geompy.ImportXAO(f_xao)
|
||||||
|
|
||||||
|
# import XAO data from memory buffer (bytes array)
|
||||||
|
ok_mem, sphere_xao_mem, sub_shapes_mem, groups_mem, fields_mem = geompy.ImportXAOMem(buff_xao)
|
||||||
|
|
||||||
# clean up
|
# clean up
|
||||||
for f in f_brep, f_iges, f_step, f_stl1, f_stl2, f_vtk1, f_vtk2, f_xao:
|
for f in f_brep, f_iges, f_step, f_stl1, f_stl2, f_vtk1, f_vtk2, f_xao:
|
||||||
os.remove(f)
|
os.remove(f)
|
||||||
|
@ -88,6 +88,16 @@ In the \b File menu select <b>Import/XAO</b>.
|
|||||||
|
|
||||||
\par
|
\par
|
||||||
|
|
||||||
|
It is possible to import a shape from XAO file using the TUI Command:
|
||||||
|
|
||||||
|
<em>ok, Shape, Sub_Shapes, Groups, Fields = geompy.ImportXAO(FileName)</em>
|
||||||
|
|
||||||
|
It is also possible to import a shape from XAO format memory buffer (bytes array) using the TUI Command:
|
||||||
|
|
||||||
|
<em>ok, Shape, Sub_Shapes, Groups, Fields = geompy.ImportXAOMem(aBuffer)</em>
|
||||||
|
|
||||||
|
\par
|
||||||
|
|
||||||
<em>To export a shape in the \b XAO format:</em>
|
<em>To export a shape in the \b XAO format:</em>
|
||||||
|
|
||||||
\par
|
\par
|
||||||
@ -104,6 +114,12 @@ In this dialog:
|
|||||||
- Select the \b Fields of the chosen shape to be exported.
|
- Select the \b Fields of the chosen shape to be exported.
|
||||||
- Press "Apply" or "Apply & Close" button to get the result.
|
- Press "Apply" or "Apply & Close" button to get the result.
|
||||||
|
|
||||||
It is also possible to export a shape using the TUI Command: <em>geompy.ExportXAO(Shape, Groups, Fields, Author, FileName, ShapeFileName)</em>
|
It is possible to export a shape in XAO file using the TUI Command:
|
||||||
|
|
||||||
|
<em>geompy.ExportXAO(Shape, Groups, Fields, Author, FileName, ShapeFileName)</em>
|
||||||
|
|
||||||
|
It is also possible to export a shape in XAO format memory buffer (bytes array) using the TUI Command:
|
||||||
|
|
||||||
|
<em>aBuffer = geompy.ExportXAOMem(Shape, Groups, Fields, Author)</em>
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
\anchor tui_creation_exportxao
|
|
||||||
<br><h2>Creation of ExportXAO</h2>
|
|
||||||
|
|
||||||
\code
|
|
||||||
import salome
|
|
||||||
import GEOM
|
|
||||||
from salome.geom import geomBuilder
|
|
||||||
geompy = geomBuilder.New()
|
|
||||||
|
|
||||||
gg = salome.ImportComponentGUI("GEOM")
|
|
||||||
|
|
||||||
# create ExportXAO object
|
|
||||||
exportxao = geompy.ExportXAO([value], [value], [value], [value])
|
|
||||||
|
|
||||||
# add object in the study
|
|
||||||
id_exportxao = geompy.addToStudy(exportxao,"ExportXAO")
|
|
||||||
|
|
||||||
# display exportxao
|
|
||||||
gg.createAndDisplayGO(id_exportxao)
|
|
||||||
\endcode
|
|
||||||
|
|
@ -46,6 +46,19 @@ module GEOM
|
|||||||
in string fileName,
|
in string fileName,
|
||||||
in string shapeFileName );
|
in string shapeFileName );
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Export a shape to XAO format in a byte array
|
||||||
|
* \param shape The shape to export
|
||||||
|
* \param groups The list of groups to export
|
||||||
|
* \param fields The list of fields to export
|
||||||
|
* \param author The author of the export
|
||||||
|
* \return Byte array with exported data.
|
||||||
|
*/
|
||||||
|
SALOMEDS::TMPFile ExportXAOMem( in GEOM::GEOM_Object shape,
|
||||||
|
in GEOM::ListOfGO groups,
|
||||||
|
in GEOM::ListOfFields fields,
|
||||||
|
in string author );
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Import a shape from XAO format
|
* Import a shape from XAO format
|
||||||
* \param fileName The name of the file to import
|
* \param fileName The name of the file to import
|
||||||
@ -60,6 +73,21 @@ module GEOM
|
|||||||
out GEOM::ListOfGO subShapes,
|
out GEOM::ListOfGO subShapes,
|
||||||
out GEOM::ListOfGO groups,
|
out GEOM::ListOfGO groups,
|
||||||
out GEOM::ListOfFields fields );
|
out GEOM::ListOfFields fields );
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Import a shape from XAO format byte array
|
||||||
|
* \param theBuff The byte array with data in XAO format
|
||||||
|
* \param shape The imported shape
|
||||||
|
* \param subShapes The list of imported subShapes
|
||||||
|
* \param groups The list of imported groups
|
||||||
|
* \param fields The list of imported fields
|
||||||
|
* \return boolean indicating if import was successful.
|
||||||
|
*/
|
||||||
|
boolean ImportXAOMem( in SALOMEDS::TMPFile theBuff,
|
||||||
|
out GEOM::GEOM_Object shape,
|
||||||
|
out GEOM::ListOfGO subShapes,
|
||||||
|
out GEOM::ListOfGO groups,
|
||||||
|
out GEOM::ListOfFields fields );
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
#
|
#
|
||||||
|
|
||||||
|
import GEOM
|
||||||
from GEOM import IXAOOperations
|
from GEOM import IXAOOperations
|
||||||
|
|
||||||
# Engine Library Name
|
# Engine Library Name
|
||||||
@ -57,6 +58,32 @@ def ExportXAO(self, shape, groups, fields, author, fileName, shapeFileName = "")
|
|||||||
RaiseIfFailed("ExportXAO", anOp)
|
RaiseIfFailed("ExportXAO", anOp)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
## Export a shape to XAO format in byte array
|
||||||
|
# @param shape The shape to export
|
||||||
|
# @param groups The list of groups to export
|
||||||
|
# @param fields The list of fields to export
|
||||||
|
# @param author The author of the file
|
||||||
|
# @return Byte array with exported data
|
||||||
|
#
|
||||||
|
# @ingroup l2_import_export
|
||||||
|
def ExportXAOMem(self, shape, groups, fields, author):
|
||||||
|
"""
|
||||||
|
Export a shape to XAO format in byte array
|
||||||
|
|
||||||
|
Parameters:
|
||||||
|
shape The shape to export
|
||||||
|
groups The list of groups to export
|
||||||
|
fields The list of fields to export
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
Byte array with exported data
|
||||||
|
"""
|
||||||
|
from salome.geom.geomBuilder import RaiseIfFailed
|
||||||
|
anOp = GetXAOPluginOperations(self)
|
||||||
|
res = anOp.ExportXAOMem(shape, groups, fields, author)
|
||||||
|
RaiseIfFailed("ExportXAOMem", anOp)
|
||||||
|
return res
|
||||||
|
|
||||||
## Import a shape from XAO format
|
## Import a shape from XAO format
|
||||||
# @param fileName The name of the file to import
|
# @param fileName The name of the file to import
|
||||||
# @param theName Object name; when specified, this parameter is used
|
# @param theName Object name; when specified, this parameter is used
|
||||||
@ -91,7 +118,78 @@ def ImportXAO(self, fileName, theName=None):
|
|||||||
"""
|
"""
|
||||||
from salome.geom.geomBuilder import RaiseIfFailed
|
from salome.geom.geomBuilder import RaiseIfFailed
|
||||||
anOp = GetXAOPluginOperations(self)
|
anOp = GetXAOPluginOperations(self)
|
||||||
res = anOp.ImportXAO(fileName)
|
(res, shape, subShapes, groups, fields) = anOp.ImportXAO(fileName)
|
||||||
RaiseIfFailed("ImportXAO", anOp)
|
RaiseIfFailed("ImportXAO", anOp)
|
||||||
self._autoPublish(res[1], theName, "imported")
|
if res:
|
||||||
return res
|
# publish imported shape
|
||||||
|
self._autoPublish(shape, theName, "imported")
|
||||||
|
# publish imported sub shapes, groups and fields
|
||||||
|
if theName or self.myMaxNbSubShapesAllowed:
|
||||||
|
for ss in (subShapes + groups + fields):
|
||||||
|
self.addToStudyInFather(shape, ss, ss.GetName())
|
||||||
|
if isinstance( ss, GEOM._objref_GEOM_Field ):
|
||||||
|
listStepIDs = ss.GetSteps()
|
||||||
|
for stepID in listStepIDs:
|
||||||
|
step = ss.GetStep(stepID)
|
||||||
|
self.addToStudyInFather(ss, step, step.GetName())
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
return (res, shape, subShapes, groups, fields)
|
||||||
|
|
||||||
|
## Import a shape from XAO format byte array
|
||||||
|
# @param byteArray byte array with XAO data
|
||||||
|
# @param theName Object name; when specified, this parameter is used
|
||||||
|
# for result publication in the study. Otherwise, if automatic
|
||||||
|
# publication is switched on, default value is used for result name.
|
||||||
|
#
|
||||||
|
# @return tuple (\a res, \a shape, \a subShapes, \a groups, \a fields)
|
||||||
|
# \a res Flag indicating if the import was successful
|
||||||
|
# \a shape The imported shape
|
||||||
|
# \a subShapes The list of imported subShapes
|
||||||
|
# \a groups The list of imported groups
|
||||||
|
# \a fields The list of imported fields
|
||||||
|
#
|
||||||
|
# @ingroup l2_import_export
|
||||||
|
def ImportXAOMem(self, byteArray, theName=None):
|
||||||
|
"""
|
||||||
|
Import a shape from XAO format byte array
|
||||||
|
|
||||||
|
Parameters:
|
||||||
|
byteArray byte array with XAO data
|
||||||
|
theName Object name; when specified, this parameter is used
|
||||||
|
for result publication in the study. Otherwise, if automatic
|
||||||
|
publication is switched on, default value is used for result name.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
A tuple (res, shape, subShapes, groups, fields):
|
||||||
|
- res: Flag indicating if the import was successful
|
||||||
|
- shape: The imported shape
|
||||||
|
- subShapes: The list of imported subShapes
|
||||||
|
- groups: The list of imported groups
|
||||||
|
- fields: The list of imported fields
|
||||||
|
"""
|
||||||
|
from salome.geom.geomBuilder import RaiseIfFailed
|
||||||
|
anOp = GetXAOPluginOperations(self)
|
||||||
|
(res, shape, subShapes, groups, fields) = anOp.ImportXAOMem(byteArray)
|
||||||
|
RaiseIfFailed("ImportXAOMem", anOp)
|
||||||
|
if res:
|
||||||
|
# publish imported shape
|
||||||
|
self._autoPublish(shape, theName, "imported")
|
||||||
|
# publish imported sub shapes, groups and fields
|
||||||
|
if theName or self.myMaxNbSubShapesAllowed:
|
||||||
|
for ss in (subShapes + groups + fields):
|
||||||
|
self.addToStudyInFather(shape, ss, ss.GetName())
|
||||||
|
if isinstance( ss, GEOM._objref_GEOM_Field ):
|
||||||
|
listStepIDs = ss.GetSteps()
|
||||||
|
for stepID in listStepIDs:
|
||||||
|
step = ss.GetStep(stepID)
|
||||||
|
self.addToStudyInFather(ss, step, step.GetName())
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
return (res, shape, subShapes, groups, fields)
|
||||||
|
@ -655,7 +655,9 @@ const std::string XaoExporter::saveToXml(Xao* xaoObject)
|
|||||||
|
|
||||||
xmlChar *xmlbuff;
|
xmlChar *xmlbuff;
|
||||||
int buffersize;
|
int buffersize;
|
||||||
xmlDocDumpFormatMemory(doc, &xmlbuff, &buffersize, 1); // format = 1 for node indentation
|
//xmlDocDumpFormatMemory(doc, &xmlbuff, &buffersize, 1); // format = 1 for node indentation
|
||||||
|
// save with encoding to correspond to "saveToFile" and provide the same file size
|
||||||
|
xmlDocDumpFormatMemoryEnc(doc, &xmlbuff, &buffersize, "UTF-8", 1); // format = 1 for node indentation
|
||||||
xmlFreeDoc(doc);
|
xmlFreeDoc(doc);
|
||||||
xmlCleanupGlobals();
|
xmlCleanupGlobals();
|
||||||
|
|
||||||
|
@ -58,6 +58,8 @@
|
|||||||
|
|
||||||
#include <TopExp.hxx>
|
#include <TopExp.hxx>
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
XAO::Dimension shapeEnumToDimension(const TopAbs_ShapeEnum& shape)
|
XAO::Dimension shapeEnumToDimension(const TopAbs_ShapeEnum& shape)
|
||||||
{
|
{
|
||||||
XAO::Dimension dim;
|
XAO::Dimension dim;
|
||||||
@ -323,12 +325,13 @@ void XAOPlugin_IOperations::exportSubshapes( const Handle(GEOM_Object)& shape, X
|
|||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* Export a shape to XAO format
|
* Export a shape to XAO format file.
|
||||||
* \param shape The shape to export
|
* \param shape The shape to export.
|
||||||
* \param groups The list of groups to export
|
* \param groups The list of groups to export.
|
||||||
* \param fields The list of fields to export
|
* \param fields The list of fields to export.
|
||||||
* \param fileName The name of the file to exported
|
* \param fileName The name of the file to be exported.
|
||||||
* \return boolean indicating if export was succeful.
|
* \param shapeFileName The name of the file for shape, if it should be exported separately.
|
||||||
|
* \return boolean indicating if export was successful.
|
||||||
*/
|
*/
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
bool XAOPlugin_IOperations::ExportXAO( Handle(GEOM_Object) shape,
|
bool XAOPlugin_IOperations::ExportXAO( Handle(GEOM_Object) shape,
|
||||||
@ -338,21 +341,67 @@ bool XAOPlugin_IOperations::ExportXAO( Handle(GEOM_Object) shape,
|
|||||||
const char* fileName,
|
const char* fileName,
|
||||||
const char* shapeFileName )
|
const char* shapeFileName )
|
||||||
{
|
{
|
||||||
SetErrorCode(KO);
|
if (!fileName || !strlen(fileName)) {
|
||||||
|
SetErrorCode("Empty file name");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (shape.IsNull()) return false;
|
exportXAO( shape, groupList, fieldList, author, fileName, shapeFileName );
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Export a shape to XAO format string.
|
||||||
|
* \param shape The shape to export.
|
||||||
|
* \param groups The list of groups to export.
|
||||||
|
* \param fields The list of fields to export.
|
||||||
|
* \return The exported string.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
std::string XAOPlugin_IOperations::ExportXAOMem( Handle(GEOM_Object) shape,
|
||||||
|
std::list<Handle(GEOM_Object)> groupList,
|
||||||
|
std::list<Handle(GEOM_Field)> fieldList,
|
||||||
|
const char* author )
|
||||||
|
{
|
||||||
|
std::string anXML = exportXAO( shape, groupList, fieldList, author, NULL, NULL );
|
||||||
|
return anXML;
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Export a shape to XAO format file or string.
|
||||||
|
* \param shape The shape to export.
|
||||||
|
* \param groups The list of groups to export.
|
||||||
|
* \param fields The list of fields to export.
|
||||||
|
* \param fileName The name of the file to be exported. If empty, export to string.
|
||||||
|
* \param shapeFileName The name of the file for shape, if it should be exported separately.
|
||||||
|
* \return The exported string, if fileName is empty, or empty string.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
std::string XAOPlugin_IOperations::exportXAO( Handle(GEOM_Object) shape,
|
||||||
|
std::list<Handle(GEOM_Object)> groupList,
|
||||||
|
std::list<Handle(GEOM_Field)> fieldList,
|
||||||
|
const char* author,
|
||||||
|
const char* fileName,
|
||||||
|
const char* shapeFileName )
|
||||||
|
{
|
||||||
|
SetErrorCode(KO);
|
||||||
|
std::string anXML ("");
|
||||||
|
|
||||||
|
if (shape.IsNull()) return anXML;
|
||||||
|
|
||||||
// add a new shape function with parameters
|
// add a new shape function with parameters
|
||||||
Handle(GEOM_Function) lastFunction = shape->GetLastFunction();
|
Handle(GEOM_Function) lastFunction = shape->GetLastFunction();
|
||||||
if (lastFunction.IsNull()) return false;
|
if (lastFunction.IsNull()) return anXML;
|
||||||
|
|
||||||
// add a new result object
|
// add a new result object
|
||||||
Handle(GEOM_Object) result = GetEngine()->AddObject(GEOM_IMPORT);
|
Handle(GEOM_Object) result = GetEngine()->AddObject(GEOM_IMPORT);
|
||||||
|
|
||||||
// add an Export function
|
// add an Export function
|
||||||
Handle(GEOM_Function) exportFunction = result->AddFunction(XAOPlugin_Driver::GetID(), EXPORT_SHAPE);
|
Handle(GEOM_Function) exportFunction = result->AddFunction(XAOPlugin_Driver::GetID(), EXPORT_SHAPE);
|
||||||
if (exportFunction.IsNull()) return false;
|
if (exportFunction.IsNull()) return anXML;
|
||||||
if (exportFunction->GetDriverGUID() != XAOPlugin_Driver::GetID()) return false;
|
if (exportFunction->GetDriverGUID() != XAOPlugin_Driver::GetID()) return anXML;
|
||||||
|
|
||||||
// create the XAO object
|
// create the XAO object
|
||||||
XAO::Xao* xaoObject = new XAO::Xao();
|
XAO::Xao* xaoObject = new XAO::Xao();
|
||||||
@ -369,16 +418,36 @@ bool XAOPlugin_IOperations::ExportXAO( Handle(GEOM_Object) shape,
|
|||||||
exportSubshapes(shape, geometry);
|
exportSubshapes(shape, geometry);
|
||||||
xaoObject->setGeometry(geometry);
|
xaoObject->setGeometry(geometry);
|
||||||
|
|
||||||
if (!exportGroups(groupList, xaoObject, geometry)) return false;
|
if (!exportGroups(groupList, xaoObject, geometry)) return anXML;
|
||||||
exportFields(fieldList, xaoObject, geometry);
|
exportFields(fieldList, xaoObject, geometry);
|
||||||
|
|
||||||
// export the XAO to the file
|
bool isFile = (fileName && strlen(fileName));
|
||||||
xaoObject->exportXAO(fileName, shapeFileName);
|
if (isFile) {
|
||||||
|
// export the XAO to the file
|
||||||
|
xaoObject->exportXAO(fileName, shapeFileName);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// export the XAO to the string
|
||||||
|
anXML = xaoObject->getXML();
|
||||||
|
}
|
||||||
|
|
||||||
// make a Python command
|
// make a Python command
|
||||||
GEOM::TPythonDump pd(exportFunction);
|
GEOM::TPythonDump pd (exportFunction);
|
||||||
std::string convFileName = Kernel_Utils::BackSlashToSlash(fileName);
|
if (isFile) {
|
||||||
pd << "exported = geompy.ExportXAO(" << shape;
|
pd << "exported = geompy.ExportXAO(";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!shape->GetName().IsEmpty()) {
|
||||||
|
std::string aGeometryNamePy (shape->GetName().ToCString());
|
||||||
|
std::replace(aGeometryNamePy.begin(), aGeometryNamePy.end(), ' ', '_');
|
||||||
|
pd << "aXAOBuff_" << aGeometryNamePy.c_str() << " = geompy.ExportXAOMem(";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
pd << "aXAOBuff = geompy.ExportXAOMem(";
|
||||||
|
}
|
||||||
|
|
||||||
|
// shape
|
||||||
|
pd << shape;
|
||||||
|
|
||||||
// list of groups
|
// list of groups
|
||||||
pd << ", [";
|
pd << ", [";
|
||||||
@ -404,12 +473,24 @@ bool XAOPlugin_IOperations::ExportXAO( Handle(GEOM_Object) shape,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
pd << "], ";
|
pd << "], ";
|
||||||
pd << "\"" << author << "\", \"" << convFileName.c_str() << "\", \"" << shapeFileName << "\")";
|
|
||||||
|
// author
|
||||||
|
pd << "\"" << author << "\"";
|
||||||
|
|
||||||
|
// files
|
||||||
|
if (isFile) {
|
||||||
|
std::string convFileName = Kernel_Utils::BackSlashToSlash(fileName);
|
||||||
|
std::string convShapeFileName;
|
||||||
|
if (shapeFileName && strlen(shapeFileName))
|
||||||
|
convShapeFileName = Kernel_Utils::BackSlashToSlash(shapeFileName);
|
||||||
|
pd << ", \"" << convFileName.c_str() << "\", \"" << convShapeFileName.c_str() << "\"";
|
||||||
|
}
|
||||||
|
pd << ")";
|
||||||
|
|
||||||
SetErrorCode(OK);
|
SetErrorCode(OK);
|
||||||
delete xaoObject;
|
delete xaoObject;
|
||||||
|
|
||||||
return true;
|
return anXML;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XAOPlugin_IOperations::importSubShapes( XAO::Geometry* xaoGeometry,
|
void XAOPlugin_IOperations::importSubShapes( XAO::Geometry* xaoGeometry,
|
||||||
@ -440,7 +521,10 @@ void XAOPlugin_IOperations::importSubShapes( XAO::Geometry* xaoGeometry,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
subShape->SetName(name.c_str());
|
subShape->SetName(name.c_str());
|
||||||
subShape->SetType(shapeType);
|
|
||||||
|
// commented out, as it prevents correct operation information filling
|
||||||
|
// type should be a GEOM_SUBSHAPE
|
||||||
|
//subShape->SetType(shapeType);
|
||||||
|
|
||||||
GEOM_ISubShape aSSI(aFunction);
|
GEOM_ISubShape aSSI(aFunction);
|
||||||
aSSI.SetMainShape(function);
|
aSSI.SetMainShape(function);
|
||||||
@ -456,13 +540,13 @@ void XAOPlugin_IOperations::importSubShapes( XAO::Geometry* xaoGeometry,
|
|||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* Import a shape from XAO format
|
* Import a shape from XAO format file.
|
||||||
* \param fileName The name of the file to import
|
* \param fileName The name of the file to import.
|
||||||
* \param shape The imported shape
|
* \param shape The imported shape.
|
||||||
* \param subShapes The list of imported groups
|
* \param subShapes The list of imported sub-shapes.
|
||||||
* \param groups The list of imported groups
|
* \param groups The list of imported groups.
|
||||||
* \param fields The list of imported fields
|
* \param fields The list of imported fields.
|
||||||
* \return boolean indicating if import was succeful.
|
* \return boolean indicating if import was successful.
|
||||||
*/
|
*/
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
||||||
@ -470,17 +554,70 @@ bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
|||||||
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
Handle(TColStd_HSequenceOfTransient)& groups,
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
Handle(TColStd_HSequenceOfTransient)& fields )
|
Handle(TColStd_HSequenceOfTransient)& fields )
|
||||||
|
{
|
||||||
|
if (fileName == NULL || !strlen(fileName)) {
|
||||||
|
SetErrorCode("Empty file name");
|
||||||
|
}
|
||||||
|
|
||||||
|
importXAO( fileName, "", shape, subShapes, groups, fields );
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Import a shape from XAO format string.
|
||||||
|
* \param theXML The input buffer.
|
||||||
|
* \param shape The imported shape.
|
||||||
|
* \param subShapes The list of imported sub-shapes.
|
||||||
|
* \param groups The list of imported groups.
|
||||||
|
* \param fields The list of imported fields.
|
||||||
|
* \return boolean indicating if import was successful.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
bool XAOPlugin_IOperations::ImportXAOMem( const std::string& theXML,
|
||||||
|
Handle(GEOM_Object)& shape,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& fields )
|
||||||
|
{
|
||||||
|
importXAO( NULL, theXML, shape, subShapes, groups, fields );
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Import a shape from XAO format file.
|
||||||
|
* \param fileName The name of the file to import.
|
||||||
|
* \param shape The imported shape.
|
||||||
|
* \param subShapes The list of imported sub-shapes.
|
||||||
|
* \param groups The list of imported groups.
|
||||||
|
* \param fields The list of imported fields.
|
||||||
|
* \return boolean indicating if import was successful.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
bool XAOPlugin_IOperations::importXAO( const char* fileName,
|
||||||
|
const std::string& theXML,
|
||||||
|
Handle(GEOM_Object)& shape,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& fields )
|
||||||
{
|
{
|
||||||
SetErrorCode(KO);
|
SetErrorCode(KO);
|
||||||
|
|
||||||
if (fileName == NULL || groups.IsNull() || fields.IsNull())
|
if (groups.IsNull() || fields.IsNull())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
bool isFile = (fileName && strlen(fileName));
|
||||||
|
|
||||||
// Read the XAO
|
// Read the XAO
|
||||||
XAO::Xao* xaoObject = new XAO::Xao();
|
XAO::Xao* xaoObject = new XAO::Xao();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
xaoObject->importXAO(fileName);
|
if (isFile)
|
||||||
|
xaoObject->importXAO(fileName);
|
||||||
|
else {
|
||||||
|
xaoObject->setXML(theXML);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (XAO::XAO_Exception& exc)
|
catch (XAO::XAO_Exception& exc)
|
||||||
{
|
{
|
||||||
@ -503,7 +640,14 @@ bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
|||||||
if (function.IsNull()) return false;
|
if (function.IsNull()) return false;
|
||||||
if (function->GetDriverGUID() != XAOPlugin_Driver::GetID()) return false;
|
if (function->GetDriverGUID() != XAOPlugin_Driver::GetID()) return false;
|
||||||
|
|
||||||
function->SetString( XAOPlugin_Driver::GetFileNameTag(), fileName );
|
// Initialize python dimp here to prevent dumping of sub shapes, groups and fields
|
||||||
|
GEOM::TPythonDump pd(function);
|
||||||
|
|
||||||
|
if (isFile)
|
||||||
|
function->SetString( XAOPlugin_Driver::GetFileNameTag(), fileName );
|
||||||
|
else {
|
||||||
|
function->SetString( XAOPlugin_Driver::GetFileNameTag(), "NO, imported from byte array" );
|
||||||
|
}
|
||||||
|
|
||||||
// set the geometry
|
// set the geometry
|
||||||
if (xaoGeometry->getFormat() == XAO::BREP)
|
if (xaoGeometry->getFormat() == XAO::BREP)
|
||||||
@ -658,7 +802,6 @@ bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// make a Python command
|
// make a Python command
|
||||||
GEOM::TPythonDump pd(function);
|
|
||||||
pd << "(imported, " << shape << ", ";
|
pd << "(imported, " << shape << ", ";
|
||||||
|
|
||||||
// list of sub shapes
|
// list of sub shapes
|
||||||
@ -695,9 +838,21 @@ bool XAOPlugin_IOperations::ImportXAO( const char* fileName,
|
|||||||
pd << obj << ((i < nbFields) ? ", " : "");
|
pd << obj << ((i < nbFields) ? ", " : "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
std::string convFileName = Kernel_Utils::BackSlashToSlash( fileName );
|
pd << "]) = geompy.";
|
||||||
pd << "]";
|
|
||||||
pd << ") = geompy.ImportXAO(\"" << convFileName.c_str() << "\")";
|
if (isFile) {
|
||||||
|
std::string convFileName = Kernel_Utils::BackSlashToSlash( fileName );
|
||||||
|
pd << "ImportXAO(\"" << convFileName.c_str() << "\")";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!shape->GetName().IsEmpty()) {
|
||||||
|
std::string aGeometryNamePy (shape->GetName().ToCString());
|
||||||
|
std::replace(aGeometryNamePy.begin(), aGeometryNamePy.end(), ' ', '_');
|
||||||
|
pd << "ImportXAOMem(aXAOBuff_" << aGeometryNamePy.c_str() << ")";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
pd << "ImportXAOMem(aXAOBuff)";
|
||||||
|
}
|
||||||
|
|
||||||
delete xaoObject;
|
delete xaoObject;
|
||||||
SetErrorCode(OK);
|
SetErrorCode(OK);
|
||||||
|
@ -50,13 +50,36 @@ public:
|
|||||||
const char* fileName,
|
const char* fileName,
|
||||||
const char* shapeFileName );
|
const char* shapeFileName );
|
||||||
|
|
||||||
|
std::string ExportXAOMem( Handle(GEOM_Object) shape,
|
||||||
|
std::list<Handle(GEOM_Object)> groupList,
|
||||||
|
std::list<Handle(GEOM_Field)> fieldList,
|
||||||
|
const char* author );
|
||||||
|
|
||||||
bool ImportXAO( const char* fileName,
|
bool ImportXAO( const char* fileName,
|
||||||
Handle(GEOM_Object)& shape,
|
Handle(GEOM_Object)& shape,
|
||||||
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
Handle(TColStd_HSequenceOfTransient)& groups,
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
Handle(TColStd_HSequenceOfTransient)& fields );
|
Handle(TColStd_HSequenceOfTransient)& fields );
|
||||||
|
|
||||||
|
bool ImportXAOMem( const std::string& theXML,
|
||||||
|
Handle(GEOM_Object)& shape,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& fields );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
std::string exportXAO( Handle(GEOM_Object) shape,
|
||||||
|
std::list<Handle(GEOM_Object)> groupList,
|
||||||
|
std::list<Handle(GEOM_Field)> fieldList,
|
||||||
|
const char* author,
|
||||||
|
const char* fileName,
|
||||||
|
const char* shapeFileName );
|
||||||
|
bool importXAO( const char* fileName,
|
||||||
|
const std::string& theXML,
|
||||||
|
Handle(GEOM_Object)& shape,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& subShapes,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& groups,
|
||||||
|
Handle(TColStd_HSequenceOfTransient)& fields );
|
||||||
void importSubShapes( XAO::Geometry* xaoGeometry,
|
void importSubShapes( XAO::Geometry* xaoGeometry,
|
||||||
Handle(GEOM_Function) function,
|
Handle(GEOM_Function) function,
|
||||||
int shapeType,
|
int shapeType,
|
||||||
|
@ -49,14 +49,14 @@ XAOPlugin_IOperations_i::~XAOPlugin_IOperations_i()
|
|||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* Export a shape to XAO format
|
* Export a shape to XAO format file
|
||||||
* \param shape The shape to export
|
* \param shape The shape to export
|
||||||
* \param groups The list of groups to export
|
* \param groups The list of groups to export
|
||||||
* \param fields The list of fields to export
|
* \param fields The list of fields to export
|
||||||
* \param author The author of the export
|
* \param author The author of the export
|
||||||
* \param fileName The name of the exported file
|
* \param fileName The name of the exported file
|
||||||
* \param shapeFileName If not empty, save to shape to this external file
|
* \param shapeFileName If not empty, save the BREP shape to this external file
|
||||||
* \return boolean indicating if export was succeful.
|
* \return boolean indicating if export was successful.
|
||||||
*/
|
*/
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
||||||
@ -66,12 +66,63 @@ CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
|||||||
const char* fileName,
|
const char* fileName,
|
||||||
const char* shapeFileName)
|
const char* shapeFileName)
|
||||||
{
|
{
|
||||||
bool isGood = false;
|
exportXAO( shape, groups, fields, author, true, fileName, shapeFileName );
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Export a shape to XAO format buffer
|
||||||
|
* \param shape The shape to export
|
||||||
|
* \param groups The list of groups to export
|
||||||
|
* \param fields The list of fields to export
|
||||||
|
* \param author The author of the export
|
||||||
|
* \return The output buffer
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
SALOMEDS::TMPFile* XAOPlugin_IOperations_i::ExportXAOMem( GEOM::GEOM_Object_ptr shape,
|
||||||
|
const GEOM::ListOfGO& groups,
|
||||||
|
const GEOM::ListOfFields& fields,
|
||||||
|
const char* author )
|
||||||
|
{
|
||||||
|
std::string anXMLBuf = exportXAO( shape, groups, fields, author, false, "", "" );
|
||||||
|
|
||||||
|
int size = anXMLBuf.size();
|
||||||
|
CORBA::Octet* OctetBuf = SALOMEDS::TMPFile::allocbuf(size);
|
||||||
|
memcpy(OctetBuf, anXMLBuf.c_str(), size);
|
||||||
|
SALOMEDS::TMPFile_var SeqFile = new SALOMEDS::TMPFile (size,size,OctetBuf,1);
|
||||||
|
return SeqFile._retn();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Export a shape to XAO format
|
||||||
|
* \param shape The shape to export
|
||||||
|
* \param groups The list of groups to export
|
||||||
|
* \param fields The list of fields to export
|
||||||
|
* \param author The author of the export
|
||||||
|
* \param toFile Export to file if true, otherwise export to memory buffer (the returned string)
|
||||||
|
* \param fileName The name of the exported file
|
||||||
|
* \param shapeFileName If not empty, save the BREP shape to this external file
|
||||||
|
* \return string The exported buffer if toFile=false, otherwise an empty string
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
std::string XAOPlugin_IOperations_i::exportXAO( GEOM::GEOM_Object_ptr shape,
|
||||||
|
const GEOM::ListOfGO& groups,
|
||||||
|
const GEOM::ListOfFields& fields,
|
||||||
|
const char* author,
|
||||||
|
const bool toFile,
|
||||||
|
const char* fileName,
|
||||||
|
const char* shapeFileName)
|
||||||
|
{
|
||||||
|
std::string anXMLBuff;
|
||||||
// Set a not done flag
|
// Set a not done flag
|
||||||
GetOperations()->SetNotDone();
|
GetOperations()->SetNotDone();
|
||||||
|
|
||||||
// Get the reference shape
|
// Get the reference shape
|
||||||
Handle(GEOM_Object) reference = GetObjectImpl( shape );
|
Handle(GEOM_Object) reference = GetObjectImpl( shape );
|
||||||
|
if( reference.IsNull() )
|
||||||
|
return anXMLBuff;
|
||||||
|
|
||||||
// Get the reference groups
|
// Get the reference groups
|
||||||
CORBA::ULong ind = 0;
|
CORBA::ULong ind = 0;
|
||||||
@ -79,7 +130,7 @@ CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
|||||||
for (; ind < groups.length(); ind++)
|
for (; ind < groups.length(); ind++)
|
||||||
{
|
{
|
||||||
Handle(GEOM_Object) gobj = GetObjectImpl( groups[ind] );
|
Handle(GEOM_Object) gobj = GetObjectImpl( groups[ind] );
|
||||||
if (gobj.IsNull()) return false;
|
if (gobj.IsNull()) return anXMLBuff;
|
||||||
groupsObj.push_back(gobj);
|
groupsObj.push_back(gobj);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,17 +140,21 @@ CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
|||||||
for( ; ind < fields.length(); ind++ )
|
for( ; ind < fields.length(); ind++ )
|
||||||
{
|
{
|
||||||
Handle(GEOM_Field) fobj = Handle(GEOM_Field)::DownCast( GetBaseObjectImpl( fields[ind] ) );
|
Handle(GEOM_Field) fobj = Handle(GEOM_Field)::DownCast( GetBaseObjectImpl( fields[ind] ) );
|
||||||
if( fobj.IsNull() ) return false;
|
if( fobj.IsNull() ) return anXMLBuff;
|
||||||
fieldsObj.push_back(fobj);
|
fieldsObj.push_back(fobj);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !reference.IsNull() )
|
if ( toFile )
|
||||||
{
|
{
|
||||||
// Export XAO
|
// Export XAO
|
||||||
isGood = GetOperations()->ExportXAO( reference, groupsObj, fieldsObj, author, fileName, shapeFileName );
|
GetOperations()->ExportXAO( reference, groupsObj, fieldsObj, author, fileName, shapeFileName );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
anXMLBuff = GetOperations()->ExportXAOMem( reference, groupsObj, fieldsObj, author );
|
||||||
}
|
}
|
||||||
|
|
||||||
return isGood;
|
return anXMLBuff;
|
||||||
}
|
}
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
@ -110,7 +165,7 @@ CORBA::Boolean XAOPlugin_IOperations_i::ExportXAO( GEOM::GEOM_Object_ptr shape,
|
|||||||
* \param subShapes The list of imported subShapes
|
* \param subShapes The list of imported subShapes
|
||||||
* \param groups The list of imported groups
|
* \param groups The list of imported groups
|
||||||
* \param fields The list of imported fields
|
* \param fields The list of imported fields
|
||||||
* \return boolean indicating if import was succeful.
|
* \return boolean indicating if import was successful.
|
||||||
*/
|
*/
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
CORBA::Boolean XAOPlugin_IOperations_i::ImportXAO( const char* fileName,
|
CORBA::Boolean XAOPlugin_IOperations_i::ImportXAO( const char* fileName,
|
||||||
@ -118,6 +173,53 @@ CORBA::Boolean XAOPlugin_IOperations_i::ImportXAO( const char* fileName,
|
|||||||
GEOM::ListOfGO_out subShapes,
|
GEOM::ListOfGO_out subShapes,
|
||||||
GEOM::ListOfGO_out groups,
|
GEOM::ListOfGO_out groups,
|
||||||
GEOM::ListOfFields_out fields)
|
GEOM::ListOfFields_out fields)
|
||||||
|
{
|
||||||
|
SALOMEDS::TMPFile_var aBuff;
|
||||||
|
importXAO( true, fileName, aBuff, shape, subShapes, groups, fields);
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Import a shape from XAO format memory buffer
|
||||||
|
* \param fileName The name of the file to import
|
||||||
|
* \param shape The imported shape
|
||||||
|
* \param subShapes The list of imported subShapes
|
||||||
|
* \param groups The list of imported groups
|
||||||
|
* \param fields The list of imported fields
|
||||||
|
* \return boolean indicating if import was successful.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
CORBA::Boolean XAOPlugin_IOperations_i::ImportXAOMem( const SALOMEDS::TMPFile& theBuff,
|
||||||
|
GEOM::GEOM_Object_out shape,
|
||||||
|
GEOM::ListOfGO_out subShapes,
|
||||||
|
GEOM::ListOfGO_out groups,
|
||||||
|
GEOM::ListOfFields_out fields)
|
||||||
|
{
|
||||||
|
importXAO( false, NULL, theBuff, shape, subShapes, groups, fields);
|
||||||
|
return IsDone();
|
||||||
|
}
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
/*!
|
||||||
|
* Import a shape from XAO format
|
||||||
|
* \param isFile Boolean flag to switch between import from file or from buffer
|
||||||
|
* \param fileName The name of the file to import from if isFile=true
|
||||||
|
* \param theBuff The buffer to import from if isFile=false
|
||||||
|
* \param shape The imported shape
|
||||||
|
* \param subShapes The list of imported subShapes
|
||||||
|
* \param groups The list of imported groups
|
||||||
|
* \param fields The list of imported fields
|
||||||
|
* \return boolean indicating if import was successful.
|
||||||
|
*/
|
||||||
|
//=============================================================================
|
||||||
|
CORBA::Boolean XAOPlugin_IOperations_i::importXAO( const bool isFile,
|
||||||
|
const char* fileName,
|
||||||
|
const SALOMEDS::TMPFile& theBuff,
|
||||||
|
GEOM::GEOM_Object_out shape,
|
||||||
|
GEOM::ListOfGO_out subShapes,
|
||||||
|
GEOM::ListOfGO_out groups,
|
||||||
|
GEOM::ListOfFields_out fields)
|
||||||
{
|
{
|
||||||
GEOM::GEOM_Object_var vshape;
|
GEOM::GEOM_Object_var vshape;
|
||||||
shape = vshape._retn();
|
shape = vshape._retn();
|
||||||
@ -133,9 +235,21 @@ CORBA::Boolean XAOPlugin_IOperations_i::ImportXAO( const char* fileName,
|
|||||||
Handle(TColStd_HSequenceOfTransient) importedGroups = new TColStd_HSequenceOfTransient();
|
Handle(TColStd_HSequenceOfTransient) importedGroups = new TColStd_HSequenceOfTransient();
|
||||||
Handle(TColStd_HSequenceOfTransient) importedFields = new TColStd_HSequenceOfTransient();
|
Handle(TColStd_HSequenceOfTransient) importedFields = new TColStd_HSequenceOfTransient();
|
||||||
Handle(GEOM_Object) hshape;
|
Handle(GEOM_Object) hshape;
|
||||||
bool res = GetOperations()->ImportXAO( fileName, hshape, importedSubShapes, importedGroups, importedFields );
|
|
||||||
|
|
||||||
if( !GetOperations()->IsDone() || !res )
|
if (isFile) {
|
||||||
|
GetOperations()->ImportXAO( fileName, hshape, importedSubShapes, importedGroups, importedFields );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (theBuff.length() < 1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
char* buf = (char*)theBuff.NP_data();
|
||||||
|
//std::string anXMLBuff (buf); // works wrongly
|
||||||
|
std::string anXMLBuff (buf, theBuff.length());
|
||||||
|
GetOperations()->ImportXAOMem( anXMLBuff, hshape, importedSubShapes, importedGroups, importedFields );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !GetOperations()->IsDone() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// parse fields
|
// parse fields
|
||||||
@ -165,7 +279,7 @@ CORBA::Boolean XAOPlugin_IOperations_i::ImportXAO( const char* fileName,
|
|||||||
|
|
||||||
shape = GetObject( hshape );
|
shape = GetObject( hshape );
|
||||||
|
|
||||||
return res;
|
return IsDone();
|
||||||
}
|
}
|
||||||
|
|
||||||
XAOPlugin_IOperations* XAOPlugin_IOperations_i::GetOperations()
|
XAOPlugin_IOperations* XAOPlugin_IOperations_i::GetOperations()
|
||||||
|
@ -50,13 +50,41 @@ public:
|
|||||||
const char* fileName,
|
const char* fileName,
|
||||||
const char* shapeFileName );
|
const char* shapeFileName );
|
||||||
|
|
||||||
|
SALOMEDS::TMPFile* ExportXAOMem( GEOM::GEOM_Object_ptr shape,
|
||||||
|
const GEOM::ListOfGO& groups,
|
||||||
|
const GEOM::ListOfFields& fields,
|
||||||
|
const char* author );
|
||||||
|
|
||||||
CORBA::Boolean ImportXAO( const char* fileName,
|
CORBA::Boolean ImportXAO( const char* fileName,
|
||||||
GEOM::GEOM_Object_out shape,
|
GEOM::GEOM_Object_out shape,
|
||||||
GEOM::ListOfGO_out subShapes,
|
GEOM::ListOfGO_out subShapes,
|
||||||
GEOM::ListOfGO_out groups,
|
GEOM::ListOfGO_out groups,
|
||||||
GEOM::ListOfFields_out fields );
|
GEOM::ListOfFields_out fields );
|
||||||
|
|
||||||
|
CORBA::Boolean ImportXAOMem( const SALOMEDS::TMPFile& theBuff,
|
||||||
|
GEOM::GEOM_Object_out shape,
|
||||||
|
GEOM::ListOfGO_out subShapes,
|
||||||
|
GEOM::ListOfGO_out groups,
|
||||||
|
GEOM::ListOfFields_out fields );
|
||||||
|
|
||||||
XAOPlugin_IOperations* GetOperations();
|
XAOPlugin_IOperations* GetOperations();
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string exportXAO( GEOM::GEOM_Object_ptr shape,
|
||||||
|
const GEOM::ListOfGO& groups,
|
||||||
|
const GEOM::ListOfFields& fields,
|
||||||
|
const char* author,
|
||||||
|
const bool toFile,
|
||||||
|
const char* fileName,
|
||||||
|
const char* shapeFileName );
|
||||||
|
|
||||||
|
CORBA::Boolean importXAO( const bool isFile,
|
||||||
|
const char* fileName,
|
||||||
|
const SALOMEDS::TMPFile& theBuff,
|
||||||
|
GEOM::GEOM_Object_out shape,
|
||||||
|
GEOM::ListOfGO_out subShapes,
|
||||||
|
GEOM::ListOfGO_out groups,
|
||||||
|
GEOM::ListOfFields_out fields );
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user