aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2020-03-27 17:23:10 +0100
committerEven Rouault <even.rouault@spatialys.com>2020-03-27 22:36:08 +0100
commit238f48fb7cd006296cbd622ab9e4187139af9a8e (patch)
tree08487933c418ca9221293333ce6b9a57c4ac6e5a /src
parentec206a4d507d36a082070b53d462753f68711806 (diff)
downloadPROJ-238f48fb7cd006296cbd622ab9e4187139af9a8e.tar.gz
PROJ-238f48fb7cd006296cbd622ab9e4187139af9a8e.zip
Fix identification of projected CRS whose name is close but not strictly equal to a ESRI alias (fixes #2099)
Diffstat (limited to 'src')
-rw-r--r--src/iso19111/crs.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/src/iso19111/crs.cpp b/src/iso19111/crs.cpp
index cff93508..b0f5bcf9 100644
--- a/src/iso19111/crs.cpp
+++ b/src/iso19111/crs.cpp
@@ -3741,7 +3741,8 @@ ProjectedCRS::identify(const io::AuthorityFactoryPtr &authorityFactory) const {
return res;
}
res.emplace_back(crsNN, eqName ? 90 : 70);
- } else if (eqName && CRS::getPrivate()->implicitCS_ &&
+ } else if (objects.size() == 1 &&
+ CRS::getPrivate()->implicitCS_ &&
coordinateSystem()
->axisList()[0]
->unit()
@@ -3759,11 +3760,11 @@ ProjectedCRS::identify(const io::AuthorityFactoryPtr &authorityFactory) const {
derivingConversionRef()->_isEquivalentTo(
crs->derivingConversionRef().get(),
util::IComparable::Criterion::EQUIVALENT,
- dbContext) &&
- objects.size() == 1) {
+ dbContext)) {
res.clear();
- res.emplace_back(crsNN,
- crs->nameStr() == thisName ? 100 : 90);
+ res.emplace_back(crsNN, crs->nameStr() == thisName
+ ? 100
+ : eqName ? 90 : 70);
return res;
} else {
res.emplace_back(crsNN, 25);