OK, say that we have this and that it is implemented as something like
alias -> proc
and that we do
def proc
puts "boom! proc not available any more!"
end
then
p = -> { puts "lambda-the-ultimate!" }
p.call
lambda-the-ultimate!
q = proc { puts "lambda-the-ultimate!" }
boom! proc not available any more!
q.call
NoMethodError: undefined method `call' for nil:NilClass
so, as it's easily enough to override the meaning of 'proc', why should
'->' be any different? Sure, the one big problem is that all methods
have the same precedence and that you can't override it in any way. If
you would redefine built-in operators, you wouldn't be able to change
their precedence either and it would mess with the whole "all
user-defined operators have the same precedence rule", _if_ there is
such a rule. So perhaps not all user-defined operators should have the
same precedence. Either don't add this rule, but keep all new operators
(defined by the user) on a separate level, or allow the user to set the
precedence of operators. Again, complications arise in the parsing when
things change precedence, but that's another problem.
That should be a trivial patch to the patch, if that seems to increase
the net happiness of the world. If others speak in favor of the idea
I'll work it up (*smile* or you are of course free to try your hand at
it if you prefer).
Yes, but it detracts from the whole point of adding the capabilities of
this patch. The point isn't to make user-defined operators different
from built-in ones, the point is to make them indistinguishable from
them - to allow us, as programmers, to work in the same namespace as
matz or any of the language designers. This worries some people, but
I personally don't see an good reason for worry, if done correctly (i.e.
not introducing bugs or breakage). Remember, Ruby allows you to add and
redefine methods in base classes, so if you want to wreak havoc, the
tools are readily available even without user-defined operators.
Sure, I can see the problem of adding new operators to the core language
contra user-defined ones, yet this can be handled in a similar manner to
that of how any incompatibilities between lanugage revisions seem to be
handled - major versions. So in Ruby 2.0 there will be a set of new
operators, perhaps '->' for lambda, among other things such as new
methods in new base classes. Then, the user is free to alter them and
add new operators, methods and classes as they see fit. Once enough
momentum is gathered, Ruby 3.0 is released with a new set of new
operators, and so on and so on. Sure, you might not want to go down the
road of "no backwards compatibility", but I believe I read somewhere
that Ruby 2.0 won't be backwards compatible either way,
nikolai