Skip to content
This repository has been archived by the owner on Nov 21, 2024. It is now read-only.

For 3.0, make required elements first in each sequence #96

Open
mccalluc opened this issue Dec 4, 2014 · 5 comments
Open

For 3.0, make required elements first in each sequence #96

mccalluc opened this issue Dec 4, 2014 · 5 comments

Comments

@mccalluc
Copy link

mccalluc commented Dec 4, 2014

In the current schema, some required elements come after optional elements. If the required elements are missing from a document, and you try to validate, the error message is hard to understand: It may list all the missing optional elements which could have gone in there, obscuring the real problem.

This change in the schema would not be backwards compatible, so it can not be done before 3.0.

@awead
Copy link

awead commented Dec 4, 2014

Would making validation not dependent on node order solve this?

@mccalluc
Copy link
Author

mccalluc commented Dec 5, 2014

I don't know, and I feel like that could introduce other problems, at least as far as human readability.

  • "I don't know": I wanted to make a couple of toy schemas and see what kind of validation errors they produce, but I didn't get around to it today. I did a bit of reading (1 2), and did get the sense that xsd:any is harder for the parser to implement, so I'm not sure the the messages would be more useful in general.
  • "human readability"
    • If it could be anywhere, it's much harder for a human to notice that it's missing than if it had to be at the top.
    • Similarly, if it should be unique, but instead there are multiple, perhaps not adjacent to each other, that also becomes harder to notice.

@awead
Copy link

awead commented Dec 5, 2014

Although they are probably in the minority, my thoughts are that XML, and PBcore for that matter, should never be for human readability. Computers should be parsing it, not us.
Furthermore, ensuring that elements are order independent reduces the likelihood of additional problems later. For me, getting exported PBCore to validate always involved an extra step of reordering the nodes. Removing that requirement would make that process easier.

@johnnypass
Copy link

I'm with you on this one, Adam. Also, is this related to an already closed issue (#19) from 4 years ago? I can't tell exactly from the comments why the issue was closed.

@mccalluc
Copy link
Author

I don't understand those comments either; Sorry.

A less ordered schema can work, but getting the cardinality constraints right might be tricky: I don't know that there's a way with xsd:all to say a given element must occur exactly once: If there's only required element you could imagine something like

xsd:sequence
   xsd:all (except required)
   required
   xsd:all (except required)

... but if there is more than one required element, then you'd have to have choice for all the different possible orderings ...

One way of resolving this is to segregate the required elements; actually, the xhtml schema is a good example of this: body is free-form, but you want at most one title, and so it goes in the head element instead, which is tighter.

Similarly, the handling of repeating elements will need to be be reconsidered... Will it be confusing if occurrences are separated? Perhaps not.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants