-
Notifications
You must be signed in to change notification settings - Fork 128
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
Rework for version 2.0 #422
base: main
Are you sure you want to change the base?
Conversation
Fix tests Simplify json::animation module Simplify json::buffer module Simpify json::camera module Simpify json::extensions::scene module Simpify json::material module Simplify json::mesh module Simplify json::mesh module Simplify json::texture module Remove json::validation::Checked enum Replace unnecessary macro Merge gltf-json crate into gltf crate Simplify json::camera module some more Add stub wrapper code Trial generating wrapper code Replace Void type with IgnoredAny Remove unused Primitive type Add wrap_indexed extension Remove unnecessary const Add custom (de)serialization macros Remove accessor extensions Remove animation extensions Remove asset extensions Remove buffer extensions Remove image extensions Remove skin extensions Insert serde attributes automatically for Option Insert serde attributes automatically for Vec Test and fix auto camel case fields Add tests for gltf(extension) attribute Fix doc test builds Temporarily remove extras feature Refactor asset Temporarily remove names feature Refactor buffer Insert serde attributes automatically for bool Refactor accessor Refactor animation Refactor camera Refactor image Add default field attribute and derive macro Refactor material Refactor scene and root Refactor texture Refactor material and mesh Refactor skin Remove re-exports of serde_json functions Refactor remaining modules The giant hoist Move Wrap trait into its own module Refactor lib.rs Implement Index and IndexMut for Root Test camera projection Rename accessor::Type as AttributeType Remove leftovers Add fallback for unrecognized extensions Refactor import
d73c626
to
fcc59f5
Compare
As someone interested in the 2.0 plan, and with an application that exports to glTF, I tried out this branch, and here are my observations:
|
@kpreid thanks for trying it out and providing feedback so quick! 😄
Regarding #[derive(Debug)]
#[non_exhaustive]
pub struct Example {
pub index: usize,
pub required: i32,
pub optional: Option<i32>,
}
impl Example {
pub fn base(index: usize, required: i32) -> Self {
Self {
index,
required,
optional: None,
}
}
} #[test]
fn exhaustive() {
let example = lib::Example {
index: 123,
optional: Some(456),
required: 789,
};
println!("{example:#?}");
}
#[test]
fn non_exhaustive() {
let example = lib::Example {
optional: Some(456),
..lib::Example::base(123, 456)
};
println!("{example:#?}");
} I'm not sure about the ergonomics of this approach though. |
* Replace `buffer::Stride` with `usize` * Avoid serializing `buffer::View::offset` Additional changes: * Rename validate_hook as validate * Allow `#[gltf(validate = "...")]` to be applied to fields * Remove remaining gltf-json code * Document `gltf_derive::Default` macro * Document `gltf_derive::Validate` hook
Changing a type alias would be a non-additive feature (regardless of the direction it goes; both widening and narrowing can break code), which becomes a hazard for any use of
That all makes sense. I just wanted to ensure you'd considered the option when designing 2.0. I personally wouldn't mind the “base constructor” design, but my preferences tend to rigor over convenience. |
I've given the base constructor a go and it's really not ideal. Here are excerpts of some real code that uses my prototype: root.push(
gltf_ext::buffer::View {
stride: Some(vertex_size),
target: Some(gltf_ext::buffer::Target::ArrayBuffer),
..gltf_ext::buffer::View::new(
buffer,
vertex_buffer_view_size,
)
},
); root.push(
gltf_ext::Accessor {
buffer_view: Some(vertex_buffer_view),
count: num_vertices.into(),
component_type: gltf_ext::accessor::ComponentType::F32,
extras: Default::default(),
attribute_type:gltf_ext::accessor::AttributeType::Vec3,
min: Some(json!(bbox.min())),
max: Some(json!(bbox.max())),
..gltf_ext::Accessor::packed(
gltf_ext::accessor::AttributeType::Vec3,
gltf_ext::accessor::ComponentType::F32,
vertex_buffer_view,
0u64.into(),
num_vertices.into(),
)
},
); What I don't like about it is it's unclear what fields are being initialised by the base constructor. It provides limited 'safety' in that there will be fields that need to be set or not set depending on context. I haven't been able to think of a simple solution to work |
Unfortunately, while this strategy satisfies semver, it violates feature additivity. Example: if
then |
Ah, you're totally right. In that case, I might have to abandon the one data structure approach and go back to having separate structs for core fields and extensions. |
A friend of mine suggested to avoid the semver issue by making a major version release each time a new extension is added. I think it kind of defeats the point of semver in the first place but it would solve this backward compatibility issue. |
I notice that in the current state of the branch (9b8bc87), — On the other hand, considering all of the field trouble, maybe an overall better answer is to just make every struct |
Somewhat off-topic but related, but it might be worth using cargo-hack with |
No description provided.