• andyburke@fedia.io
    link
    fedilink
    arrow-up
    22
    arrow-down
    1
    ·
    2 days ago

    Old programmers shouting at clouds.

    (Old programmer here, I just shout at differently shaped clouds than this one.)

    Edit: I am not sure if the respondents to this comment think I have a horse in this race. I said I don’t and that I shout at different clouds. I am just here answering a question.

    • floofloof@lemmy.ca
      link
      fedilink
      arrow-up
      22
      ·
      edit-2
      2 days ago

      Another old programmer here, and I don’t see the issue. C# gets better with every release and the null coalescing assignment operator is very handy. It also exists in JavaScript.

      • Victor@lemmy.world
        link
        fedilink
        arrow-up
        4
        ·
        24 hours ago

        I feel like it boils down to understanding that operator. I’m a TypeScript developer by trade so I had no issue understanding this. 🤷‍♂️

      • LeFrog@discuss.tchncs.de
        link
        fedilink
        arrow-up
        4
        ·
        edit-2
        2 days ago

        Ruby has it as well:

        a ||= b
        
        # which means
        a = a || b
        # wich is the same as
        a = b if !a
        # which rubyists like to write as
        a = b unless a
        # or as ternary
        a = a ? a : b
        
        • Victor@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          24 hours ago

          That’s way too many ways of doing the same thing, yuck.

          But you’re saying the idiomatic way is to use unless, rather than the actual operator for this?

          • LeFrog@discuss.tchncs.de
            link
            fedilink
            arrow-up
            1
            ·
            23 hours ago

            This is basically one of the core ideas of Ruby: that you can read it like a story. Once you are used to reading it as “do X unless Y”, you will miss it in other languages. Note that I wrote Y, not Y is true. Because often Y is a statement that has meaning in itself.

            Example:

            # imagine that given_name is some text from user input
            
            # this is of course valid:
            user.name = given_name if !user.is_locked
            
            # but this reads more fluently:
            user.name = given_name unless user.is_locked
            

            Ruby also allows using ? as last character in method names, which is a convention for methods that return either true or false.

            Same goes for ! (the bang operator), that is commonly used to tell developers that there exists a non-bang version of the same method as well. The bang method is often the more strict version (e.g. raises an error instead of returning nil; or having side effects compared to the non-bang version).

            So the above example may be more commonly written like this:

            user.name = given_name unless user.locked?
            

            and the question mark makes you automatically adding is or has while reading: Set the user’s name to the given_name unless the user is locked

            Of course this is all by convention and you may also do it different. But that’s how most Ruby code is written.

            To stay consistent, lots of projects use RuboCop, which warns you on inconsistency based on your project’s settings.

            • Victor@lemmy.world
              link
              fedilink
              arrow-up
              1
              ·
              22 hours ago

              you will miss it in other languages

              I honestly don’t like the “unless X” paradigm, because it adds the condition at the end. The ??= operator shows us what will happen much sooner.

              I guess it’s a matter of personal taste.