-
Notifications
You must be signed in to change notification settings - Fork 109
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
final
as new keyword
#700
Comments
what would it do if the target isn't lua5.4? |
quoted from https://github.com/teal-language/tl/blob/master/docs/tutorial.md#const-variables
|
I have restrained myself from making purely cosmetic changes/additions to the "Lua parts of the language" so far, and I don't have immediate plans to change this. But if I were to do this, I'd probably just name it |
For an example (with a small module) of the tedious syntax of annotation, see |
I read the previous comments, 5.1 const can just throw an error if you do something dumb, const could be noice for functions too! Like if you want function(test: const number)
test = test + 1
end would throw an error like |
For my two cents I think it'd be a great value add if Teal could have some way of enforcing immutability of compound types when so desired, in whatever way seems most appropriate. Even if only by declaring a reference variable as immutable. In other words an object can only be mutated through a mutable reference. And mutable reference can be assigned to an immutable reference, but not the other way around (except perhaps by an explicit cast but then at least you know it's not an accident). Something like that. Simple but effective. It's just nice to know when the compiler can catch unintended mutations when there shouldn't be any. |
Just my feedback: I don't think adding custom syntax just to be C-like is a good idea, and being honest, I did found the Anyway, I'm just saying this because I don't believe adding syntax sugar to get a C-like syntax worth the complexity and maintenance cost to Teal, in my opinion. I do however find interesting the idea of adding it's own annotations or expand it's capabilities, like
I can see fperrad point though, this is currently possible: local function add(x: integer, y: integer): integer
return x + y
end
add = assert -- oops!
print(add(5, 10)) And this is only way to avoid such thing I suppose, which doesn't seems elegant: local add <const> = function(x: integer, y: integer): integer
return x + y
end
add = assert -- error: test.tl:5:1: cannot assign to <const> variable
print(add(5, 10)) If we re-use Nelua syntax here (which the syntax for annotations is a bit different IIRC), it could be: local function add(x: integer, y: integer): integer <const> maybe this could be a possible option? Another possibility is making functions |
Lua 5.4 & Teal support the
<const>
annotation. That allows immutable variable.But for large use, the annotation syntax is ugly and too long.
My proposal is just a sugar syntax based on a new keyword
final
:final foo = something
-->local foo <const> = something
final fn() end
-->local fn <const> = function() end
The text was updated successfully, but these errors were encountered: