-
Notifications
You must be signed in to change notification settings - Fork 942
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
Deprecate old variable actions and conditions in extensions #7406
base: master
Are you sure you want to change the base?
Conversation
- The extension variables must be used instead - Old extensions can be maintained by copy-pasting existing actions and conditions from the extension events
So I agree this improves the search (and some sort of improvement is needed), but this breaks the concept of functions and global variables Extensions are still the only way to realistically build your own functions, and functions need a way to access program-wide global variables (not just function variables). I'm not saying this change shouldn't be made, but there still needs to be a way to access globals (and potentially even scene variables) from within project specific functions, especially as that's also a standard expectation in base Javascript and most languages. This might also just be solvable by having the extension variable conditions/actions/etc be labeled as extension variables, or (probably preferably) having the project level variable conditions/actions/expression be renamed to specify External variables in their naming (rather than their path) within the extension editor. This is also important because passing the variables back and forth via parameters and duplicating globals inside project specific extensions triples the source code weight of each variable, and that increases even more if you have to pass the values once off via an action or condition (and makes it worse spaghetti code than it would be today) Again, to be clear: I still think a change is needed from current state, but it shouldn't be to remove needed functionality for project specific extensions. |
Technically:
I haven't use many languages but I've rarely seen variable used in a global context. I wouldn't even be able to say if it's possible or not even though I used these languages for years. For GDevelop, an expression is similar to a public read-only static class members. Modifying the same state from everywhere (scenes events and extensions events) is what is called spaghetti coding. It's very hard not to end-up in this situation even for trained coders. Languages usually give tools to avoid it. For GDevelop, I think that restricting variables to extensions is one of these tools. Note that, in extensions, there is still action and condition to access object variable that are used by scene events. We can't enforce usage of behaviors and properties yet because properties can't be structures nor arrays at the moment. |
Global scope variables used in functions/elsewhere in an app is relatively common in Javascript, at least when used in business apps, for the need to declare things at the global application or project level that will be used across scopes or in functions built by other developers. This is true even in strict mode in browsers: https://www.w3schools.com/js/js_scope.asp C++ has the same concept and usage as Javascript: https://www.geeksforgeeks.org/cpp-global-variables/ Lua has a similar concept, although it basically treats every variable as global unless explicitly set up as local: I agree with not accessing scene variables (the use cases for scene variables are very small), but the ability to access global variables from within project-specific extensions is pretty important. While I have a few specific use cases, the most common one I run across is setting up input functions.
Is it physically possible to accommodate this use case after your proposed change? Yes, but then you have to replicate the entire variable structure both in and outside of the extension, then set up events that pass the updated data back and forth, but that's an entire duplicated set of variables, and extra events to pass those variables back and forth on every scene, every time the key bindings are updated, or the game is loaded/saved, etc. |
It will avoid confusion when selecting external variable instructions by mistake (especially because there is a 8/9 chance to select them in the search).
data:image/s3,"s3://crabby-images/c3593/c3593465f8b959e0ed512735057fa26e1c016d58" alt="image"
These instructions were kept to help with the transition but they do more harm that good:
Variable()
andGlobalVariable()
when it's not used anywhere else