• PhobosAnomaly@feddit.uk
    link
    fedilink
    arrow-up
    40
    ·
    7 months ago

    I was brought up on C, did a module of Java at uni, and am doing an algorithms course which is python heavy.

    My other half - who’s quite handy with Python - looks in sheer horror at my code which is littered with semicolons.

    I was stumped for half an hour figuring out why the Python interpreter was bouncing an error before it had even reached the main program logic… turns out a { before the block of code royally ruins the interpreter’s day.

    Still, I live and learn.

  • Carighan Maconar@lemmy.world
    link
    fedilink
    arrow-up
    24
    ·
    7 months ago

    For bonus points take their code and completely go wild with utterly random indentation and line breaks, just to drive the point home. 😈

    • force@lemmy.world
      link
      fedilink
      arrow-up
      4
      ·
      edit-2
      7 months ago

      That said, with how few expressions are return values, I do wonder why semicolons are the default rather than adding a special character to indicate return values.

      you mean like return/break/etc.?

      because Rust was designed to remind you of functional programming despite not being very functional, and because semicolons allow way better syntax rules in Rust and are generally pretty vital for good, readable lowish-level code. it also allows Rust programmers to use newlines/indents and stuff to pretty up their code a lot without littering it with random \ and |> and begin end and such everywhere, which, given how dense Rust code can be and how much it uses iterators and weird trait magic, is a big plus for readability

        • force@lemmy.world
          link
          fedilink
          arrow-up
          2
          ·
          edit-2
          7 months ago

          I don’t work on any widely-used languages (I’ve made my own but not anything important) but I do think the designers of Zig and Rust have very good reasons for using semicolons – I read some reasons from the Rust devs themselves somewhere but I can’t remember them other than it vaguely being about how Rust is expression-based and intended to be lightweight and how whitespace significance can create confusion around how to read and write certain things and bla bla bla…

          but my personal opinion, what I generally I would imagine it’s for other than readability, is because the code can look a lot cleaner when an expression returned from a block is just the expression, and not expression plus some token like return. It’s especially nice in long closures or extremely short and simple blocks. I would rather consistently have to write expressions broadly like let a = { b + c }; rather than let a = { return b + c }. The semicolon has significance as a “result discarder” so expressions can be the default, so it’s on the surface a lot more functional-friendly.

          Also this is more specific but I hate the way WS languages generally handle quotes

  • arudesalad@sh.itjust.works
    link
    fedilink
    arrow-up
    2
    ·
    7 months ago

    I was taught python by my school but I would rather write in other languages but the difference in formatting still gets me after years

  • toastal@lemmy.ml
    link
    fedilink
    arrow-up
    4
    arrow-down
    4
    ·
    7 months ago

    Folks acting like Python is the only language without semicolons. 😏

    I got tripped up so many time in the last 3 weeks using PHP after years in ML family languages. I am already newlining & it’d be poor style to put more than one statement on a line so what is the point of these semicolons?

    • palordrolap@kbin.social
      link
      fedilink
      arrow-up
      19
      arrow-down
      1
      ·
      7 months ago

      In some languages
      a newline does not
      necessarily indicate
      the end of a statement.

      In others, sometimes it could, but would leave things ambiguous
      as to whether the statement was ended or not.

      And so, punctuation is necessary.

      • toastal@lemmy.ml
        link
        fedilink
        arrow-up
        3
        ·
        7 months ago

        But newlines + indentation are supported by a lot of languages & when it is, it’s easier to read since the prevailing convention is already to newline, then in indent. When you follow the usual coding styles or autoformatted & removed the semicolons, you’ve gained nothing for readability & added noise. I much prefer the languages that take this convention & bake it in so you don’t have to have that that visual noise—and in these languages, I never felt the parsing rules were ambiguous.

    • pixelscript@lemmy.ml
      link
      fedilink
      English
      arrow-up
      6
      ·
      7 months ago

      it’d be poor style to put more than one statement on a line

      Unlike Python, most languages do not endorse a specific concept of style. You’re free to dabble in all the bad style choices you like, on the off chance that once in a blue moon they prove to be situationally useful.

      • CanadaPlus@lemmy.sdf.org
        link
        fedilink
        arrow-up
        1
        ·
        edit-2
        7 months ago

        Why haven’t custom parsers become more of a thing? All the compiler or interpreter really needs is a valid parse tree. You could even have some kind of special command or directive to switch styles, if a section would be really ugly otherwise.

      • toastal@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        7 months ago

        With indentation-based languages the bad coding style we are talking about is putting multiple statements on a line or unindenting a block …& never has that been something I wanted to do. I would rather this aspect be enforced at the language for readability where there is still room in all other aspects to try out other styles.

      • toastal@lemmy.ml
        link
        fedilink
        arrow-up
        3
        ·
        7 months ago

        The best languages about really embracing punctuation as you would in English is Prolog & Erlang with their periods, semicolons, & commas.