From 1e39be325369d1d29354a2104411f4f8547e4aeb Mon Sep 17 00:00:00 2001 From: Even Rouault Date: Wed, 22 Mar 2023 13:52:03 +0100 Subject: [PATCH] Coord. operation factory: count identified concatenated operations as a single step --- .../operation/coordinateoperationfactory.cpp | 7 ++++++- test/unit/test_operationfactory.cpp | 20 ++++++++++++++++++- 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/src/iso19111/operation/coordinateoperationfactory.cpp b/src/iso19111/operation/coordinateoperationfactory.cpp index d8a72bfb97..40e3d003c6 100644 --- a/src/iso19111/operation/coordinateoperationfactory.cpp +++ b/src/iso19111/operation/coordinateoperationfactory.cpp @@ -1478,7 +1478,12 @@ struct FilterResults { const auto curAccuracy = getAccuracy(op); bool dummy = false; const auto curExtent = getExtent(op, true, dummy); - const auto curStepCount = getTransformationStepCount(op); + // If a concatenated operation has an identifier, consider it as + // a single step (to be opposed to synthetized concatenated + // operations). Helps for example to get EPSG:8537, + // "Egypt 1907 to WGS 84 (2)" + const auto curStepCount = + op->identifiers().empty() ? getTransformationStepCount(op) : 1; if (first) { resTemp.emplace_back(op); diff --git a/test/unit/test_operationfactory.cpp b/test/unit/test_operationfactory.cpp index d3be21e6dd..93a5a98f82 100644 --- a/test/unit/test_operationfactory.cpp +++ b/test/unit/test_operationfactory.cpp @@ -1059,7 +1059,7 @@ TEST(operation, geogCRS_to_geogCRS_context_concatenated_operation) { authFactory->createCoordinateReferenceSystem("4807"), // NTF(Paris) authFactory->createCoordinateReferenceSystem("4171"), // RGF93 ctxt); - ASSERT_EQ(list.size(), 4U); + ASSERT_EQ(list.size(), 2U); EXPECT_EQ(list[0]->nameStr(), "NTF (Paris) to RGF93 v1 (1)"); EXPECT_EQ(list[0]->exportToPROJString(PROJStringFormatter::create().get()), @@ -1092,6 +1092,24 @@ TEST(operation, geogCRS_to_geogCRS_context_concatenated_operation) { // --------------------------------------------------------------------------- +TEST(operation, + geogCRS_to_geogCRS_context_concatenated_operation_Egypt1907_to_WGS84) { + auto authFactory = + AuthorityFactory::create(DatabaseContext::create(), "EPSG"); + auto ctxt = CoordinateOperationContext::create(authFactory, nullptr, 0.0); + auto list = CoordinateOperationFactory::create()->createOperations( + authFactory->createCoordinateReferenceSystem("4229"), // Egypt 1907 + authFactory->createCoordinateReferenceSystem("4326"), // WGS84 + ctxt); + ASSERT_EQ(list.size(), 3U); + // Concatenated operation + EXPECT_EQ(list[1]->nameStr(), "Egypt 1907 to WGS 84 (2)"); + ASSERT_EQ(list[1]->coordinateOperationAccuracies().size(), 1U); + EXPECT_EQ(list[1]->coordinateOperationAccuracies()[0]->value(), "6.0"); +} + +// --------------------------------------------------------------------------- + TEST(operation, geogCRS_to_geogCRS_context_ED50_to_WGS72_no_NTF_intermediate) { auto authFactory = AuthorityFactory::create(DatabaseContext::create(), "EPSG");