aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2020-03-30 23:56:39 +0200
committerGitHub <noreply@github.com>2020-03-30 23:56:39 +0200
commit5bb88a1d8c4ac71a4c702ab877e4bc7aa9dc261c (patch)
tree216e119f32568d3eb4178f10d61f09754bf1cef2 /src
parent977305e82a339558f8ac5226f2884d2523a4c03e (diff)
parent9c8dc7e59d0df54b19bc4dcf1293ce2ac49d05a5 (diff)
downloadPROJ-5bb88a1d8c4ac71a4c702ab877e4bc7aa9dc261c.tar.gz
PROJ-5bb88a1d8c4ac71a4c702ab877e4bc7aa9dc261c.zip
Merge pull request #2118 from rouault/backport_6_3_fix_2116
[Backport 6.3] ESRI_WKT ingestion: make sure to identify to non-deprecated EPSG entry when possible (fixes #2116)
Diffstat (limited to 'src')
-rw-r--r--src/iso19111/factory.cpp36
1 files changed, 27 insertions, 9 deletions
diff --git a/src/iso19111/factory.cpp b/src/iso19111/factory.cpp
index e3bbcf95..e3aee4b4 100644
--- a/src/iso19111/factory.cpp
+++ b/src/iso19111/factory.cpp
@@ -5343,18 +5343,36 @@ std::string AuthorityFactory::getOfficialNameFromAlias(
if (res.empty()) {
return std::string();
}
- const auto &row = res.front();
- outTableName = row[0];
- outAuthName = row[1];
- outCode = row[2];
- sql = "SELECT name FROM \"";
- sql += replaceAll(outTableName, "\"", "\"\"");
- sql += "\" WHERE auth_name = ? AND code = ?";
- res = d->run(sql, {outAuthName, outCode});
+
+ params.clear();
+ sql.clear();
+ bool first = true;
+ for (const auto &row : res) {
+ if (!first)
+ sql += " UNION ALL ";
+ first = false;
+ outTableName = row[0];
+ outAuthName = row[1];
+ outCode = row[2];
+ sql += "SELECT name, ? AS table_name, auth_name, code, deprecated "
+ "FROM \"";
+ sql += replaceAll(outTableName, "\"", "\"\"");
+ sql += "\" WHERE auth_name = ? AND code = ?";
+ params.emplace_back(outTableName);
+ params.emplace_back(outAuthName);
+ params.emplace_back(outCode);
+ }
+ sql = "SELECT name, table_name, auth_name, code FROM (" + sql +
+ ") x ORDER BY deprecated LIMIT 1";
+ res = d->run(sql, params);
if (res.empty()) { // shouldn't happen normally
return std::string();
}
- return res.front()[0];
+ const auto &row = res.front();
+ outTableName = row[1];
+ outAuthName = row[2];
+ outCode = row[3];
+ return row[0];
}
}