Skip to content
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

Better TypeId #209

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from
Draft

Better TypeId #209

wants to merge 3 commits into from

Conversation

oscartbeaumont
Copy link
Member

@oscartbeaumont oscartbeaumont commented Dec 25, 2023

Hack around the 'static bound on Rust's built-in TypeId to allow the ID to be tied to a compiler intrinsic instead of the implementation location of the macro like it currently issues.

Issues blocking merge:

  • Lack of const traits or a workaround a non 'static TypeId without them
  • or remove NamedType::SID which I could see happening.

oscartbeaumont added a commit that referenced this pull request Dec 25, 2023
@oscartbeaumont
Copy link
Member Author

SomeGenericType<A> and SomeGenericType<B> will have a different TypeID which from a Rust language perspective makes sense but Specta can't work with that so this probally isn't going to be possible.

@indietyp
Copy link

How about something like: https://play.rust-lang.org/?version=stable&mode=debug&edition=2021&gist=d0c96326c80dbadb1cd688a570040b03 ?

The idea comes from an issue I read on StableTypeId in bevy (bevyengine/bevy#32). The note in the type_name is quite important here: https://doc.rust-lang.org/std/any/fn.type_name.html

@oscartbeaumont
Copy link
Member Author

I considered it but I don't think it's a good idea.

The returned string must not be considered to be a unique identifier of a type as multiple types may map to the same type name.

Taken from the Rust docs for type_name.

fyi, different versions of a single crate can be included in a dependency tree, so even without plugin loading I believe you can have multiple types with the same type_name but different layouts :/

From here

I would suspect this would be a problem. Rust also reserve the right to change the output of type_name so I don't love the idea of relying on it so crucially.

@oscartbeaumont
Copy link
Member Author

oscartbeaumont commented Dec 26, 2023

The more I think about it I suspect the current implementation of SpectaID would break if you have multiple of the same crate, however, that's an easy fix so I still see it as a problem.

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

Successfully merging this pull request may close these issues.

2 participants