-
-
Notifications
You must be signed in to change notification settings - Fork 138
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
The usage of python.args is inconsistent with Lua varargs semantics #182
Comments
Hmm. I don't really see this as a big issue. The To me, the Lua semantics look like a gotcha here (it loses data, after all), so I guess that once Lua users ran into them and learned about them, they'd probably expect them. But I don't see a requirement to follow Lua here. And I'm also not completely sure that we are "following Lua" here. I don't think the examples above are completely comparable. |
On the contrary, Lua users expect packed arguments to only be unpacked only if they're last, and bringing the Python behavior to Lua calls would be a source of unnecessary confusion, ergo a "gotcha". This is natural to Lua users: python.builtins.print(2, 3, python.args{4, 5, 6, sep=', '})
-- prints 2, 3, 4, 5 While this is not natural to Lua users: python.builtins.print(python.args{4, 5}, python.args{6, sep=', '})
-- prints 2, 3, 4, 5 In the use case you gave on #177, this would be even more dramatic: python.builtins.print(A, B, C, D)
-- currently, we need to know if A, B, C, D are python.args in order to estimate the number of positional arguments
-- in pure Lua, we only need to know if D is python.args to estimate the number of positional arguments (3 + #D) I reiterate here the importance of keeping Lua code natural to the Lua programmer. |
We can, of course, rename |
Introduction:
With the recent introduction of
python.args
, a subtle semantic defect relating to Lua varargs has leaked.Moreover, the performance of Python calls in Lua (with and without
python.args
) would be greatly improved as a side effect of a more restricted usage ofpython.args
.Reasoning:
Currently, in Lua, the ellipsis token (
...
) is used for representing varargs inside functions.Additionally, the
...
expression can be used in table constructors.However, with multiple varargs, only the last one is expanded.
Analogously, function calls also have their return values expanded.
However, with multiple function calls, only the last one is expanded.
In contrast, the current handling of
python.args
allows multiple instances to expand in the same call.Notice the dissonance between this example and the previous, in pure Lua.
Proposed solutions:
One option would be to expand
python.args
only if it is the last argument of a function call.This solution is most cohesive with the current Lua varargs semantics, since
python.args
would only be expanded if last.As a side bonus, detecting and handling
python.args
would have significant performance gains.A second option would be to restrict the usage of
python.args
for keyword arguments only.This would not clash with current Lua semantics, since it does not support keyword arguments.
Note that table unpacking is possible anyways with the
table.unpack
function in standard Lua, so we would not be loosing any functionality for unpacking positional arguments.Furthermore, this would also bring significant performance benefits to the current implementation of Python calls in Lua.
The text was updated successfully, but these errors were encountered: