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

gltf-json 1.3 breaks semver #385

Open
Ralith opened this issue Aug 27, 2023 · 3 comments
Open

gltf-json 1.3 breaks semver #385

Ralith opened this issue Aug 27, 2023 · 3 comments

Comments

@Ralith
Copy link
Contributor

Ralith commented Aug 27, 2023

#381 changed the type of a public field without bumping the major version number of gltf-json. This broke my code.

@kpreid
Copy link
Contributor

kpreid commented Aug 27, 2023

The same change also broke my glTF export code. I'm aware that this is an intentional choice regarding the versioning of gltf-json, but I'd like to ask you to reconsider it in the future. As far as I'm aware, the only way to generate glTF files (without writing a set of serde structure types from scratch) is to depend directly on gltf-json and use its structure fields.

@kpreid
Copy link
Contributor

kpreid commented Dec 17, 2023

And with the latest release I'm reminded of more ways this is a problem: if something in the dependency graph starts to depend on a newer gltf-json, and gltf is also in the graph but nothing depends on the latest version, then Cargo will update gltf-json without gltf, producing a broken build.

Please start using accurate semver for gltf-json — any time a type is changed incompatibly etc., its major version must be bumped. (Yes, this means it must go out of sync with gltf. But at least until gltf 2.0.0 comes along, you can have gltf 1.5 paired with gltf-json 5.0.0 and so on.)

https://crates.io/crates/cargo-semver-checks can help validate that the version is properly incremented when changes occur.

@alteous
Copy link
Member

alteous commented Dec 17, 2023

Okay I see this situation is clearly irritating lots of people. I will make the next release 2.0, ensure the semantic versioning applies to the underlying data structures thereon. This will likely entail merging gltf-json with the main crate. cargo-semver-checks is a good suggestion.

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

No branches or pull requests

3 participants