-
-
Notifications
You must be signed in to change notification settings - Fork 97
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
Add support for typed WeakRefs to GDScript #9174
Comments
Exploring some possible implementations with the typed array style solution, will see if it leads anywhere as a start |
See also:
I think to implement this properly we would at least need some refactoring of I think that for a proper implementation we would need a unified type system with first class types (the type whose values represent types). This will allow nested types (like |
Managed some basic ideas for this on the C++ side but got bogged down trying to work with some other ideas, I still consider it relevant but I found my original use case less critical when looking at implementations, so this much broader generics and deeper systems for it feels more appropriate as I feel the original need for the weak references in this fashion to be less urgent as such, and looking forward to future improvements of the generics, with a unified type system! Thank you for your feedback, and hopefully we can find a more unified proposal idea for this, I'd love for this idea to be part of a wider system, even if it does mean delaying it Since exporting |
Out of curiosity I went around and checked what other Object classifies as a container, and could possibly be typed in the API to justify something more feature-complete in... some future. There isn't actually much. PackedScene and WeakRef are outliers. For your interest, it really is a stretch. PackedDataContainer, TileSetScenesCollectionSource, MeshLibrary... |
How could I have been so stupid!? InstancePlaceholder would GREATLY benefit from this, too. |
WeakRef
Just to throw my $0.02 in here, I'd find this useful for situations like one I'm in now. I'm using a SubViewport with a 3D scene to handle some diagetic UI stuff, but I am also passing back references to the Node3Ds within that scene to the "parent" world scripts to do some un-projecting for additional UI shenanigans. This sort of bridging is naturally risky and I naturally want to play it safe and have a simple GD script "handle" class that has typed WeakRefs to all the things I'm passing between the two worlds but as it stands I just have to clumsily cast-by-convention. Not a big deal and getters can make this mostly a non-issue, but is a potentially useful example where I'm working around gdscript here instead of with it. |
Describe the project you are working on
N/A
Describe the problem or limitation you are having in your project
WeakRef
is great in a lot of ways and saves a lot of work, however they are a bit cryptic in their usage and can be hard to use, and they are especially bad for code readability and conveying intent.Describe the feature / enhancement and how it helps to overcome the problem or limitation
A new syntactic sugar feature for GDScript which would be
WeakRef[T]
, this would both be a symbolic feature, indicating intent to someone reading the code, and also be enforced on assignment, at least by the analyzer or in the editor/debug builds. It would also provide static type hinting when using theget_ref
method, if desired we could also make theweakref
method able to hint at the result type as well if the argument is typed, sovar my_ref := weakref(foo)
would be typedWeakRef[Foo]
iffoo
was typed asFoo
.See also #7363 for discussion on exporting
WeakRef
and related, where this would also be useful for various aspects of this. With the possibility also of syntactic sugar for a weak export, see #7363 (comment) for details.Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
This would be a parsing and compilation feature of GDScript, some form of metadata on the associated variables, and analyzer code. It could also be enforced more strongly on other levels with the VM and similar.
Some question marks I have are how we would handle assignment from other
WeakRef
s, hownull
would be treated, and similar, but those are aspects I think would be part of working out how to implement it and use it.The above suggestion for syntactic sugar for exports would also be an optional alternative solution to this, as
WeakRef
is more relevant IMO in exports than using them as local variables, and in that case the loss of readability and intent is less significant.It could also be a higher level feature in C++ as well, with some
template <T> TypedWeakRef : public WeakRef
with associated typing management, if needed, that would make the GDScript side of things less critical and would use methods similar to howTypedArray
works, but sinceWeakRef
is used much less on the C++ side of the engine this would be less critical, though it would be more powerful, and again provide the same benefits. Though this isn't possible in the current engine architecture due to class bindings with templates.The solution might be to add typing features to
WeakRef
like we have forArray
, I suspect that would be the most convenient method in the end.If this enhancement will not be used often, can it be worked around with a few lines of script?
It can be worked around by adding code comments, but that isn't very clear or clean.
Is there a reason why this should be core and not an add-on in the asset library?
It is a core feature of GDScript.
The text was updated successfully, but these errors were encountered: