FreeCAD / src /Mod /Import /App /StepShape.cpp
AbdulElahGwaith's picture
Upload folder using huggingface_hub
985c397 verified
// SPDX-License-Identifier: LGPL-2.1-or-later
/***************************************************************************
* Copyright (c) 2014 Jürgen Riegel <juergen.riegel@web.de> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* 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 Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#include <sstream>
#include <Base/Exception.h>
#include <Base/FileInfo.h>
#include <Interface_Static.hxx>
#include <Message_Messenger.hxx>
#include <Message_PrinterOStream.hxx>
#include <STEPControl_Reader.hxx>
#include <Standard_Version.hxx>
#include <StepData_StepModel.hxx>
#include "StepShape.h"
using namespace Import;
StepShape::StepShape() = default;
StepShape::~StepShape() = default;
int StepShape::read(const char* fileName)
{
STEPControl_Reader aReader;
Base::FileInfo fi(fileName);
if (!fi.exists()) {
std::stringstream str;
str << "File '" << fileName << "' does not exist!";
throw Base::FileException(str.str().c_str());
}
if (aReader.ReadFile((Standard_CString)fileName) != IFSelect_RetDone) {
throw Base::FileException("Cannot open STEP file");
}
Handle(TColStd_HSequenceOfTransient) list = aReader.GiveList();
// Use method StepData_StepModel::NextNumberForLabel to find its rank with the following:
// Standard_CString label = "#...";
Handle(StepData_StepModel) model = aReader.StepModel();
std::cout << "dump of step header:" << std::endl;
model->DumpHeader(std::cout);
for (int nent = 1; nent <= model->NbEntities(); nent++) {
Handle(Standard_Transient) entity = model->Entity(nent);
std::cout << "label entity " << nent << ":";
model->PrintLabel(entity, std::cout);
std::cout << ";" << entity->DynamicType()->Name() << std::endl;
}
return 0;
}