Remix.run Logo
austin-cheney 4 days ago

I love that you are using colon for the assignment operator. This is absolutely correct. Most languages use the equal sign as the assignment operator in most contexts and then the colon in limited contexts. This comes from Fortan and its just wrong. The equal sign should be reserved for comparisons, because that is what it means in mathematics.

jasperry 4 days ago | parent | next [-]

To push back a little: Designing the syntax of a programming language always involves tradeoffs; nothing is "just wrong". For better or worse, equal sign as assignment has become widely used and understood. I think the author's use of colon is neat, but it is confusing if you're used to seeing that as the type indicator; again, a tradeoff. I like the look of := as the assignment operator but it adds another shifted key to type, which can push you that much closer to RSI for such a common operation.

znkr 4 days ago | parent | prev | next [-]

> The equal sign should be reserved for comparisons, because that is what it means in mathematics.

This is touching on a pet peeve of mine: Mathematics and programming are similar in many aspects, but this is not one of them. In mathematics = is not a comparison, but a statement.

More generally, mathematics is about tautologies, that is statements that are always true. In programming, a comparison is evaluated to either true or false.

That doesn’t mean that there’s no room for conditionals in mathematics (one example is piecewise function definitions). But it’s not the same. Heck, even the definition of “function” is different between mathematics and programming.

mastermage 3 days ago | parent [-]

That's why procedure is so much better of a name. It's not a hill I'm willing to die on but I think it's correct.

jasperry 3 days ago | parent | next [-]

Seconded. Languages could even use "function" only for pure functions and "procedure" for everything else. Pascal uses "procedure" for things that don't return a value, but I think the pure vs. side effect distinction is more useful.

austin-cheney 3 days ago | parent [-]

In languages that have block scope a procedure is that block. It’s a boundary but receives no input and does not return output. Functions do allow input and do return output. This distinction is clear in C lang that has both functions and procedures.

As a new language design feature procedures could be assigned to references for reuse in the same way as calling a function by name/variable.

jasperry 3 days ago | parent [-]

I've never heard of blocks in block-scoped languages being called procedures. I feel like the word "block" is well understood and serves the purpose fine. In lots of other languages, things called procedures do take input, like Ruby, which has first-class Procs like you mentioned.

ffsm8 3 days ago | parent | prev [-]

And let's use the keyword "go-to" to run a function, back to the basics basically ಥ ‿ ಥ

mastermage 3 days ago | parent [-]

ok maybe not that, that was awful.

gucci-on-fleek 4 days ago | parent | prev | next [-]

> The equal sign should be reserved for comparisons, because that is what it means in mathematics.

"let x = 1" has the same meaning in mathematics as well as JavaScript and Rust.

yawaramin 4 days ago | parent [-]

In Rust yes, in JavaScript not really.

qayxc 4 days ago | parent [-]

In JS it would be const x = 1, which would be equivalent again.

AdieuToLogic 4 days ago | parent | prev | next [-]

> I love that you are using colon for the assignment operator. This is absolutely correct.

Historically, distinguishing an equality operator from an assignment one has existed for many decades. Whether using colon for the latter is "absolutely correct" is the subject of valid debate.

An equally compelling case could be made for any of the following assignment operators as well:

  foo <- 42
  foo -> 42
  foo <= 42
  foo => 42
  foo <-> 42   if expressing substitutability is important
  foo := 42    Pascal lives!
  (foo 42)     so does LISP!
  foo is 42    for those who prefer English operators
  f(foo) = 42  for mathematically inclined languages
Etcetera
dist1ll 4 days ago | parent | prev | next [-]

> because that is what it means in mathematics

Personally, I think this argument only holds water for languages that are rooted in mathematics (e.g. Haskell, Lean, Rocq, F*, ...). If your computational model comes from a place of physical hardware, instructions, registers, memory etc. you're going to end up with something very different than an abstract machine based on lambda calculus. Both valid ways to design a PL.

agalunar 4 days ago | parent | prev | next [-]

I’d argue there’s a very big difference between “x: y” and “x : y”. I can only see the former as assignment and the latter as the has-type relation.

(I find it baffling in the extreme that in many mainstream languages the convention is to write type annotations as “x: T”, both prima facie and because in those languages the notation then collides with field assignment!)

bluecalm 4 days ago | parent | prev | next [-]

Mathematics, famous for consistent readable notation. Next idea should be to just stop declaring variables at all assuming they mean what they usually mean in similar programs. Starting array indexes from 1 instead of 0 is another one although that was already tried :)

zabzonk 4 days ago | parent | prev | next [-]

what about:

    f(x) = x * 2
not assignment, and it looks like maths to me
nnnnico 4 days ago | parent [-]

Thats what the parent said, shouldnt be used for assigment

grg0 4 days ago | parent [-]

It's not a comparison either. OP's statement is just wrong; the obvious meaning of = is equality. For the definition of a pure function, = is the obvious symbol to use since the RHS can be substituted in for the LHS in any context.

-> for definition is just annoying. On every keyboard layout, it takes two strikes to type, possibly with shift involved.

amelius 3 days ago | parent | next [-]

Use ≟ for comparison. I don't know where to find it on my keyboard, though. Maybe language designers should invent a keyboard along with their language.

moi2388 4 days ago | parent | prev | next [-]

Yes. I too thought it was this. It is equality, and thereby lets you rewrite one side into the other side.

Then again I quite like rewriting languages like Mathematica and lean

austin-cheney 3 days ago | parent | prev [-]

Equality is a comparison.

3 days ago | parent | next [-]
[deleted]
grg0 3 days ago | parent | prev [-]

Not in the sense of evaluating to a boolean.

amelius 3 days ago | parent | prev | next [-]

I'd like to see language designers make function calls happen in the order you read them.

For example, in most languages you have a notation like f(g(h(x))) which calls the functions in the exact opposite order of reading which is unnecessarily confusing.

cb321 3 days ago | parent [-]

You would probably enjoy the UFCS https://en.wikipedia.org/wiki/Uniform_function_call_syntax of Nim, D, etc. Basically `h.g.f(x)` or in Nim you can drop the parens and say `h.g.f x` { but it may not scale past a single argument }. This tends to be only "an option" - more on the "allow/enable" side than the "force them" to do it side, though.

bregma 3 days ago | parent | prev | next [-]

Even this is wrong. Programming should be explicit and easy for anyone to read.

    c = a + b;
is bad since it's an assertion that c is equal to the sum of a and b, and before it's executed, it's completely untrue. Not only that, but it's math and like Barbie has taught us, math is hard.

Nope, make it explicit. You're moving the value of an expression to a placeholder. The only sensible way to write that would be

    ADD a TO b GIVING c
Why, with such a simple and obvious English-like syntax even a common business-oriented person could use the language.
4 days ago | parent | prev | next [-]
[deleted]
rurban 4 days ago | parent | prev [-]

Sure but mathematics is better. There you can switch LHS with RHS.

Instead of := you should use => for assignment.

bregma 3 days ago | parent [-]

What would you use for equal-to-or-greater-than comparisons?

rurban 3 days ago | parent [-]

Right. -> for assignments then. Still better than Pascal Assign :=