///////////////////////////////////////////////////////////////////////////////
// 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.
///////////////////////////////////////////////////////////////////////////////
#ifndef _CIS2_FILE_H
#define _CIS2_FILE_H
#include "StepCore.h"
#include "StepBuildOptions.h"
#include "daiStepFile.h"
#include "StepGeomModule.h"
#include "StepEntityResolver.h"
/** \details
This class represents a CIS/2 file.
*/
class STEPCORE_EXPORT OdCis2File : public OdStepFile
{
public:
//DOM-IGNORE-BEGIN
ODRX_DECLARE_MEMBERS(OdCis2File);
//DOM-IGNORE-END
/** \details
Default constructor for the OdCis2File class.
*/
OdCis2File();
/** \details
Destructor for the OdCis2File class.
*/
~OdCis2File();
virtual OdDAI::OdCompoundPtr getCompound(const OdDAIObjectId& id) override;
/** \details
Retrieves the current model context of the file object.
\returns An instance of the OdStepModelContext class to be set as the model context object.
*/
void setContext(const OdStepModelContext& context);
/** \details
Sets geometrical context selection to build a geometrical representation for selected geometrical contexts.
Only selected contexts will be composed and drawn.
\param contexts [in] A set of OdUnitConverter class that represents the current model's unit converter.
*/
OdDAI::OdUnitConverterPtr getUnitConverter() override;
/** \details
Sets convertible unit from current class.
\returns eOk if initialization operation was successful; otherwise the method returns an appropriate error code.
*/
OdResult initializeUnitConverter() override;
/** \details
Retrieves the model's root instances.
\returns The identifiers of the root instances of the model.
*/
const OdDAIObjectIds getRootIds() override;
protected:
/** \details
Method is called just after file reading has ended.
\returns eOk if operation successfully done; otherwise, the method returns an appropriate error code.
*/
virtual OdResult onReadFileEnd() override;
private:
OdResult setGeomResource();
std::map m_openCompounds;
OdDAIObjectIds m_selContexts;
OdStep::OdStepGeomModulePtr m_pGeom;
OdStepEntResolver* m_pEntResolver = nullptr;
OdDAI::OdUnitConverterPtr m_pConverter;
};
/** \details
A data type that represents a smart pointer to an