mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-16 17:40:35 +05:00
Group management
This commit is contained in:
parent
146fbd48fb
commit
6c4637452d
@ -51,7 +51,7 @@ LIB_SRC = \
|
||||
DriverUNV_W_SMESHDS_Document.cxx \
|
||||
DriverUNV_W_SMDS_Mesh.cxx \
|
||||
DriverUNV_W_SMESHDS_Mesh.cxx \
|
||||
UNV_Utilities.cxx UNV2411_Structure.cxx UNV2412_Structure.cxx
|
||||
UNV_Utilities.cxx UNV2411_Structure.cxx UNV2412_Structure.cxx UNV2417_Structure.cxx
|
||||
|
||||
# Executables targets
|
||||
BIN = UNV_Test
|
||||
|
68
src/DriverUNV/UNV2417_Structure.cxx
Normal file
68
src/DriverUNV/UNV2417_Structure.cxx
Normal file
@ -0,0 +1,68 @@
|
||||
#include "UNV2417_Structure.hxx"
|
||||
#include "UNV_Utilities.hxx"
|
||||
|
||||
using namespace std;
|
||||
using namespace UNV;
|
||||
using namespace UNV2417;
|
||||
|
||||
#ifdef _DEBUG_
|
||||
static int MYDEBUG = 1;
|
||||
#else
|
||||
static int MYDEBUG = 0;
|
||||
#endif
|
||||
|
||||
static string _label_dataset = "2417";
|
||||
|
||||
void UNV2417::Read(std::ifstream& in_stream, TDataSet& theDataSet)
|
||||
{
|
||||
if(!in_stream.good())
|
||||
EXCEPTION(runtime_error,"ERROR: Input file not good.");
|
||||
|
||||
/*
|
||||
* adjust the \p istream to our
|
||||
* position
|
||||
*/
|
||||
if(!beginning_of_dataset(in_stream,_label_dataset))
|
||||
EXCEPTION(runtime_error,"WARNING: Could not find "<<_label_dataset<<" dataset!");
|
||||
|
||||
TGroupId aId;
|
||||
for(; !in_stream.eof();){
|
||||
in_stream >> aId ;
|
||||
if(aId == -1){
|
||||
// end of dataset is reached
|
||||
break;
|
||||
}
|
||||
|
||||
int n_nodes;
|
||||
TRecord aRec;
|
||||
int aTmp;
|
||||
in_stream>>aTmp; // miss not necessary values
|
||||
in_stream>>aTmp;
|
||||
in_stream>>aTmp;
|
||||
in_stream>>aTmp;
|
||||
in_stream>>aTmp;
|
||||
in_stream>>n_nodes;
|
||||
|
||||
int aElType;
|
||||
int aElId;
|
||||
int aNum;
|
||||
for(int j=0; j < n_nodes; j++){
|
||||
in_stream>>aElType;
|
||||
in_stream>>aElId;
|
||||
switch (aElType) {
|
||||
case 7: // Nodes
|
||||
aNum = aRec.NodeList.size();
|
||||
aRec.NodeList.resize(aNum + 1);
|
||||
aRec.NodeList[aNum] = aElId;
|
||||
break;
|
||||
case 8: // Elements
|
||||
aNum = aRec.ElementList.size();
|
||||
aRec.ElementList.resize(aNum + 1);
|
||||
aRec.ElementList[aNum] = aElId;
|
||||
break;
|
||||
}
|
||||
}
|
||||
theDataSet.insert(TDataSet::value_type(aId,aRec));
|
||||
}
|
||||
|
||||
}
|
44
src/DriverUNV/UNV2417_Structure.hxx
Normal file
44
src/DriverUNV/UNV2417_Structure.hxx
Normal file
@ -0,0 +1,44 @@
|
||||
// Copyright (C) 2003 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.
|
||||
//
|
||||
// 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
|
||||
|
||||
#ifndef UNV2417_Structure_HeaderFile
|
||||
#define UNV2417_Structure_HeaderFile
|
||||
|
||||
#include <map>
|
||||
#include <vector>
|
||||
#include <fstream>
|
||||
|
||||
|
||||
namespace UNV2417{
|
||||
|
||||
typedef std::vector<int> TListOfId; // Nodal connectivitiesList of Id
|
||||
|
||||
struct TRecord{
|
||||
TListOfId NodeList;
|
||||
TListOfId ElementList;
|
||||
};
|
||||
|
||||
typedef int TGroupId; // type of element label
|
||||
typedef std::map<TGroupId, TRecord> TDataSet;
|
||||
|
||||
void Read(std::ifstream& in_stream, TDataSet& theDataSet);
|
||||
};
|
||||
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user