aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/iso19111/factory.cpp70
-rw-r--r--test/unit/test_factory.cpp12
2 files changed, 82 insertions, 0 deletions
diff --git a/src/iso19111/factory.cpp b/src/iso19111/factory.cpp
index fa2a0ef3..cf44024f 100644
--- a/src/iso19111/factory.cpp
+++ b/src/iso19111/factory.cpp
@@ -4951,6 +4951,76 @@ AuthorityFactory::createCoordinateReferenceSystem(const std::string &code,
if (crs) {
return NN_NO_CHECK(crs);
}
+
+ if (d->authority() == metadata::Identifier::OGC) {
+ if (code == "AnsiDate") {
+ // Derived from http://www.opengis.net/def/crs/OGC/0/AnsiDate
+ return crs::TemporalCRS::create(
+ util::PropertyMap()
+ // above URL indicates Julian Date" as name... likely wrong
+ .set(common::IdentifiedObject::NAME_KEY, "Ansi Date")
+ .set(metadata::Identifier::CODESPACE_KEY, d->authority())
+ .set(metadata::Identifier::CODE_KEY, code),
+ datum::TemporalDatum::create(
+ util::PropertyMap().set(
+ common::IdentifiedObject::NAME_KEY,
+ "Epoch time for the ANSI date (1-Jan-1601, 00h00 UTC) "
+ "as day 1."),
+ common::DateTime::create("1600-12-31T00:00:00Z"),
+ datum::TemporalDatum::CALENDAR_PROLEPTIC_GREGORIAN),
+ cs::TemporalCountCS::create(
+ util::PropertyMap(),
+ cs::CoordinateSystemAxis::create(
+ util::PropertyMap().set(
+ common::IdentifiedObject::NAME_KEY, "Time"),
+ "T", cs::AxisDirection::FUTURE,
+ common::UnitOfMeasure("day", 0,
+ UnitOfMeasure::Type::TIME))));
+ }
+ if (code == "JulianDate") {
+ // Derived from http://www.opengis.net/def/crs/OGC/0/JulianDate
+ return crs::TemporalCRS::create(
+ util::PropertyMap()
+ .set(common::IdentifiedObject::NAME_KEY, "Julian Date")
+ .set(metadata::Identifier::CODESPACE_KEY, d->authority())
+ .set(metadata::Identifier::CODE_KEY, code),
+ datum::TemporalDatum::create(
+ util::PropertyMap().set(
+ common::IdentifiedObject::NAME_KEY,
+ "The beginning of the Julian period."),
+ common::DateTime::create("-4714-11-24T12:00:00Z"),
+ datum::TemporalDatum::CALENDAR_PROLEPTIC_GREGORIAN),
+ cs::TemporalCountCS::create(
+ util::PropertyMap(),
+ cs::CoordinateSystemAxis::create(
+ util::PropertyMap().set(
+ common::IdentifiedObject::NAME_KEY, "Time"),
+ "T", cs::AxisDirection::FUTURE,
+ common::UnitOfMeasure("day", 0,
+ UnitOfMeasure::Type::TIME))));
+ }
+ if (code == "UnixTime") {
+ // Derived from http://www.opengis.net/def/crs/OGC/0/UnixTime
+ return crs::TemporalCRS::create(
+ util::PropertyMap()
+ .set(common::IdentifiedObject::NAME_KEY, "Unix Time")
+ .set(metadata::Identifier::CODESPACE_KEY, d->authority())
+ .set(metadata::Identifier::CODE_KEY, code),
+ datum::TemporalDatum::create(
+ util::PropertyMap().set(common::IdentifiedObject::NAME_KEY,
+ "Unix epoch"),
+ common::DateTime::create("1970-01-01T00:00:00Z"),
+ datum::TemporalDatum::CALENDAR_PROLEPTIC_GREGORIAN),
+ cs::TemporalCountCS::create(
+ util::PropertyMap(),
+ cs::CoordinateSystemAxis::create(
+ util::PropertyMap().set(
+ common::IdentifiedObject::NAME_KEY, "Time"),
+ "T", cs::AxisDirection::FUTURE,
+ common::UnitOfMeasure::SECOND)));
+ }
+ }
+
auto res = d->runWithCodeParam(
"SELECT type FROM crs_view WHERE auth_name = ? AND code = ?", code);
if (res.empty()) {
diff --git a/test/unit/test_factory.cpp b/test/unit/test_factory.cpp
index c67f1490..2bc43b2d 100644
--- a/test/unit/test_factory.cpp
+++ b/test/unit/test_factory.cpp
@@ -4244,4 +4244,16 @@ TEST(factory, objectInsertion) {
}
}
+// ---------------------------------------------------------------------------
+
+TEST(factory, ogc_timecrs) {
+ auto ctxt = DatabaseContext::create();
+ auto factory = AuthorityFactory::create(ctxt, Identifier::OGC);
+ factory->createCoordinateReferenceSystem("AnsiDate");
+ factory->createCoordinateReferenceSystem("JulianDate");
+ factory->createCoordinateReferenceSystem("UnixTime");
+}
+
+// ---------------------------------------------------------------------------
+
} // namespace