Line data Source code
1 : /****************************************************************************** 2 : * 3 : * Project: OpenGIS Simple Features Reference Implementation 4 : * Purpose: Implements Open FileGDB OGR driver. 5 : * Author: Even Rouault, <even dot rouault at spatialys.com> 6 : * 7 : ****************************************************************************** 8 : * Copyright (c) 2024, Even Rouault <even dot rouault at spatialys.com> 9 : * 10 : * SPDX-License-Identifier: MIT 11 : ****************************************************************************/ 12 : 13 : #ifndef FILEGDB_COORDPREC_READ_H 14 : #define FILEGDB_COORDPREC_READ_H 15 : 16 : #include "cpl_minixml.h" 17 : 18 : #include "ogr_geomcoordinateprecision.h" 19 : 20 : /*************************************************************************/ 21 : /* GDBGridSettingsToOGR() */ 22 : /*************************************************************************/ 23 : 24 : /** Fill OGRGeomCoordinatePrecision from XML "psSpatialReference" node. 25 : */ 26 : static OGRGeomCoordinatePrecision 27 3143 : GDBGridSettingsToOGR(const CPLXMLNode *psSpatialReference) 28 : { 29 3143 : OGRGeomCoordinatePrecision oCoordPrec; 30 : const char *pszXYScale = 31 3143 : CPLGetXMLValue(psSpatialReference, "XYScale", nullptr); 32 3143 : if (pszXYScale && CPLAtof(pszXYScale) > 0) 33 : { 34 3143 : oCoordPrec.dfXYResolution = 1.0 / CPLAtof(pszXYScale); 35 : } 36 : const char *pszZScale = 37 3143 : CPLGetXMLValue(psSpatialReference, "ZScale", nullptr); 38 3143 : if (pszZScale && CPLAtof(pszZScale) > 0) 39 : { 40 3141 : oCoordPrec.dfZResolution = 1.0 / CPLAtof(pszZScale); 41 : } 42 : const char *pszMScale = 43 3143 : CPLGetXMLValue(psSpatialReference, "MScale", nullptr); 44 3143 : if (pszMScale && CPLAtof(pszMScale) > 0) 45 : { 46 658 : oCoordPrec.dfMResolution = 1.0 / CPLAtof(pszMScale); 47 : } 48 : 49 6286 : CPLStringList aosSpecificOptions; 50 39024 : for (const CPLXMLNode *psChild = psSpatialReference->psChild; psChild; 51 35881 : psChild = psChild->psNext) 52 : { 53 35881 : if (psChild->eType == CXT_Element && 54 : // The 3 below values are only generated by the FileGDB SDK 55 32738 : !EQUAL(psChild->pszValue, "WKID") && 56 29999 : !EQUAL(psChild->pszValue, "LatestWKID") && 57 29887 : !EQUAL(psChild->pszValue, "WKT")) 58 : { 59 27164 : const char *pszValue = CPLGetXMLValue(psChild, "", ""); 60 27164 : if (CPLGetValueType(pszValue) == CPL_VALUE_REAL) 61 7048 : pszValue = CPLSPrintf("%.15g", CPLAtof(pszValue)); 62 27164 : aosSpecificOptions.SetNameValue(psChild->pszValue, pszValue); 63 : } 64 : } 65 6286 : oCoordPrec.oFormatSpecificOptions["FileGeodatabase"] = 66 6286 : std::move(aosSpecificOptions); 67 6286 : return oCoordPrec; 68 : } 69 : 70 : #endif /* FILEGDB_COORDPREC_READ_H */