User-facing changes:
Rewrote logic around how emld works with schemaLocation:
schemaLocation argument on as_xml used to fill in a default value that pointed to a local copy of eml.xsd. Now, it automatically fills in a web-resolvable location to make validating documents easier out of the box.Re-worked the logic for handling schemaLocation when serializing to XML:
schemaLocation is present on the emld object, it is used verbatim (no change in API here) regardless of the schemaLocation argument of as_xml.schemaLocation is absent on the emld object:
as_xml(..., schemaLocation = TRUE) causes a value to be guessed.as_xml(..., schemaLocation = FALSE) explicitly prevents a value from being filled in when serialized.as_xml(..., schemaLocation = "Some value) explicitly sets the provided value.emld::eml_validate no longer depends on schemaLocation to determine the correct XSD to use during schema validation and now uses two helpers (See below) to find the correct schema file. See #52 & #45.
emld::eml_version now allows specifying the version without the eml- prefix, like `eml_version(“2.1.1”), and will throw a warning when it gets output that doesn’t ’look right rather than silently failing.
Fixed a bug where the EML 2.1.1 units dictionary was being used for EML 2.2.0 docs which would cause spurious validation errors. See #56.
Developer-facing (non-exported) changes:
find_real_root_name(doc : xml_document) : list(prefix : character, name: character) which returns the namespace prefix and the local name of the root element on an xml_document.guess_root_schema(doc : xml_document) : list(module : character, version : character, namespace : character) which returns the module, schema version, and namespace URI of the root element on an xml_document.schemaLocation is now ignored during roundtrip testing because of the new (above) behavior of emld with respect to schemaLocation.inst/tests.Other changes:
references attributes #48references. #47TextType nodes where extra whitespace was being added. #37.eml_validate’s behavior when validating custom units. #35.NEWS.md file to track changes to the package.