Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Inconsistent object field naming in Material for generic properties #2420

Open
spnda opened this issue Jun 28, 2024 · 7 comments
Open

Inconsistent object field naming in Material for generic properties #2420

spnda opened this issue Jun 28, 2024 · 7 comments
Assignees
Milestone

Comments

@spnda
Copy link

spnda commented Jun 28, 2024

The name, extras, and extensions fields exist on every object, in that order, and always at the end as the last fields. However, for the Material object these fields come first, as declared here in the JSON schema:

"name": { },
"extensions": { },
"extras": { },

Is there any reason for this inconsistency? I'm interested since I want to speed up the JSON deserialization in fastgltf by assuming a certain field order, that is consistent with the spec, when I can safely detect the asset was serialized using the library. And it feels wrong to me that these three fields appear at the beginning here instead of the end.

@lexaknyazev
Copy link
Member

RFC 8259 that defines JSON format says:

An object is an unordered collection of zero or more name/value pairs, where a name is a string and a value is a string, number, boolean, null, object, or array.

JSON parsing libraries have been observed to differ as to whether or not they make the ordering of object members visible to calling software. Implementations whose behavior does not depend on member ordering will be interoperable in the sense that they will not be affected by these differences.

glTF does not define (let alone require) any specific order of object properties.

@lexaknyazev
Copy link
Member

That said, we'll update the schema file for consistency.

@javagl
Copy link
Contributor

javagl commented Jun 28, 2024

It may be worth noting that these properties are actually not defined in the material, for example, but at

(which material is ""inheriting"" from, as far as one can say this for JSON schema...)

(EDIT: The point is that the order can even be different in the "base" definition and the ""inheriting"" one...)

@lexaknyazev lexaknyazev self-assigned this Jun 28, 2024
@lexaknyazev lexaknyazev added this to the 2.0.x milestone Jun 28, 2024
@spnda
Copy link
Author

spnda commented Jul 25, 2024

glTF does not define (let alone require) any specific order of object properties.

Is there any way I could put some hidden or meaningless tag somewhere into the glTF file that still conforms with the spec? I am planning on writing a Parser that would try and detect that tag, and then if it exists use a parser that is a lot quicker since it assumes a certain field order. Perhaps something in the Asset object, or some fake extension I could add to extensionsUsed like EXT_fastgltf_field_order? I still want the assets to be compatible with other loaders and tools, without them noticing this hidden tag.

@lexaknyazev
Copy link
Member

Assuming that the flag should be located as close as possible to the beginning of the file, I'd suggest adding something to the extras property of the root glTF object.

{
  "extras": {
    "fastgltfFieldOrder": true
  },
  "asset": {
    "version": "2.0"
  }
}

@spnda
Copy link
Author

spnda commented Jul 25, 2024

hmm though I am not sure how we'll that'd work in a generic library, since I currently just forward the extra object's JSON as a string to the user. And when exporting glTF's I essentially ask the user for the object string, and it'd be hard or at least a little hacky to add another field into that object... And what about other loaders... would they be fine with that extra field just existing? Is it the norm to ignore unknown fields when working with JSON? I don't know much of the glTF ecosystem and quirks of JSON loaders apart from what exists for C++.

@lexaknyazev
Copy link
Member

The spec explicitly defines extras as a place for application-specific data, thus it's valid for it to have any value.

# for free to join this conversation on GitHub. Already have an account? # to comment
Projects
None yet
Development

No branches or pull requests

3 participants