Two and Three Document DeltaV2 Format
DeltaXML DeltaV2 Format Description
The DeltaXML DeltaV2 format is a representation of two or three XML documents in a single document. Any of the original documents can be extracted from the Delta. The Delta is intended to be an improved version of the original DeltaXML Delta format. In particular the attribute changes are represented within elements and are therefore easier to process.
When the format is applied to two documents, these input documents are denoted A and B, and with three documents the inputs are denoted A, B and C.
Namespaces and Prefixes
Three namespaces are used in the DeltaV2 format to represent change, they are summarized in the following table:
|
usual prefix |
namespace URI |
purpose |
|---|---|---|
deltaxml |
http://www.deltaxml.com/ns/well-formed-delta-v1 |
Elements and attributes used to represent change between the inputs |
dxa |
http://www.deltaxml.com/ns/non-namespaced-attribute |
The namespace of an element, used to represent an attribute, which was not in a namespace in one or both input files. |
|
|
http://www.deltaxml.com/ns/xml-namespaced-attribute |
The namespace of an element, used to represent an attribute in the XML
namespace (corresponding to the URI:
|
The v1 component of the namespace URI is not a mistake. This URI was initially chosen when opinions on versioning of XML vocabularies and namespaces were in their infancy; we now agree with the mainstream opinion that new versions of a format/language should keep the same namespace.
Elements and Attributes
This is a list of the elements used by this format:
|
Element name |
Content |
Purpose |
|---|---|---|
|
deltaxml:attributes |
One of more elements, each of which has a local-name and namespace corresponding to an attribute beloning to the parent element. |
Details any differences between the attributes associated with the parent element. |
|
deltaxml:attributeValue |
CDATA representing the value of an attribute |
To record an attribute value that appeared in one or more of the input documents. |
|
deltaxml:textGroup |
One or more deltaxml:text elements. |
This element contains the variants of this segment of text. |
|
deltaxml:text |
PCDATA, i.e. text |
To record a text item that appeared in one or more of the input documents. |
This is a list of the attributes used by Delta
|
Attribute name |
Content |
Purpose |
|---|---|---|
|
deltaxml:deltaV2 |
For a delta of two documents, one of the following values: A, B, A=B, A!=B For a delta of three documents, one of the following values: A, B, C, A=B, A!=B, B=C, B!=C, A=C, A!=C, A=B=C, A!=B!=C, A=B!=C, A=C!=B, A!=B=C. |
Details the documents in which this data item appeared. If it appeared in
more than one document, this attribute also indicates whether the data items
were the same or different. For example, |
On the root element the following attributes must appear:
|
Attribute name |
Content |
Purpose |
|---|---|---|
|
deltaxml:version |
This must be "2.0" |
This indicates the version of the delta format. |
|
deltaxml:content-type |
This must have one of two values: |
This indicates if the delta document contains just the changes
( |
On each deltaxml:attributes element the following attribute/value must be present:
|
Attribute name |
Content |
Purpose |
|---|---|---|
|
deltaxml:ordered |
This must be "false" |
Indicates that the child elements, used to represent attributes, can appear in any order. |
Description
There is no DTD or Schema for a Delta, but the Delta will have the same look and feel as the original documents. There is a set of simple rules which apply to the Delta format. In general terms, the Delta generated from a set of documents will be a union of these documents in the sense that all the data that appears in any of the documents will also appear in the Delta.
Elements, attributes and text that are identified by DeltaXML as common to two or more of the documents are shared in the Delta. A subtree that appears unchanged in one or more documents will appear in the Delta almost exactly as it appeared in the original document(s).
Rules for a two input Delta
The definitive version of these rules is contained in a Schematron rule document: deltaV2-schematron.xml
Rules for a three input Delta
The definitive version of these rules will be contained in a Schematron rule document.
Full Context Delta
In an analogous manner to the original Delta format, a Delta can either show
just changes or can include all the data from the original documents. When only
changes are shown, the content of any unchanged element is not reproduced in the
delta. This will be for any element with a deltaxml:deltaV2
attribute equal to A=B or, for three documents, A=B=C.
Compatibility with original Delta format
The original delta format handled two documents only. The values of the
deltaxml:deltaV2 attribute correspond with the
deltaxml:delta attribute as follows: add becomes
B, delete becomes A,
unchanged becomes A=B and WFmodify
becomes A!=B. The value WFmodifyUnordered is also
A!=B but the deltaxml:ordered="false" attribute
remains on the element so that knowledge of the unordered content remains in the
delta document.
Attribute changes are now handled within markup to make processing easier. There is no longer a representation of an exchange between two elements or an element and text item.
Examples for Two Documents
Examples of Elements in Delta
|
Document A |
Document B |
|---|---|
|
<example> <tel/> |
<example> </person> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B"> |
Element <firstName> appears in both documents, A and B, and is the same in both. Element <lastName> appears in document B only. Element <T> appears in document A only. |
Examples of Text in Delta
|
Document A |
Document B |
|---|---|
|
<example> |
<example> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B"> |
The text in <firstName> is "J" in A and "John" in document B. The text in <lastName> is the same in both documents. |
Examples of Attributes in Delta
|
Document A |
Document B |
|---|---|
|
<example> |
<example> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B"> |
The attribute 'gender' is unchanged and so appears as a regular attribute. The attribute 'age' has a value of 36 in document A and 37 in B. Element <firstName> appears now as the second child of <person>. |
Examples for Three Documents
Examples of Elements in Delta
|
Document A |
Document B |
Document C |
|---|---|---|
|
<example> |
<example> </person> |
<example> </person> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B!=C"> |
Element <lastName> appears in two documents, A and B, and is the same in both. Element <tel> appears in only one document, A. |
Examples of Text in Delta
|
Document A |
Document B |
Document C |
|---|---|---|
|
<example> |
<example> |
<example> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B!=C"> |
The text in <firstName> is "J" in both A and C. The text in <firstName> is "John" in document B. The text in <lastName> is the same in all documents. |
Examples of Attributes in Delta
|
Document A |
Document B |
Document C |
|---|---|---|
|
<example> |
<example> |
<example> |
And the Delta for this will be as follows:
|
Delta |
Comments |
|---|---|
|
<example deltaxml:deltaV2="A!=B!=C"> |
The attribute 'gender' is unchanged and so appears as a regular attribute. The attribute 'age' has a value of 36 in document A and 37 in B. Element <firstName> appears now as the second child of <person>. |