/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2025, Open Design Alliance (the "Alliance"). // All rights reserved. // // This software and its documentation and related materials are owned by // the Alliance. The software may only be incorporated into application // programs owned by members of the Alliance, subject to a signed // Membership Agreement and Supplemental Software License Agreement with the // Alliance. The structure and organization of this software are the valuable // trade secrets of the Alliance and its suppliers. The software is also // protected by copyright law and international treaty provisions. Application // programs incorporating this software must include the following statement // with their copyright notices: // // This application incorporates Open Design Alliance software pursuant to a license // agreement with Open Design Alliance. // Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance. // All rights reserved. // // By use of this software, its documentation or related materials, you // acknowledge and accept the above terms. /////////////////////////////////////////////////////////////////////////////// #include "OdaCommon.h" #include #include "ExIgesTutorial_01.h" Tutorial_01::Tutorial_01(const OdString& applicationName) : BaseIgesTutorial(applicationName) { m_tutorialArgsParser. add_param( std::make_shared>(m_igesFileName, "filename", "input .iges or .igs file to read")); m_tutorialArgsParser .add_param( std::make_shared(m_noWait, "-NoWait", "disable \"press any key\" on finish.")); } void printTab(int tab) { for (int i = 0; i < tab; ++i) { odPrintConsoleString(OD_T(" ")); } } int Tutorial_01::run(MyServices &svcs, const std::vector& argv, std::ostream& resultStream) { auto parseResult = BaseIgesTutorial::run(svcs, argv, resultStream); if (parseResult != 0) { return parseResult; } IgesFilePtr igesFile = svcs.readFile(m_igesFileName); OdDAI::ModelPtr model = igesFile->getModel(); OdDAI::InstanceIteratorPtr instIterator = model->newIterator(); for (; !instIterator->done(); instIterator->step()) { OdDAI::ApplicationInstancePtr inst = instIterator->id().openObject(); printf("%s", OdDAI::Utils::getStepLine(inst).c_str()); printf("\r\n"); } return (int)eOk; }