Salome HOME
Prevent recording nodes as elements
authoreap <eap@opencascade.com>
Wed, 14 Mar 2012 12:32:53 +0000 (12:32 +0000)
committereap <eap@opencascade.com>
Wed, 14 Mar 2012 12:32:53 +0000 (12:32 +0000)
src/SMESHDS/SMESHDS_SubMesh.cxx

index e73301dd953c92d3aeb31120e679cd7998e495e5..9bbbf51d2716b99bf010e7f2d574afa487206ee1 100644 (file)
@@ -71,6 +71,11 @@ void SMESHDS_SubMesh::AddElement(const SMDS_MeshElement * ME)
 {
   if (!IsComplexSubmesh())
     {
+      if ( ME->GetType() == SMDSAbs_Node )
+      {
+        AddNode( static_cast< const SMDS_MeshNode* >( ME ));
+        return;
+      }
       //MESSAGE("in " << myIndex << " AddElement "<< ME->GetID());
       int oldShapeId = ME->getshapeId();
       if ( oldShapeId > 0 )
@@ -160,7 +165,7 @@ void SMESHDS_SubMesh::AddNode(const SMDS_MeshNode * N)
         {
 //           MESSAGE("========== AddNode already belonging to other subShape " << N->GetID());
           // OK for vertex nodes
-          //this->getParent()->UnSetNodeOnShape(N);
+          throw SALOME_Exception(LOCALIZED("add node in subshape already belonging to a subshape"));
         }
       SMDS_MeshNode* node = (SMDS_MeshNode*)(N);
       node->setShapeId(myIndex);