-
-
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
Introduce a variable-free loop #1282
Comments
I would rather prefer to enable the standard pattern from Python: for _ in range(10):
add_child(scene) Unfortunately currently The benefits would be:
Also,
In Nim this would be forbidden: let (a, _, c) = (1, 2, 3)
# works
echo a, c
# not allowed: `_` isn't a variable binding
echo _ |
Now you can do this: for _i in range(amount):
add_child(scene) or this: for _i in amount:
add_child(scene) Some programming languages have special syntax for this case. |
@dalexeev You can also use |
@Calinou The following code for __ in 5:
print('---')
for __ in 7:
print('*') will throw the error: And this will work: for _i in 5:
print('---')
for _j in 7:
print('*') With Basically, I like for _ in 5: ...
for _ in range(5): ...
for _ in range(0, 5): ...
for _ in range(1, 6): ...
for _ in range(2, 7): ...
... That is, we only care about the number of repetitions. So we could replace "for _ in" with something else. Possible options:
|
Does it harm readability to call the variable |
I'm not very familiar with Python, but I also think the
Is this a common pattern? It seems really hacky and not intuitive at all. I need to backtrack my knowledge of
Not really, I guess. But underscore or not, there is still an unused variable there. You have only solved the problem by sweeping the variable under the carpet by putting the underscore in front of it, so to speak. I've read that gdscript was designed with ease of use for beginners in mind and managing unused variables and underscores seem to go against that philosophy. To add to dalexeev's list of possible options is a variant of # 1, to only use
|
I don't think adding new keywords always makes a language easier to learn. Sometimes, it can be the opposite. Instead, relying on "emergent" feature usage can make more sense (which is pretty much what single-underscore variables are about). |
And why is it wrong if the whole point of this proposal is getting rid of the warning? It's definitely not worth adding a new keyword or special syntax for this specific case.
Warnings can be easily disabled. Personally I find majority of them useless. |
This is a matter of semantics. All loops are implemented using GOTO. Personally, I would also add infinite loop (instead of # Loop of n iterations
loop 5:
print("*")
# Infinite loop
loop:
...
if cond: break
... |
The warnings are a symptom of the problem, which is that I am being forced to introduce a variable that I will never use. It is an awkward solution in my eyes and it feels like I'm hacking how ´for´is meant to work in gdscript. |
@masi456 Feel free to open a pull request for this 🙂 |
The documentation on this one seems to be out of date. It says:
Going strictly after the doc, |
@masi456 It's kind of a special case here. Did you figure out a way to make |
@Calinou as far as I saw yesterday, both would be possible, but only implementing it for the special case would be easier. I may need to re-check this. The question is, what would be the preferred way of handling this? |
Note that the goal should not be to make for _ in range(3):
for _ in range(3):
print("do it") By applying the same behavior to normal variable bindings, this would enable a new more concise pattern of discarding return values without having to introduce dummy return variables to silence the "unused return value" warning: var _ = function_call()
var _ = function_call() Here it would be similarly more convenient if the |
It's better: _ = function_call()
_ = function_call() |
@dalexeev Yes that is a good option as well. Perhaps requiring the var a, _ = returns_pair() |
I think another solution is to just treat the "Unused for loop variables" on the GDScript warnings level (either ignore completely or introduce another type of warning), IMO. To be honest, the existing warning system makes people come up with various hacks and workarounds on the script level just to avoid them currently, which worsens readability of scripts with enabled warnings... |
@Xrayez I would prefer keeping the warning for unused loop variables as it can be used to catch actual bugs in code. I think adding a variable-free loop is a better way to handle the problem here. |
The |
var amount = 10
for amount:
something() or will it be unreasonably difficult to implement/parse? |
@me2beats I have already suggested this above, as one of the options. I don’t think it’s difficult to implement. The only question is how readable it is and whether it is necessary. The good thing about this option is that it doesn't require a new keyword. for i in arr: ...
for i in range(a, b): ...
for i in n: ...
for n: ... |
Describe the project you are working on:
Platformer game
Describe the problem or limitation you are having in your project:
Very often I will use for loops to do the same task several times and not to iterate through data sets. For example when spawning many scenes at once (bullets or enemies). I will use a for loop for this:
This is fine but it will generate a warning about the 'i' not being used, which quickly clutter up the warnings list.
Describe the feature / enhancement and how it helps to overcome the problem or limitation:
Introduce a variable free loop for these scenarios. It will work like a normal for-loop only there is no loose variable that is never used. A user will only state how many times the loop will run.
Describe how your proposal will work, with code, pseudocode, mockups, and/or diagrams:
Something like this:
If this enhancement will not be used often, can it be worked around with a few lines of script?:
You can skip the warning by putting an underscore in front of the variable. However, there is something with introducing a variable that is not used for anything that doesn't sit right with me. A variable free loop that basically works as a counter seems cleaner.
Is there a reason why this should be core and not an add-on in the asset library?:
Change in gdscript
The text was updated successfully, but these errors were encountered: