-
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
XML Format Consultation: Merging <groups> and <enums> #335
Comments
The expression of enum group allocation and use that the current XML contains is important to us - the SGI enum registry was literally the place gl.xml began from. I don't see how you can simultaneously use the enums tags for semantic grouping and numerical grouping without simply replicating every enum in at least two places, so I'm not feeling much enthusiasm for this idea - although I applaud your efforts to construct it in terms of the existing schema. |
Yeah I understand that, and perhaps we need to look further into the current state of the groupings to look at what can be done to achieve the main goal: enforcing validity of groupings without causing any further trouble for vendors and spec editors. |
A way of doing this that would probably have no effect on current consumers is to move the group attribute into the individual <enum> tags rather than using <enums> as a grouping mechanism. It is kinda wordy (expands the file size by 5-10% at a guess), but since it's just a new attribute on an existing tag, it should be ignored by our scripts, and probably by most processing tools unaware of it. |
Yeah that works for me, I’ll update the proposal next time I’m on a
computer.
…On Thu, 12 Dec 2019 at 10:37, Jon Leech ***@***.***> wrote:
A way of doing this that would probably have no effect on current
consumers is to move the group attribute into the individual <enum> tags
rather than using <enums> as a grouping mechanism. It is kinda wordy
(expands the file size by 5-10% at a guess), but since it's just a new
attribute on an existing tag, it should be ignored by our scripts, and
probably by most processing tools unaware of it.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#335?email_source=notifications&email_token=ACVEYI65PGT3FAECFPX345TQYIH5TA5CNFSM4JW74LVKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEGWHKMY#issuecomment-564950323>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACVEYI7OEJX463XQCQXHDJ3QYIH5TANCNFSM4JW74LVA>
.
|
OK. If we go this way, please add the attributes at the end of the tag, not the beginning - keeping the name & value first is preferable for me. |
Yeah I agree with that 100%, putting it elsewhere would make it a lot
harder to edit the enums.
…On Thu, 12 Dec 2019 at 11:41, Jon Leech ***@***.***> wrote:
OK. If we go this way, please add the attributes at the end of the tag,
not the beginning - keeping the name & value first is preferable for me.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#335?email_source=notifications&email_token=ACVEYIZBZQZ6FOWZV3ARXL3QYIPPDA5CNFSM4JW74LVKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEGWMXQY#issuecomment-564972483>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACVEYI6NSXKSM75BUHGTM4LQYIPPDANCNFSM4JW74LVA>
.
|
I've updated the issue, let me know if there's any further comments. I've also been hearing radio silence from the downstream consumers which is slightly worrying. |
Maybe you also want to CC dbuenzli/tgls |
@dbuenzli any comments? |
Impacts ANGLE as we use gl.xml to generate our entry points and other files. @null77 is my handle. |
@null77 Do you use the blocks at all? This proposal only affects this portion of the spec, if you're not parsing anything else then you won't be affected by this issue. |
We do. They're helpful when converting a GLenum to string as some GLenum values overlap. |
Ah ok. In the |
The motivation sounds reasonable. Implementing a presubmit check that validates new enums have a group tag also sounds like it would solve your problem without causing conflicts downstream. What do you think? I'm assuming your motivation is that the groups aren't reliable right now. |
Yeah I was thinking about adding in a check as we already developed a small
error checker application internally, but a presubmit check won’t fix the
problem where the groupings are separate and, as a result, spec editors
have to go out of their way to ensure group correctness whereas if they’re
declared inline with the enum, it’s a lot easier for spec editors to
declare the groups.
I want to work with downstream consumers before we do anything destructive
like get rid of the blocks - I only want to do this once I know everyone’s
ready
…On Mon, 16 Dec 2019 at 22:54, Jamie Madill ***@***.***> wrote:
The motivation sounds reasonable. Implementing a presubmit check that
validates new enums have a group tag also sounds like it would solve your
problem without causing conflicts downstream. What do you think? I'm
assuming your motivation is that the groups aren't reliable right now.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#335?email_source=notifications&email_token=ACVEYI2GOVFPXPUMWSTVBWTQZABJDA5CNFSM4JW74LVKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEHANACQ#issuecomment-566284298>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACVEYIYDYBMFWNBCIDFHGG3QZABJDANCNFSM4JW74LVA>
.
|
The proposal sounds reasonable to me. It is inconvenient a bit to have to redo our parsing. Also you might want to include an example of how you handle enums with multiple groups in your examples section. |
Yeah it’ll probably be a | separator. Will update the proposal when I’m
next on a PC.
…On Mon, 16 Dec 2019 at 23:00, Jamie Madill ***@***.***> wrote:
How do you handle enums that are in more than one group? I imagine you
could use a separator token. Might want to include an example of this.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#335?email_source=notifications&email_token=ACVEYI4JHPOXWJUHY5MKM23QZACBBA5CNFSM4JW74LVKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEHANQBA#issuecomment-566286340>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACVEYI753EJ6Y5ZR7J5JAPDQZACBBANCNFSM4JW74LVA>
.
|
I'm fine with the change. I dont have these things in my mind since I wrote them 6 years ago but a quick look seems to indicate I'm not using It's even likely my parser won't need to be changed since as far as I understand the idea is to drop |
Alright have updated the proposal with the latest comments - thanks everyone for the help and co-operation btw, I understand that a lot of factors need to be considered when making such a huge change. I think at the moment I'm gonna hold out for some formal comments from the OpenGL Working Group next time they have a OpenGL(ES) meeting, will make a PR after. |
@oddhack @pdaniell-nv Has this been discussed in an OpenGL(ES) working group meeting yet, if not have you any idea when it will be (if at all)? |
I expect we'll talk about it once meetings resume in mid-January. Many people are not available during the holidays and no working group meetings are happening. This is probably not going to be an objectionable change to Khronos, but I expect we'll want to have more confidence that XML consumers won't be unpleasantly surprised - staging it by adding the new attributes first and getting rid of the group tags later is a good approach. I'm unsure how to effectively reach a wide audience, although we could do an announcement on opengl.org / khronos.org newsfeed and maybe get some of the more active social media API bloggers to mention it. I'm in favor of using , as the separator in the group attribute values, rather than |. |
Ah I didn't know they'd stopped for now. My apologies :|
Yeah I've tried to do that as best I can by tagging maintainers of known bindings libraries here on GitHub, but doing an announcement somewhere is probably needed to notify all downstream consumers.
Yeah Once this has been discussed in a working group meeting, I shall create a PR moving the group definitions to the new attribute, but leave the old blocks alone until given the green-light by the working group. |
Thanks for looping me in. My bindings actually process the man pages instead of using the xml schema (I didn't even know the xml existed). I'll look at using the xml schema in the future, but for now I am unaffected. |
Awesome, glad to hear :) |
@giawa be aware that the refpages are not a great place to get comprehensive API information from. They only go up to GL 4.5 and do not include extensions. |
@pdaniell-nv please put on the WG agenda when meetings start up again. I think this proposal has evolved far enough to be adoptable by us - there are some questions about how to transition from the old to the new schema but leaving the old group tags in place for a while should make this have low impact on XML consumers. The new attributes are likely to be ignored by existing consumers. |
Changes look good for cl-opengl, and I build bindings manually to edit new function names anyway, so transition doesn't matter too much for me. I notice the new patch adds the It might be a bit more work for the initial translation, but would possibly make it easier to check against extension specs if the groups for a specific extension were together. Might also be easier for extension writers, since they would presumably be adding the Doesn't seem like it would complicate it much for users of the xml, just possibly removing some duplicates if an enum is added by more than 1 extension or feature level. |
@Perksey I'm not too daunted from the GLEW point of view. It may break GLEW in some workflows, but my feeling is that comes with the territory. |
I don't have deep knowledge of associating XML schemas with XML documents, but https://www.w3.org/XML/2010/01/xml-model/ appears to bear on this. We could add some xml-model directives to gl.xml, although how to namespace minor iterations to the schema isn't entirely obvious. Perhaps the xml-model directive could refer to a github URL pointing at the latest update to the RNC schema at the time the document was edited. It would require some discipline whenever introducing changes to the schema as it's the sort of overhead that's easily forgotten, although if the changes break schema validation, CI could potentially catch it. |
Sounds like a plan. Will adjust the existing PR later on today.
…On Mon, 13 Jan 2020 at 01:41, Jon Leech ***@***.***> wrote:
I don't have deep knowledge of associating XML schemas with XML documents,
but https://www.w3.org/XML/2010/01/xml-model/ appears to bear on this. We
could add some xml-model directives to gl.xml, although how to namespace
minor iterations to the schema isn't entirely obvious. Perhaps the
xml-model directive could refer to a github URL pointing at the latest
update to the RNC schema at the time the document was edited. It would
require some discipline whenever introducing changes to the schema as it's
the sort of overhead that's easily forgotten, although if the changes break
schema validation, CI could potentially catch it.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#335?email_source=notifications&email_token=ACVEYI732VGS3B3OW54AYBDQ5PBEZA5CNFSM4JW74LVKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEIXKRUQ#issuecomment-573483218>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACVEYI2IIV2HGHDBQ5KNDUDQ5PBEZANCNFSM4JW74LVA>
.
|
From the perspective of libepoxy this change looks good; our XML → C dispatch generation only cares about If we wanted to change the enumeration symbol definition code, having the group(s) in the same element as the enumeration would definitely make it easier/more efficient, as opposed to generating a lookup table on the side, so the proposed change looks good to me. |
Awesome, glad to hear. There aren't a lot of downstream consumers of the XML that use the groupings but we want to ensure the few that do are ready for the change. |
Please note: I'd also like to start thinking of a rough timeframe for removing the old blocks to defer use & modification of them. I get this isn't something that can't be done very suddenly but now we've seen the extent of these changes, we should be able to come up with a rough idea of how long the old format will last - months? a year? multiple years? Perhaps this is something else that should be discussed at the working group meeting, although seeing as Khronos doesn't use the groupings themselves I'm not sure how useful that'll be without a bit of community input. |
My approach would be to keep the API as it is and generate the If right now the decision is to have breaking changes at any time (also in the future), might as well remove the |
We could do that, however that involves setting up the necessary infrastructure to have that automatically done and I'm not in a position to do that at the moment. I feel the |
I think we should allow around anywhere from 6 months to 1 year before we remove the old syntax to allow downstream dependencies in active development to adapt to the new syntax. Any project that doesn't update their copy of the spec within a year is probably dead anyway. This will probably need a little voice from the working group though. |
It's been a fair few months since the change was introduced and I think it's been a success - many thanks to Qualcomm for being a pioneer of this new system (which is exactly what I'd hoped to get out of this change: making it easier for official authors to introduce groups rather than them having to go far out of their way to introduce them) The next step would be announcing an official removal date for the old group blocks, which won't be easy. From this thread, I've gathered there are downstream consumers using the groups:
If you could let me know of your status in the transition, this could help inform a decision as to when the old syntax should be deprecated and removed, which will likely need to be discussed with the OpenGL(ES) Working Group but I want to make sure that the consumers we do know of are prepared before the WG move to schedule when/if they'll be removed. TL;DR lmk how your migrations to the group attributes are going - if you're all done then Khronos should probably decide when to remove the blocks. |
Glad has support for the new attributes, not much of a big change since I did not use them for codegen previously. |
OpenTK is using a fork of the spec for our current code generation, and our upcomming code generation is using the new onees, so not a big bias from here |
cl-opengl is OK with switching to group attributes, We are using a fork temporarily, and will switch to new format before next update (if I have any changes that need pushed upstream, I'd probably rather make them to the new format anyway). |
Ok cool, in which case the assignee of this issue should probably change to whoever is going to decide on the date of the old block removal (as currently it's still assigned to me) |
|
Awesome! |
The commit after that changes the schema, see: KhronosGroup/OpenGL-Registry#335 KhronosGroup/OpenGL-Registry#343 To follow these changes, we will need to massage the registry processor accordingly, but this will be done later.
Introduction
One thing that's annoyed me about the current XML schema is that the strongly-typed enum groupings are separate to the rest of the specification. Granted, they aren't that useful in C but downstream consumers (such as my Silk.NET library for C#) who are using the XML specification to bind OpenGL to languages that do better support strongly typed enums.
Today's problem
The problem with the group tags being separate is that there's a lesser emphasis on the correctness of the groupings. And, to be fair to the Khronos Group, I see why they wouldn't need to worry about the groupings as they don't use them themselves and, as such, won't want to dedicate cycles to ensuring the groupings' correctness.
I want to tackle this problem by merging the
<enum>
blocks and the<group>
blocks. If these structures are merged, it encourages spec editors to group the enums properly upon creating a new extension, and should hopefully solve the problem of invalid groupings going forward because if creating proper enum groups is a requirement upon vendors and extension writers, we won't have any group problems going forward.Solution in action
My proposed solution uses already established schema elements such that it wouldn't be too breaking for the Khronos Group themselves, but may affect downstream consumers. This is why I want to consult with these consumers so that we can establish whether this is a worthy enhancement to the spec.
Current syntax
Proposed Syntax
Pros
group="FirstGroup,SecondGroupINTEL"
)Cons
Proposed course of action
<group>
blocks will remain unchanged for now.<group>
blocks.<group>
blocks after as many enums have been grouped as possible.Closing
I understand that the groupings affect the Khronos group in no way shape or form, but this change matters plenty to downstream consumers that might be depending on the groups and this change will be doing them a favour in the long-term.
Thank you for reading and I hope you take this into consideration.
Version History
|
separator,
separator for token reuseStakeholders
OpenGLAda - @flyx
cl-opengl - @3b
CSGL - @thatonecheetah
opengl4csharp - @giawa
OpenGLDotNet - @carmack78
OpenGL.Net - @luca-piccioni
OpenTK - @varon @jvbsl @frederikja163
Silk.NET - myself @frederikja163 @AzyIsCool
dglOpenGL - @SaschaWillems
JOGL - @sgothel
LWJGL - @Spasi
LuaGL - @drahosp
glMLite - @fccm
ModernGL - @cprogrammer1994
PyOpenGLng - @FabriceSalvaire
Racket OpenGL - @stephanh42
Ruby OpenGL - @vaiorabbit
Please tag anyone I may have missed who might be impacted by this.
The text was updated successfully, but these errors were encountered: