From 138555c2491a70428d3c8c82fdf9bb778ad0ae62 Mon Sep 17 00:00:00 2001 From: Even Rouault Date: Wed, 26 Aug 2020 00:18:36 +0200 Subject: proj_create_vertical_crs_ex(): add a ACCURACY option to provide an explicit accuracy, or derive it from the grid name if it is known --- src/iso19111/factory.cpp | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'src/iso19111/factory.cpp') diff --git a/src/iso19111/factory.cpp b/src/iso19111/factory.cpp index a9d82268..a011f397 100644 --- a/src/iso19111/factory.cpp +++ b/src/iso19111/factory.cpp @@ -1256,6 +1256,25 @@ DatabaseContext::getNonDeprecated(const std::string &tableName, return res; } +// --------------------------------------------------------------------------- + +std::vector +DatabaseContext::getTransformationsForGridName( + const DatabaseContextNNPtr &databaseContext, const std::string &gridName) { + auto sqlRes = databaseContext->d->run( + "SELECT auth_name, code FROM grid_transformation " + "WHERE grid_name = ? OR grid_name = " + "(SELECT original_grid_name FROM grid_alternatives " + "WHERE proj_grid_name = ?)", + {gridName, gridName}); + std::vector res; + for (const auto &row : sqlRes) { + res.emplace_back(AuthorityFactory::create(databaseContext, row[0]) + ->createCoordinateOperation(row[1], true)); + } + return res; +} + //! @endcond // --------------------------------------------------------------------------- -- cgit v1.2.3