-
-
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
Separate integer and real division operators in GDScript #1866
Comments
Confusion can be taught out of a person as they get more familiar with the tools they use. On the other hand scripting languages oft-times have a very inconsistent type coercion to achieve that "newb-friendliness" with varying degrees of success, mostly the type of success that backfires a lot. GDScript is clear of that for the most part, so I'd prefer it stays this way. Also, Python is not the only language that people come from, so I don't see why that would matter. |
I generally agree with you, but not in this particular case. In other (probably even most) other languages, the `/` operator behaves differently, regardless of whether it has `//` (or `div`) operator. So it's not just about those coming from Python. I also often say that GDScript is not Python, but this comparison cannot be avoided, since these languages are similar in syntax.
And besides, the problem is not only newbies not reading the documentation. The problem is that one `/` is acting as two different division operators. Let's be guided by objective facts, and not subjective love for one or another programming language.
|
It is not though. It just doesn't coerce the type of the return value unless you give it a clear indication that you need to do that. It's as straightforward as it gets, but maybe not obvious to a person that doesn't understand data types yet.
In dynamic languages, maybe. And granted, we have a somewhat dynamic language in GDScript here. But that doesn't mean we have to go into magical behavior to mirror classic maths. I'd prefer we stick to the rules of more strict languages so we have less chances to shoot ourselves in a foot. Also, shaders would still require you to keep this nuance in mind as they have stricter types. |
If I need mathematical division, I always use I don't see anything "magical". This works well in most dynamic languages and static languages too (for example, in Pascal).
Shaders are irrelevant to this issue. They are written in a completely different language, not GDScript. |
I don't see a point in adding // as you can very easily force a specific type onto them.. need result to be int? just do int(Arguments) and it'll spit an int |
Although I know about this trait in GDScript, I sometimes forget about it and when debugging I am surprised that the following code does not work: ceil(INT_EXPR / 2)
# And this is correct:
ceil(INT_EXPR / 2.0) It is better to explicitly use another operator when you need exactly integer division than to save on one character. |
I still see no point in adding // sorry. |
There is nothing you can do about it, as it often happens with major updates. If this is the only argument against it, then it doesn't sound convincing. Backward compatibility is not only good but also evil. |
read up, it isn't the only argument against it. it is one of the arguments but it isn't the only one and not the main one.
|
The discussion is looping, let's wait until more than 3 people take part in it. |
I think the current GDScript division behavior is fine as it is. I wouldn't break compatibility for something that is not guaranteed to be a win in all situations. |
Python deemed this important enough to break it going from Python 2 to 3. Having lived through exactly this transition I have to say it was absolutely worth it. Our code is clearer now in expressing the underlying intention and we face considerably less division based bugs. Since GDScript is heavily Python looking, it is confusing that it departs from it in that regard. I wasn't aware of it and assumed Python semantics so far. |
GDScript has nothing to do with Python besides being indentation-based as well. It's a misconception to think otherwise. Please, don't base your arguments on this, it's unrelated. |
Coming from GameMaker it briefly confused me too. Someone told me "most languages assume integers unless told otherwise" which I thought was a fine explanation. The argument being used in this thread should simply be that of standards. If we changed it, then instead of us it'd just be the other side getting the unexpected behaviour. Someone has to suffer. |
Once again, I don't want GDScript to be more Python-like. The problem is that in most languages We can just copy this one piece from Python. In all other aspects, we can still think differently. |
Where do you get this idea? This is not true for the majority, just for a specific group of languages. |
This is true for most scripting languages (JavaScript, PHP, Perl, Python, Lua, Dart, etc.). And GDScript is definitely a scripting language.
Yes, GDScript is not Python. But these languages are very similar. So it's no surprise that people expect these languages to work the same way with simple things like arithmetic operators. |
It does not matter what GDScript wants to be. Python is the highest ranked scripting language on the TIOBE index and currently on place 2 overall. This means that there is a majority of developers familiar with (and naturally assuming) Python semantics. So it is not just a matter of syntactic resemblance. Departing from the semantics of the most widely used scripting language offers a bug potential for all developers with such a background. It would be unwise to ignore this argument entirely. |
Int/Int also naturally assumes the output is desired to be Int 4 vars: a,b,c,d some function f1 does this and prints result somewhere later in the code in some function f2 This wouldn't be possible if / would force real division and // int division as the output would be float or int in both scenarios and this type of change where some variables aren't always the same type and expect to be treated differently is quite useful in quite a few scenarios.. True it's harder to keep track of constantly changing types, but working that around would make it much worse and would probably lead to plenty of Copied code left and right for every such case... meanwhile the workaround for your issues are simpler.. just turn one or both into a float if you want real division. |
Also if you don't want to do float() you can always go var1 as float/var2 instead of float(var1)/var2 if you want more readable code that is.. |
This is not the case in mathematics:
The situation is a bit similar with And I still do not understand what inconvenience (except for breaking compatibility) creates the separation of For example, Pascal is a statically typed language. However, it has No need to blindly copy the behavior of C/C++, Java, etc., especially since they are not scripting languages. |
Just read my example above. seperating would cause that use case to require quite a bit more code which isn't worth the small benefit of a seperation when that can be changed with a simple float() or with var as float. on the int/float and float/int you misunderstood me, and i've clarified it up in an edit.. I ment if both operands were same type not different types.. in mixed types it depends and goes like vector>float, float>int and the like. |
Nothing is clear from your example, sorry. |
It does. quite a bit. it isn't as simple as you think. the issue is you can't change between real division and int division at runtime with / and // the way you can with the current system, meaning you'd have to add lines of code to check if it's real division or int division that you are expecting, and that is in a SIMPLE setup... a more complex setup would require many more lines of code to deal with it.. magnitudes more in fact.. |
Explain what you want. This is a very strange formulation of the question. Give an example of a real-world problem that would require you to use the following function: func old_div(a, b):
if a is int and b is int:
return a // b
else:
return a / b |
This is still a pointless comparison. Python is a general purpose language and pretty irrelevant to the gamedev domain. GDScript is purpose built language that is bound by that domain. Int math is more relevant in gamedev than in general programming. And it is faster than any proposed alternative when you actually rely on it. And as I've mentioned before, people will still face that same behavior in our shader language. It doesn't matter where they will learn the importance of it, they inevitably will. This is the case where familiarity is not that important. If anything, familiarity within the domain will be quite different. |
This proves my point.. also you cherrypicked the quote, as the continuation explains and doesn't say this is impossible. This is 5 lines of code, + turning every / into a function, adding another 4-5 chars min per / not to mention the fact that the proposal can be worked around with only as few as 7 total chars per needed case (2 if it's a hard coded constant like in your examples above where you turn a 2 into 2.0 in a line of script instead of it being a var that is 2) I totally agree with #1866 (comment) |
Great calculations... You never gave an example of a case where you need this exotic behavior. In 99% of cases, either normal division or integer division is required, and not something incomprehensible, depending on the exact types of the operands. No matter how you think about it, division and integer division are two different operations and should not be combined. Those who do not agree with this can combine the sewer with the water supply. |
Division and Integer Division aren't 2 different operations, and thus don't need to be seperated. Note: using Ints/Floats as if a type of var is forced to float, 5 is still a valid float value and thus 5+5 can be Floats if the Vars are of the Float Type. |
@Wykleph It is impossible to keep everything in your head. I, a few people here and a few in the titter sometimes forget about this behavior and get bugs. No wonder. Tell me, do you enter 5.0/2 or 5/2 in your smartphone's calculator? (I won't fix the typo about twitter.) |
if you need to adapt then the language isn't intuitive. Imagine you come across this code sniped.
Can you seriously put a hand on a heart and swear to me that you are 100% certain that the intention of a person is to get
to return 1 not 1.25? Under new system code is more easy to ready
There is no ambiguity. Code is more intentional that way. Any argument against this is mostly "we are used to it that way". |
I think many here are way too emotionally invested in this discussion, so I'll lock it for a few days so we can all take time to chill. |
Sorry guys, I explained it as best as possible, so please try to understand it. The fact we are doing things this way already (with little to no complaining), and that there is strong opposition to changing it from a significant share of the users and core contributors (lack of consensus) makes this a no-go for the time being. Discussion on technical merit or whether users would adapt is irrelevant at this point. |
Closing due to lack of support – see the above discussion and reactions on OP. |
Sorry if this was suggested before (I didn't see it in this thread), but... Why not just introducing 2 new division operators and keeping the current behavior on If you don't like this, just ignore the new syntax. Your code will still work. I suggested
|
I just want to chime in with another voice toward this being a design flaw in GDScript that should be fixed. Let's take a moment to compare some real data using a smattering of languages:
My take away -- which matches my intuition regarding GDScript -- is that the common ground in handling of these expressions appears to be related to whether the target language has rigid typing or not. With the notable exception of Ruby, the more dynamic "scripting" type languages all seem to handle this the intuitive way because without a strong type system to tell you that you've done something wrong this behavior can be quite baffling. Based on the intentions of GDScript conveyed through its syntax and structure it seems clear to me that it has more in common with the languages that return floats than the ones that return ints, and it seems obvious that this should be the default behavior in a future version of Godot. It seems to me that in the rare case that the user actually wants integer division Consider one of the most basic practical cases that might be used in any game:
Please explain to me why this should return 0. |
Due to lack of consensus, the decision was made to keep the 3.x behavior. This cannot be revised for backwards compatibility reasons, at least in 4.x. Godot 5.0 is not expected in the next few years, so resuming the discussion will not be productive. This discussion is left unlocked only to allow users to add reactions on the comments. Please refrain from adding new comments here. Thanks for understanding! |
@dalexeev Apologies, my intention wasn't to revive a dead issue but I arrived here via a comment you yourself made on #5344 -- am I and future contributors to understand that discussion on this topic is simply not allowed at all? Is there a better place to gather support for this change? Either way thank you for responding and I will refrain from further discussion unless advised. |
Apologies for extending the discussion further. But can someone please explain to me why dividing an integer with an integer and assigning the result of an integer division into an integer should return a warning at all? Consider this example:
Perhaps Godot 4 could be updated to not output the warning in the case where the result is explicitly declared to be a integer? |
Repeating the above, please respect this:
Do not comment further here |
Describe the project you are working on:
A game
Describe the problem or limitation you are having in your project:
Describe the feature / enhancement and how it helps to overcome the problem or limitation:
I'm not a Python fanatic, but it seems to me that in this case GDScript should be consistent with it:
Arguments for:
5 / 2 == 2.5
(JavaScript, PHP, etc.). GDScript is a scripting language.5 / 2 == 2
, then2 * 2 == 5
.//
comments.Main argument: current behavior is bug prone.
If you have an
x / y
expression, you cannot tell which division will be performed: real or integer. To guarantee real you have to dofloat(x) / y
. To guarantee integer, you have to doint(x / y)
. See comment.Python once faced the same problem because is also a dynamically typed language. Version 3 has fixed this issue. See PEP 238.
See also these comments: one, two, three.
In addition, this change does not break compatibility as much as it might seem at first glance. See comment for details.
Describe how your proposal will work, with code, pseudocode, mockups, and/or diagrams:
See above.
If this enhancement will not be used often, can it be worked around with a few lines of script?:
No.
Is there a reason why this should be core and not an add-on in the asset library?:
Yes.
The text was updated successfully, but these errors were encountered: