-
-
Notifications
You must be signed in to change notification settings - Fork 282
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Should unknown keywords be collected as annotations? #698
Comments
If this is the direction you want to go, then why have annotation keywords at all? |
(removed for clearity)I just saw that there is #687 ... My bad. |
@gregsdennis I don't understand the objection. Annotations are keywords with a certain behavior, specifically a "safe" behavior that lets an application decide what to do with them. The specific annotation keywords include rules for how to combine multiple occurrences attached to the same instance location:
So, if we say to treat unknown keywords as annotations, where the values are all collected by the default mechanism (keep a set of values for each instance location), then all the standard really does with I'm not pushing strongly for this, but it does seem nice that if I throw in a "foo" keyword, at least I'll see it in the annotation output which will often be all I need. Example: I may use an I could make a vocabulary including that keyword, and if I want interoperability, or to make If no one else particularly wants this I will drop it or punt it out to the future. |
So the benefit to having annotation keywords is that it constrains the acceptable values for them (e.g. objects aren't allowed in That's fair. Just wanted the clarity. |
That is not how I look at it at all, but I guess the outcome is the same? I really don't know what to say here. |
I would say that it is an optional feature of a parser/validator implementation that should be configurable by the user. The parser/validator may by default collect all unknown keywords, but if it does, the user must be allowed to disable it. |
@gregsdennis @plankthom I think it sounds like we should see what feedback we get on vocabularies before we try to specify default behavior. I'm punting this out of draft-08. |
I can see generic annotations being useful for applications that need to generate different outputs. I'm imagining using the annotations as part of the generation logic, e.g this property should not be generated for a particular output. |
@shusson yes, annotations are particularly useful for generative use cases. And we expect a lot of extension vocabulary work to be done for generative cases, as support for that is currently weak. So setting a default behavior of treating things as annotations would make such vocabularies work without needing a custom plugin. Granted, generative tooling will read the schema without an instance so, but there are also uses of annotations with instances (e.g. the way most people end up using |
I think we can RECOMMEND that unknown keywords are collected as annotations, and applications SHOULD provide a means to turn it on or off if they do collect annotations for unknown keywords. |
Yeah, this makes sense. I'd like to RECOMMEND that it be on by default, but perhaps allow that an implementation MAY decline to collect a very large value? I think the main concern is that an unknown applicator being treated as an annotation could cause the output to balloon to problematic sizes. |
Assuming you support annotations (which is related to what output format(s) you support, now that I think of it), should unknown keywords be collected as annotations instead of ignored?
I think we will see more annotations (we've had several requested that don't clearly meet the significance criteria to be added to the standard), and it's an easy default behavior to add.
I don't feel strongly about this, just wondering if this is a sensible default option.
The text was updated successfully, but these errors were encountered: