What? I agree with function[T] style generics, and would be willing to change the access syntax to something like container.[index], as the dot makes the difference quite clear.
Or do you mean the approach to implementing a container or the way the compiler has to transform it into the set operation/mutable access? I didn’t think that was such a problem, and I quite like the way it is done in rust, but that approach may be unavailable to many languages.
Some functions also don’t have any parentheses, like field access or infix operators.
Who wants to write
sqrt(p.x*p.x+p.y*p.y)
when they could write
sqrt(p.getX().square().add(p.getY().square()))
or even
sqrt(add(square(getX(p)), square(getX(p))))
We could follow this line of thinking further and arrive at an ugly haskell-like language without pattern matching (because that is an artificial distinction between data in a record and data that can be derived from a record) or operators and barely more enjoyable to write that lambda calculus.
Some functions also don’t have any parentheses, like field access or infix operators.
You call things the way they were defined. Problem solved.
I’m kinda confused, because this is the second time now where your attempt at making a counter argument is actively supporting my point.
Is this intentional at your part?
We could follow this line of thinking further …
No we don’t. If your point relies on Turing-tarpitting the whole discussion … then you have no point.
You call things the way they were defined. Problem solved.
What?
I’m kinda confused, because this is the second time now where your attempt at making a counter argument is actively supporting my point. Is this intentional at your part?
We are ultimately arguing about subjective preferences. I favor of certain syntactic sugar because I believe it improves readability while you seem to be arguing for strict consistency above all else.
So by what metric are we measuring our points?
No we don’t. If your point relies on Turing-tarpitting the whole discussion … then you have no point.
I admit, that was hyperbolic, but I don’t see what syntax for data manipulation other than functions would be left in your ideal language.
What? I agree with
function[T]
style generics, and would be willing to change the access syntax to something likecontainer.[index]
, as the dot makes the difference quite clear. Or do you mean the approach to implementing a container or the way the compiler has to transform it into the set operation/mutable access? I didn’t think that was such a problem, and I quite like the way it is done in rust, but that approach may be unavailable to many languages.That’s still a workaround to try and keep a completely artificial distinction alive.
Even if I didn’t need
[]
for types, I still wouldn’t want “some functions use()
, some functions use[]
” as a language rule.Some functions also don’t have any parentheses, like field access or infix operators.
Who wants to write
sqrt(p.x*p.x+p.y*p.y)
when they could write
sqrt(p.getX().square().add(p.getY().square()))
or even
sqrt(add(square(getX(p)), square(getX(p))))
We could follow this line of thinking further and arrive at an ugly haskell-like language without pattern matching (because that is an artificial distinction between data in a record and data that can be derived from a record) or operators and barely more enjoyable to write that lambda calculus.
You call things the way they were defined. Problem solved.
I’m kinda confused, because this is the second time now where your attempt at making a counter argument is actively supporting my point. Is this intentional at your part?
No we don’t. If your point relies on Turing-tarpitting the whole discussion … then you have no point.
What?
We are ultimately arguing about subjective preferences. I favor of certain syntactic sugar because I believe it improves readability while you seem to be arguing for strict consistency above all else.
So by what metric are we measuring our points?
I admit, that was hyperbolic, but I don’t see what syntax for data manipulation other than functions would be left in your ideal language.