| > But when you don't want it, wrap the call: [...] And now you know how to prevent this class of bug. Catching it in an intermediate variable is possible but by no means necessary. Well, I knew that; in fact what I've linked in the past discussion was the exact code to handle this case in my type checker. It is seriously confusing that a seemingly excess parenthesis affects the code anyway, and you can't exactly know whether the parenthesis is necessary or not without using a type checker. There are some other languages that have multiple returns and can pass multiple arguments for nested calls, notably Go, but Go only does that when the inner call is the sole argument to the outer call. And Go does have a type system. Tons of other languages including JavaScript have an explicit "spread" operator which mostly retains the usability and avoids such problems. > Which is surprising! you'd think f(a,b) and f(a,b,nil) would be the same thing, and usually, they are. But not in this one case. Or any C function relying on lua_gettop. Seriously, nil should have eliminated in that stack. > I'll let you reason about what it does, and why it would be such a pain in the butt with regular expressions. I don't like a quirky EDSL alternative to the regular expression (or what it matters, parsing expression grammars) either. I prefer lpeg.re in that regard. local re = require "re"
local long_str = re.compile(
[[
end_str <- ']' '='* ']'
long_str <- {| ((!end_str .)+ ({} end_str {}) -> disp)+ |}
]],
{
disp = function (first, last)
return last - first - 2
end,
})
Lpeg itself is a fine library, but its use of 1 as anything or -1 as the end of string is annoying (at the very least `lpeg.P(-1)` should have been `lpeg.Eos` instead). I would still use lpeg proper for constructing patterns programatically.But you can't give lpeg as an answer to string.gsub and so on. First, the standard library still remains problematic and people will get tripped up (if you have no room for implementing `|`, one can require that `|` is escaped, m'kay?). Second, it's not a default, or at least not what you can easily `require`. The Lua ecosystem is fragmented primarily by not having a universally usable package system (I stress that LuaRocks is not) thus an external library is not always an option. By the way I don't know why you would want to give that obscure example to brag about Lua. Your code is in fact slightly incorrect: `(L.Cp() ...) / _disp` looks like that the capture is applied only to that parenthesis but it's not, thanks to the operator precedence. The main problem of regular expressions is an inability to refactor and you haven't correctly demonstrated that. |
So a deficiency in your code, you chose to blame the language.
That's a you problem.
> I don't like a quirky EDSL
A you problem
> I prefer lpeg.re
So Lua offers two superior ways to process strings over one? and you're still mad? Sounds like a
> But you can't give lpeg as an answer
Ah but I did. You just don't like it, which is, you guessed it, a you problem.
Ierusalimchy wrote lpeg specifically to address known deficiencies in the pattern library.
Sure, you can't always use it. Just like you might be stuck on an obsolete version of JS in an embedded system.
But this is neither Lua's problem, nor my problem. It might be your problem. I'm beginning to detect a pattern!
> Your code is in fact slightly incorrect
It is, in fact, not.
I recognize the trope here. Happily, I'm in a position to fire people who show it, and have.
In your case, I'll have to be content with never interacting with you again.