/////////////////////////////////////////////////////////////////////////////// // 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 "OdGeoDataModule.h" #include "DbBaseDatabase.h" #include "OdGeoDataPEImpl.h" #include "OdDbGeoCoordinateSystemPEImpl.h" #include "StaticRxObject.h" #include "RxDynamicModule.h" #include "OdDbGeoCoordinateSystemImpl.h" #define CMD_DEF_CLASS(CmdName, GroupName) \ extern void _##CmdName##_func(OdEdCommandContext* pCmdCtx);\ const OdString _##CmdName##_cmd::globalName() const { return OD_T(#CmdName); }\ const OdString _##CmdName##_cmd::groupName() const { return GroupName; } #define CMD_DEF(CmdName, GroupName) \ extern void _##CmdName##_func(OdEdCommandContext* pCmdCtx);\ const OdString _##CmdName##_cmd::globalName() const { return OD_T(#CmdName); }\ const OdString _##CmdName##_cmd::groupName() const { return GroupName; }\ void _##CmdName##_cmd::execute(OdEdCommandContext* pCmdCtx) { _##CmdName##_func(pCmdCtx); } #include "OdGeoDataCmdDef.h" #undef CMD_DEF_CLASS #undef CMD_DEF ODRX_DEFINE_DYNAMIC_MODULE(OdGeoDataModule); OdStaticRxObject g_pGeoDataPE; OdStaticRxObject g_pGeoDataExportPE; OdStaticRxObject g_pGeoCoordinateSystemCategoryPE; OdStaticRxObject g_pGeoCoordinateSystemPE; OdStaticRxObject g_pGeoVerticalCoordinateSystemPE; OdStaticRxObject g_pGeoCompoundCoordinateSystemPE; OdStaticRxObject g_pGeoCoordinateSystemTransformerPE; void OdGeoDataModule::initApp() { m_pOdSpatialReferenceModule = odrxDynamicLinker()->loadModule(OdSpatialReferenceModuleName, false); OdDbGeoCoordinateSystemCategoryImpl::rxInit(); OdDbGeoCoordinateSystemImpl::rxInit(); OdDbGeoVerticalCoordinateSystemImpl::rxInit(); OdDbGeoCompoundCoordinateSystemImpl::rxInit(); OdDbGeoCoordinateSystemTransformerImpl::rxInit(); OdDbGeoDataPEImpl::rxInit(); OdDbGeoDataExportPEImpl::rxInit(); OdDbGeoData::desc()->addX(OdDbGeoDataPE::desc(), &g_pGeoDataPE); OdDbDatabase::desc()->addX(OdDbBaseGeoDataExportPE::desc(), &g_pGeoDataExportPE); OdDbGeoCoordinateSystemCategoryPEImpl::rxInit(); OdDbGeoCoordinateSystemCategory::desc()->addX(OdDbGeoCoordinateSystemCategoryPE::desc(), &g_pGeoCoordinateSystemCategoryPE); OdDbGeoCoordinateSystemPEImpl::rxInit(); OdDbGeoCoordinateSystem::desc()->addX(OdDbGeoCoordinateSystemPE::desc(), &g_pGeoCoordinateSystemPE); OdDbGeoVerticalCoordinateSystemPEImpl::rxInit(); OdDbGeoVerticalCoordinateSystem::desc()->addX(OdDbGeoVerticalCoordinateSystemPE::desc(), &g_pGeoVerticalCoordinateSystemPE); OdDbGeoCompoundCoordinateSystemPEImpl::rxInit(); OdDbGeoCompoundCoordinateSystem::desc()->addX(OdDbGeoCompoundCoordinateSystemPE::desc(), &g_pGeoCompoundCoordinateSystemPE); OdDbGeoCoordinateSystemTransformerPEImpl::rxInit(); OdDbGeoCoordinateSystemTransformer::desc()->addX(OdDbGeoCoordinateSystemTransformerPE::desc(), &g_pGeoCoordinateSystemTransformerPE); OdEdCommandStackPtr pCommands = odedRegCmds(); #define CMD_DEF(CmdName, GroupName) \ pCommands->addCommand(&m_##CmdName##_cmd); #include "OdGeoDataCmdDef.h" #undef CMD_DEF } void OdGeoDataModule::uninitApp() { OdEdCommandStackPtr pCommands = odedRegCmds(); #define CMD_DEF(CmdName, GroupName) \ pCommands->removeCmd(GroupName, OD_T(#CmdName)); #include "OdGeoDataCmdDef.h" #undef CMD_DEF OdDbGeoCoordinateSystemTransformer::desc()->delX(OdDbGeoCoordinateSystemTransformerPE::desc()); OdDbGeoCoordinateSystemTransformerPEImpl::rxUninit(); OdDbGeoCompoundCoordinateSystem::desc()->delX(OdDbGeoCompoundCoordinateSystemPE::desc()); OdDbGeoCompoundCoordinateSystemPEImpl::rxUninit(); OdDbGeoVerticalCoordinateSystem::desc()->delX(OdDbGeoVerticalCoordinateSystemPE::desc()); OdDbGeoVerticalCoordinateSystemPEImpl::rxUninit(); OdDbGeoCoordinateSystem::desc()->delX(OdDbGeoCoordinateSystemPE::desc()); OdDbGeoCoordinateSystemPEImpl::rxUninit(); OdDbGeoCoordinateSystemCategory::desc()->delX(OdDbGeoCoordinateSystemCategoryPE::desc()); OdDbGeoCoordinateSystemCategoryPEImpl::rxUninit(); OdDbGeoData::desc()->delX(OdDbGeoDataPE::desc()); OdDbDatabase::desc()->delX(OdDbBaseGeoDataExportPE::desc()); OdDbGeoDataExportPEImpl::rxUninit(); OdDbGeoDataPEImpl::rxUninit(); OdDbGeoCoordinateSystemTransformerImpl::rxUninit(); OdDbGeoCompoundCoordinateSystemImpl::rxUninit(); OdDbGeoVerticalCoordinateSystemImpl::rxUninit(); OdDbGeoCoordinateSystemImpl::rxUninit(); OdDbGeoCoordinateSystemCategoryImpl::rxUninit(); }