diff --git a/xmlization/test/edge_cases_test.go b/xmlization/test/edge_cases_test.go
new file mode 100644
index 00000000..41198eee
--- /dev/null
+++ b/xmlization/test/edge_cases_test.go
@@ -0,0 +1,176 @@
+package xmlization_test
+
+import (
+ "bytes"
+ "encoding/xml"
+ aastypes "github.com/aas-core-works/aas-core3.0-golang/types"
+ aasxmlization "github.com/aas-core-works/aas-core3.0-golang/xmlization"
+ "strings"
+ "testing"
+)
+
+func TestRobustToNewline(t *testing.T) {
+ // See:
+ // https://github.com/aas-core-works/aas-core3.0-golang/issues/24
+ //
+ // We relied erroneously on whitespace between the elements which eclipsed the bug
+ // where we read into the content of a class property instead of letting the called
+ // function move the cursor.
+ text := ("" +
+ "" +
+ "some-unique-global-identifier" +
+ "" +
+ "")
+
+ reader := strings.NewReader(text)
+ decoder := xml.NewDecoder(reader)
+
+ deserialized, deseriaErr := aasxmlization.Unmarshal(decoder)
+
+ source := "Minimal example to reproduce robustness to newlines"
+
+ ok := assertNoDeserializationError(t, deseriaErr, source)
+ if !ok {
+ return
+ }
+
+ if _, ok := deserialized.(aastypes.IEnvironment); !ok {
+ t.Fatalf(
+ "Expected an instance of IEnvironment, "+
+ "but got %T: %v",
+ deserialized, deserialized,
+ )
+ return
+ }
+
+ buf := &bytes.Buffer{}
+ encoder := xml.NewEncoder(buf)
+ encoder.Indent("", "\t")
+
+ seriaErr := aasxmlization.Marshal(encoder, deserialized, true)
+ ok = assertNoSerializationError(t, seriaErr, source)
+ if !ok {
+ return
+ }
+
+ roundTrip := string(buf.Bytes())
+
+ expected := `
+
+
+ some-unique-global-identifier
+
+
+`
+ if roundTrip != expected {
+ t.Fatalf(
+ "Expected round-trip serialization to be `%v`, but got `%v`",
+ expected, roundTrip,
+ )
+ }
+}
+
+func TestRobustToNewlineOnDispatch(t *testing.T) {
+ // See:
+ // https://github.com/aas-core-works/aas-core3.0-golang/issues/24
+ //
+ // Note that both `dataSpecificationContent` and `dataSpecificationIec61360` are
+ // on the same line (right in the middle).
+ text := `
+
+
+ 0173-1#02-AAR529#004
+
+
+
+ ExternalReference
+
+
+ GlobalReference
+ https://admin-shell.io/DataSpecificationTemplates/DataSpecificationIEC61360/3/0
+
+
+
+
+
+
+ en
+ kilogram
+
+
+
+
+
+
+
+
+`
+
+ reader := strings.NewReader(text)
+ decoder := xml.NewDecoder(reader)
+
+ deserialized, deseriaErr := aasxmlization.Unmarshal(decoder)
+
+ pth := "Issue #24"
+
+ ok := assertNoDeserializationError(t, deseriaErr, pth)
+ if !ok {
+ return
+ }
+
+ if _, ok := deserialized.(aastypes.IEnvironment); !ok {
+ t.Fatalf(
+ "Expected an instance of IEnvironment, "+
+ "but got %T: %v",
+ deserialized, deserialized,
+ )
+ return
+ }
+
+ buf := &bytes.Buffer{}
+ encoder := xml.NewEncoder(buf)
+ encoder.Indent("", "\t")
+
+ seriaErr := aasxmlization.Marshal(encoder, deserialized, true)
+ ok = assertNoSerializationError(t, seriaErr, pth)
+ if !ok {
+ return
+ }
+
+ roundTrip := string(buf.Bytes())
+
+ expected := `
+
+
+ 0173-1#02-AAR529#004
+
+
+
+
+
+
+ en
+ kilogram
+
+
+
+
+
+ ExternalReference
+
+
+ GlobalReference
+ https://admin-shell.io/DataSpecificationTemplates/DataSpecificationIEC61360/3/0
+
+
+
+
+
+
+
+`
+
+ if expected != roundTrip {
+ t.Fatalf("Expected `%v`, got `%v`", expected, roundTrip)
+ }
+}
diff --git a/xmlization/xmlization.go b/xmlization/xmlization.go
index e8f10533..366a0636 100644
--- a/xmlization/xmlization.go
+++ b/xmlization/xmlization.go
@@ -569,7 +569,8 @@ func readList[T aastypes.IClass](
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readHasSemanticsWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -685,32 +686,6 @@ func readHasSemanticsWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IHasSemantics]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalHasSemantics(
- decoder *xml.Decoder,
-) (instance aastypes.IHasSemantics,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IHasSemantics " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readHasSemanticsWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IExtension]
// as a sequence of XML elements, each representing a property
// of [aastypes.IExtension].
@@ -892,7 +867,8 @@ func readExtensionAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readExtensionWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -941,37 +917,12 @@ func readExtensionWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IExtension]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalExtension(
- decoder *xml.Decoder,
-) (instance aastypes.IExtension,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IExtension " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readExtensionWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IHasExtensions]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readHasExtensionsWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1083,37 +1034,12 @@ func readHasExtensionsWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IHasExtensions]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalHasExtensions(
- decoder *xml.Decoder,
-) (instance aastypes.IHasExtensions,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IHasExtensions " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readHasExtensionsWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IReferable]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readReferableWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1225,37 +1151,12 @@ func readReferableWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IReferable]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalReferable(
- decoder *xml.Decoder,
-) (instance aastypes.IReferable,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IReferable " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readReferableWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IIdentifiable]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readIdentifiableWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1311,32 +1212,6 @@ func readIdentifiableWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IIdentifiable]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalIdentifiable(
- decoder *xml.Decoder,
-) (instance aastypes.IIdentifiable,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IIdentifiable " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readIdentifiableWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.ModellingKind].
//
@@ -1378,7 +1253,8 @@ func readTextAsModellingKind(
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readHasKindWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1426,37 +1302,12 @@ func readHasKindWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IHasKind]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalHasKind(
- decoder *xml.Decoder,
-) (instance aastypes.IHasKind,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IHasKind " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readHasKindWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IHasDataSpecification]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readHasDataSpecificationWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1572,32 +1423,6 @@ func readHasDataSpecificationWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IHasDataSpecification]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalHasDataSpecification(
- decoder *xml.Decoder,
-) (instance aastypes.IHasDataSpecification,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IHasDataSpecification " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readHasDataSpecificationWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IAdministrativeInformation]
// as a sequence of XML elements, each representing a property
// of [aastypes.IAdministrativeInformation].
@@ -1761,7 +1586,8 @@ func readAdministrativeInformationAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readAdministrativeInformationWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1810,37 +1636,12 @@ func readAdministrativeInformationWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IAdministrativeInformation]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalAdministrativeInformation(
- decoder *xml.Decoder,
-) (instance aastypes.IAdministrativeInformation,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IAdministrativeInformation " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readAdministrativeInformationWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IQualifiable]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readQualifiableWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -1944,32 +1745,6 @@ func readQualifiableWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IQualifiable]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalQualifiable(
- decoder *xml.Decoder,
-) (instance aastypes.IQualifiable,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IQualifiable " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readQualifiableWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.QualifierKind].
//
@@ -2204,7 +1979,8 @@ func readQualifierAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readQualifierWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -2253,32 +2029,6 @@ func readQualifierWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IQualifier]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalQualifier(
- decoder *xml.Decoder,
-) (instance aastypes.IQualifier,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IQualifier " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readQualifierWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IAssetAdministrationShell]
// as a sequence of XML elements, each representing a property
// of [aastypes.IAssetAdministrationShell].
@@ -2520,7 +2270,8 @@ func readAssetAdministrationShellAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readAssetAdministrationShellWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -2569,32 +2320,6 @@ func readAssetAdministrationShellWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IAssetAdministrationShell]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalAssetAdministrationShell(
- decoder *xml.Decoder,
-) (instance aastypes.IAssetAdministrationShell,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IAssetAdministrationShell " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readAssetAdministrationShellWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IAssetInformation]
// as a sequence of XML elements, each representing a property
// of [aastypes.IAssetInformation].
@@ -2765,7 +2490,8 @@ func readAssetInformationAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readAssetInformationWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -2814,32 +2540,6 @@ func readAssetInformationWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IAssetInformation]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalAssetInformation(
- decoder *xml.Decoder,
-) (instance aastypes.IAssetInformation,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IAssetInformation " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readAssetInformationWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IResource]
// as a sequence of XML elements, each representing a property
// of [aastypes.IResource].
@@ -2977,7 +2677,8 @@ func readResourceAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readResourceWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -3026,32 +2727,6 @@ func readResourceWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IResource]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalResource(
- decoder *xml.Decoder,
-) (instance aastypes.IResource,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IResource " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readResourceWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.AssetKind].
//
@@ -3262,7 +2937,8 @@ func readSpecificAssetIDAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readSpecificAssetIDWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -3292,48 +2968,22 @@ func readSpecificAssetIDWithLookahead(
),
)
return
- }
-
- current, err = readNext(decoder, current)
- if err != nil {
- return
- }
-
- instance, current, err = readSpecificAssetIDAsSequence(
- decoder,
- current,
- )
- if err != nil {
- return
- }
-
- err = checkEndElement(current, local)
- return
-}
-
-// Unmarshal an instance of [aastypes.ISpecificAssetID]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalSpecificAssetID(
- decoder *xml.Decoder,
-) (instance aastypes.ISpecificAssetID,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ISpecificAssetID " +
- "serialized as an XML element, but reached the end of file.",
- )
+ }
+
+ current, err = readNext(decoder, current)
+ if err != nil {
return
}
- instance, err = readSpecificAssetIDWithLookahead(
+ instance, current, err = readSpecificAssetIDAsSequence(
decoder,
current,
)
+ if err != nil {
+ return
+ }
+
+ err = checkEndElement(current, local)
return
}
@@ -3595,7 +3245,8 @@ func readSubmodelAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readSubmodelWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -3644,37 +3295,12 @@ func readSubmodelWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ISubmodel]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalSubmodel(
- decoder *xml.Decoder,
-) (instance aastypes.ISubmodel,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ISubmodel " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readSubmodelWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.ISubmodelElement]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readSubmodelElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -3774,32 +3400,6 @@ func readSubmodelElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ISubmodelElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalSubmodelElement(
- decoder *xml.Decoder,
-) (instance aastypes.ISubmodelElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ISubmodelElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readSubmodelElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IRelationshipElement]
// as a sequence of XML elements, each representing a property
// of [aastypes.IRelationshipElement].
@@ -4042,7 +3642,8 @@ func readRelationshipElementAsSequence(
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readRelationshipElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -4094,32 +3695,6 @@ func readRelationshipElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IRelationshipElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalRelationshipElement(
- decoder *xml.Decoder,
-) (instance aastypes.IRelationshipElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IRelationshipElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readRelationshipElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.AASSubmodelElements].
//
@@ -4427,7 +4002,8 @@ func readSubmodelElementListAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readSubmodelElementListWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -4476,32 +4052,6 @@ func readSubmodelElementListWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ISubmodelElementList]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalSubmodelElementList(
- decoder *xml.Decoder,
-) (instance aastypes.ISubmodelElementList,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ISubmodelElementList " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readSubmodelElementListWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ISubmodelElementCollection]
// as a sequence of XML elements, each representing a property
// of [aastypes.ISubmodelElementCollection].
@@ -4719,7 +4269,8 @@ func readSubmodelElementCollectionAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readSubmodelElementCollectionWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -4768,37 +4319,12 @@ func readSubmodelElementCollectionWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ISubmodelElementCollection]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalSubmodelElementCollection(
- decoder *xml.Decoder,
-) (instance aastypes.ISubmodelElementCollection,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ISubmodelElementCollection " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readSubmodelElementCollectionWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IDataElement]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readDataElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -4866,32 +4392,6 @@ func readDataElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IDataElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalDataElement(
- decoder *xml.Decoder,
-) (instance aastypes.IDataElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IDataElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readDataElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IProperty]
// as a sequence of XML elements, each representing a property
// of [aastypes.IProperty].
@@ -5139,7 +4639,8 @@ func readPropertyAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readPropertyWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -5188,32 +4689,6 @@ func readPropertyWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IProperty]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalProperty(
- decoder *xml.Decoder,
-) (instance aastypes.IProperty,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IProperty " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readPropertyWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IMultiLanguageProperty]
// as a sequence of XML elements, each representing a property
// of [aastypes.IMultiLanguageProperty].
@@ -5441,7 +4916,8 @@ func readMultiLanguagePropertyAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readMultiLanguagePropertyWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -5490,32 +4966,6 @@ func readMultiLanguagePropertyWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IMultiLanguageProperty]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalMultiLanguageProperty(
- decoder *xml.Decoder,
-) (instance aastypes.IMultiLanguageProperty,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IMultiLanguageProperty " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readMultiLanguagePropertyWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IRange]
// as a sequence of XML elements, each representing a property
// of [aastypes.IRange].
@@ -5765,7 +5215,8 @@ func readRangeAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readRangeWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -5814,32 +5265,6 @@ func readRangeWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IRange]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalRange(
- decoder *xml.Decoder,
-) (instance aastypes.IRange,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IRange " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readRangeWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IReferenceElement]
// as a sequence of XML elements, each representing a property
// of [aastypes.IReferenceElement].
@@ -6056,7 +5481,8 @@ func readReferenceElementAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readReferenceElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -6105,32 +5531,6 @@ func readReferenceElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IReferenceElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalReferenceElement(
- decoder *xml.Decoder,
-) (instance aastypes.IReferenceElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IReferenceElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readReferenceElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IBlob]
// as a sequence of XML elements, each representing a property
// of [aastypes.IBlob].
@@ -6366,7 +5766,8 @@ func readBlobAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readBlobWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -6415,32 +5816,6 @@ func readBlobWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IBlob]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalBlob(
- decoder *xml.Decoder,
-) (instance aastypes.IBlob,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IBlob " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readBlobWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IFile]
// as a sequence of XML elements, each representing a property
// of [aastypes.IFile].
@@ -6678,7 +6053,8 @@ func readFileAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readFileWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -6715,41 +6091,15 @@ func readFileWithLookahead(
return
}
- instance, current, err = readFileAsSequence(
- decoder,
- current,
- )
- if err != nil {
- return
- }
-
- err = checkEndElement(current, local)
- return
-}
-
-// Unmarshal an instance of [aastypes.IFile]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalFile(
- decoder *xml.Decoder,
-) (instance aastypes.IFile,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IFile " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readFileWithLookahead(
+ instance, current, err = readFileAsSequence(
decoder,
current,
)
+ if err != nil {
+ return
+ }
+
+ err = checkEndElement(current, local)
return
}
@@ -7006,7 +6356,8 @@ func readAnnotatedRelationshipElementAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readAnnotatedRelationshipElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -7055,32 +6406,6 @@ func readAnnotatedRelationshipElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IAnnotatedRelationshipElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalAnnotatedRelationshipElement(
- decoder *xml.Decoder,
-) (instance aastypes.IAnnotatedRelationshipElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IAnnotatedRelationshipElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readAnnotatedRelationshipElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IEntity]
// as a sequence of XML elements, each representing a property
// of [aastypes.IEntity].
@@ -7340,7 +6665,8 @@ func readEntityAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readEntityWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -7389,32 +6715,6 @@ func readEntityWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IEntity]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalEntity(
- decoder *xml.Decoder,
-) (instance aastypes.IEntity,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IEntity " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readEntityWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.EntityType].
//
@@ -7737,7 +7037,8 @@ func readEventPayloadAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readEventPayloadWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -7786,37 +7087,12 @@ func readEventPayloadWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IEventPayload]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalEventPayload(
- decoder *xml.Decoder,
-) (instance aastypes.IEventPayload,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IEventPayload " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readEventPayloadWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IEventElement]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readEventElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -7864,32 +7140,6 @@ func readEventElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IEventElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalEventElement(
- decoder *xml.Decoder,
-) (instance aastypes.IEventElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IEventElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readEventElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IBasicEventElement]
// as a sequence of XML elements, each representing a property
// of [aastypes.IBasicEventElement].
@@ -8207,7 +7457,8 @@ func readBasicEventElementAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readBasicEventElementWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -8256,32 +7507,6 @@ func readBasicEventElementWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IBasicEventElement]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalBasicEventElement(
- decoder *xml.Decoder,
-) (instance aastypes.IBasicEventElement,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IBasicEventElement " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readBasicEventElementWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IOperation]
// as a sequence of XML elements, each representing a property
// of [aastypes.IOperation].
@@ -8521,7 +7746,8 @@ func readOperationAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readOperationWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -8570,32 +7796,6 @@ func readOperationWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IOperation]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalOperation(
- decoder *xml.Decoder,
-) (instance aastypes.IOperation,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IOperation " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readOperationWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IOperationVariable]
// as a sequence of XML elements, each representing a property
// of [aastypes.IOperationVariable].
@@ -8654,11 +7854,12 @@ func readOperationVariableAsSequence(
var valueErr error
switch local {
case "value":
- theValue, valueErr = unmarshalSubmodelElement(
+ theValue, valueErr = readSubmodelElementWithLookahead(
decoder,
+ current,
)
- // unmarshalSubmodelElement stops at the end element,
- // so we look ahead to the next element.
+ // readSubmodelElementWithLookahead stops at the end element,
+ // so we look ahead to the next element, just after the end element.
if valueErr == nil {
current, valueErr = readNext(decoder, current)
}
@@ -8725,7 +7926,8 @@ func readOperationVariableAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readOperationVariableWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -8774,32 +7976,6 @@ func readOperationVariableWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IOperationVariable]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalOperationVariable(
- decoder *xml.Decoder,
-) (instance aastypes.IOperationVariable,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IOperationVariable " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readOperationVariableWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ICapability]
// as a sequence of XML elements, each representing a property
// of [aastypes.ICapability].
@@ -9006,7 +8182,8 @@ func readCapabilityAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readCapabilityWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -9055,32 +8232,6 @@ func readCapabilityWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ICapability]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalCapability(
- decoder *xml.Decoder,
-) (instance aastypes.ICapability,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ICapability " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readCapabilityWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IConceptDescription]
// as a sequence of XML elements, each representing a property
// of [aastypes.IConceptDescription].
@@ -9295,7 +8446,8 @@ func readConceptDescriptionAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readConceptDescriptionWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -9344,32 +8496,6 @@ func readConceptDescriptionWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IConceptDescription]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalConceptDescription(
- decoder *xml.Decoder,
-) (instance aastypes.IConceptDescription,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IConceptDescription " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readConceptDescriptionWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.ReferenceTypes].
//
@@ -9560,7 +8686,8 @@ func readReferenceAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readReferenceWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -9609,32 +8736,6 @@ func readReferenceWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IReference]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalReference(
- decoder *xml.Decoder,
-) (instance aastypes.IReference,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IReference " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readReferenceWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IKey]
// as a sequence of XML elements, each representing a property
// of [aastypes.IKey].
@@ -9777,7 +8878,8 @@ func readKeyAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readKeyWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -9826,32 +8928,6 @@ func readKeyWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IKey]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalKey(
- decoder *xml.Decoder,
-) (instance aastypes.IKey,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IKey " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readKeyWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.KeyTypes].
//
@@ -9930,7 +9006,8 @@ func readTextAsDataTypeDefXSD(
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readAbstractLangStringWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -9974,49 +9051,23 @@ func readAbstractLangStringWithLookahead(
decoder, current,
)
case "langStringTextType":
- instance, current, err = readLangStringTextTypeAsSequence(
- decoder, current,
- )
- default:
- err = newDeserializationError(
- fmt.Sprintf(
- "Unexpected start element %s as discriminator "+
- "for IAbstractLangString",
- local,
- ),
- )
- }
- if err != nil {
- return
- }
-
- err = checkEndElement(current, local)
- return
-}
-
-// Unmarshal an instance of [aastypes.IAbstractLangString]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalAbstractLangString(
- decoder *xml.Decoder,
-) (instance aastypes.IAbstractLangString,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
+ instance, current, err = readLangStringTextTypeAsSequence(
+ decoder, current,
+ )
+ default:
err = newDeserializationError(
- "Expected an instance of IAbstractLangString " +
- "serialized as an XML element, but reached the end of file.",
+ fmt.Sprintf(
+ "Unexpected start element %s as discriminator "+
+ "for IAbstractLangString",
+ local,
+ ),
)
+ }
+ if err != nil {
return
}
- instance, err = readAbstractLangStringWithLookahead(
- decoder,
- current,
- )
+ err = checkEndElement(current, local)
return
}
@@ -10162,7 +9213,8 @@ func readLangStringNameTypeAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLangStringNameTypeWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -10211,32 +9263,6 @@ func readLangStringNameTypeWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILangStringNameType]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLangStringNameType(
- decoder *xml.Decoder,
-) (instance aastypes.ILangStringNameType,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILangStringNameType " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLangStringNameTypeWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ILangStringTextType]
// as a sequence of XML elements, each representing a property
// of [aastypes.ILangStringTextType].
@@ -10379,7 +9405,8 @@ func readLangStringTextTypeAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLangStringTextTypeWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -10428,32 +9455,6 @@ func readLangStringTextTypeWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILangStringTextType]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLangStringTextType(
- decoder *xml.Decoder,
-) (instance aastypes.ILangStringTextType,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILangStringTextType " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLangStringTextTypeWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IEnvironment]
// as a sequence of XML elements, each representing a property
// of [aastypes.IEnvironment].
@@ -10593,7 +9594,8 @@ func readEnvironmentAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readEnvironmentWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -10642,37 +9644,12 @@ func readEnvironmentWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IEnvironment]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalEnvironment(
- decoder *xml.Decoder,
-) (instance aastypes.IEnvironment,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IEnvironment " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readEnvironmentWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize an instance of [aastypes.IDataSpecificationContent]
// as an XML element where the start element is expected to have been already read
// as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readDataSpecificationContentWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -10720,32 +9697,6 @@ func readDataSpecificationContentWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IDataSpecificationContent]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalDataSpecificationContent(
- decoder *xml.Decoder,
-) (instance aastypes.IDataSpecificationContent,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IDataSpecificationContent " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readDataSpecificationContentWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IEmbeddedDataSpecification]
// as a sequence of XML elements, each representing a property
// of [aastypes.IEmbeddedDataSpecification].
@@ -10805,11 +9756,12 @@ func readEmbeddedDataSpecificationAsSequence(
var valueErr error
switch local {
case "dataSpecificationContent":
- theDataSpecificationContent, valueErr = unmarshalDataSpecificationContent(
+ theDataSpecificationContent, valueErr = readDataSpecificationContentWithLookahead(
decoder,
+ current,
)
- // unmarshalDataSpecificationContent stops at the end element,
- // so we look ahead to the next element.
+ // readDataSpecificationContentWithLookahead stops at the end element,
+ // so we look ahead to the next element, just after the end element.
if valueErr == nil {
current, valueErr = readNext(decoder, current)
}
@@ -10885,7 +9837,8 @@ func readEmbeddedDataSpecificationAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readEmbeddedDataSpecificationWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -10934,32 +9887,6 @@ func readEmbeddedDataSpecificationWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IEmbeddedDataSpecification]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalEmbeddedDataSpecification(
- decoder *xml.Decoder,
-) (instance aastypes.IEmbeddedDataSpecification,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IEmbeddedDataSpecification " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readEmbeddedDataSpecificationWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Consume the text tokens (char data) as a string-encoded literal of
// [aastypes.DataTypeIEC61360].
//
@@ -11173,7 +10100,8 @@ func readLevelTypeAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLevelTypeWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -11222,32 +10150,6 @@ func readLevelTypeWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILevelType]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLevelType(
- decoder *xml.Decoder,
-) (instance aastypes.ILevelType,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILevelType " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLevelTypeWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IValueReferencePair]
// as a sequence of XML elements, each representing a property
// of [aastypes.IValueReferencePair].
@@ -11390,7 +10292,8 @@ func readValueReferencePairAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readValueReferencePairWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -11439,32 +10342,6 @@ func readValueReferencePairWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IValueReferencePair]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalValueReferencePair(
- decoder *xml.Decoder,
-) (instance aastypes.IValueReferencePair,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IValueReferencePair " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readValueReferencePairWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IValueList]
// as a sequence of XML elements, each representing a property
// of [aastypes.IValueList].
@@ -11591,7 +10468,8 @@ func readValueListAsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readValueListWithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -11640,32 +10518,6 @@ func readValueListWithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IValueList]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalValueList(
- decoder *xml.Decoder,
-) (instance aastypes.IValueList,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IValueList " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readValueListWithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ILangStringPreferredNameTypeIEC61360]
// as a sequence of XML elements, each representing a property
// of [aastypes.ILangStringPreferredNameTypeIEC61360].
@@ -11808,7 +10660,8 @@ func readLangStringPreferredNameTypeIEC61360AsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLangStringPreferredNameTypeIEC61360WithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -11857,32 +10710,6 @@ func readLangStringPreferredNameTypeIEC61360WithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILangStringPreferredNameTypeIEC61360]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLangStringPreferredNameTypeIEC61360(
- decoder *xml.Decoder,
-) (instance aastypes.ILangStringPreferredNameTypeIEC61360,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILangStringPreferredNameTypeIEC61360 " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLangStringPreferredNameTypeIEC61360WithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ILangStringShortNameTypeIEC61360]
// as a sequence of XML elements, each representing a property
// of [aastypes.ILangStringShortNameTypeIEC61360].
@@ -12025,7 +10852,8 @@ func readLangStringShortNameTypeIEC61360AsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLangStringShortNameTypeIEC61360WithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -12074,32 +10902,6 @@ func readLangStringShortNameTypeIEC61360WithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILangStringShortNameTypeIEC61360]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLangStringShortNameTypeIEC61360(
- decoder *xml.Decoder,
-) (instance aastypes.ILangStringShortNameTypeIEC61360,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILangStringShortNameTypeIEC61360 " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLangStringShortNameTypeIEC61360WithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.ILangStringDefinitionTypeIEC61360]
// as a sequence of XML elements, each representing a property
// of [aastypes.ILangStringDefinitionTypeIEC61360].
@@ -12242,7 +11044,8 @@ func readLangStringDefinitionTypeIEC61360AsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readLangStringDefinitionTypeIEC61360WithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -12291,32 +11094,6 @@ func readLangStringDefinitionTypeIEC61360WithLookahead(
return
}
-// Unmarshal an instance of [aastypes.ILangStringDefinitionTypeIEC61360]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalLangStringDefinitionTypeIEC61360(
- decoder *xml.Decoder,
-) (instance aastypes.ILangStringDefinitionTypeIEC61360,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of ILangStringDefinitionTypeIEC61360 " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readLangStringDefinitionTypeIEC61360WithLookahead(
- decoder,
- current,
- )
- return
-}
-
// De-serialize the instance of [aastypes.IDataSpecificationIEC61360]
// as a sequence of XML elements, each representing a property
// of [aastypes.IDataSpecificationIEC61360].
@@ -12567,7 +11344,8 @@ func readDataSpecificationIEC61360AsSequence(
// as an XML element where the start element is expected to have been already
// read as `current` token.
//
-// The de-serialization stops by consuming the final end element.
+// The de-serialization stops by consuming the final end element. The next call to
+// the `decoder.Token()` will return the element just after the end element.
func readDataSpecificationIEC61360WithLookahead(
decoder *xml.Decoder,
current xml.Token,
@@ -12616,32 +11394,6 @@ func readDataSpecificationIEC61360WithLookahead(
return
}
-// Unmarshal an instance of [aastypes.IDataSpecificationIEC61360]
-// serialized as an XML element.
-//
-// The XML element must live in the [Namespace] space.
-func unmarshalDataSpecificationIEC61360(
- decoder *xml.Decoder,
-) (instance aastypes.IDataSpecificationIEC61360,
- err error,
-) {
- var current xml.Token
- current, err = readNext(decoder, nil)
- if _, isEOF := current.(eof); isEOF {
- err = newDeserializationError(
- "Expected an instance of IDataSpecificationIEC61360 " +
- "serialized as an XML element, but reached the end of file.",
- )
- return
- }
-
- instance, err = readDataSpecificationIEC61360WithLookahead(
- decoder,
- current,
- )
- return
-}
-
// Unmarshal an instance of [aastypes.IClass] serialized as an XML element.
//
// The XML element must live in the [Namespace] space.