I feel that Yaml sucks. I understand the need for such markup language but I think it sucks. Somehow it’s clunky to use. Can you explain why?

  • @[email protected]
    link
    fedilink
    244 months ago

    As a serialization format, agree 100%, but would Python really be better if it switched to braces?

    • magic_lobster_party
      link
      fedilink
      614 months ago

      Yes, I think so. The downside with Python comes when refactoring the code. There’s always this double checking if the code is correctly indented after the refactor. Sometimes small mistakes creep in.

      It’s really hard to tell when Python code is incorrectly indented. It’s often still valid Python code, but you can’t tell if it’s wrong unless you know the intention of the code.

      In order languages it’s always obvious when code is incorrectly indented. There’s no ambiguity.

      • @[email protected]
        link
        fedilink
        English
        124 months ago

        I think this is just familiarity. I never have issues with indentation, but when refactoring js I’m always like hey who’s fucking brace is this

      • @[email protected]
        link
        fedilink
        54 months ago

        It’s only hard to tell indentation in Python when the code block gets longer than about a screen, which is usually a sign the code should be refactored into smaller methods.

        • @[email protected]
          link
          fedilink
          English
          44 months ago

          As someone who has been working in Python a ton for the last couple years, it’s amusing to me how many downvotes you’re getting for simply noting that good code style and tight, terse, modularized implementation of business logic more or less addresses the issue. Because it absolutely does in the vast majority of cases.

        • @[email protected]
          link
          fedilink
          34 months ago

          People hate hearing that they are bad coders 😂

          You and the other guy are saying to focus on writing code with less indentation and using smaller methods, and you both got downvoted.

          I fully agree, small methods all the way, and when that’s not possible it’s time to refactor into possibility!

        • @Venat0r
          link
          34 months ago

          Or a sign you should get a bigger screen 😂 (j/k)

      • @[email protected]
        link
        fedilink
        1
        edit-2
        4 months ago

        Can address it by writing code that doesn’t depend much on indentation, which also makes code more linear and easier to follow.

    • @[email protected]
      link
      fedilink
      284 months ago

      Yes it would - look at optional braces for short if expressions in C family languages and why it’s so discouraged in large projects. Terminating characters are absolutely worth the cost of an extra LoC

      • @[email protected]
        link
        fedilink
        174 months ago

        I started in C before moving on to C++, Java, Ruby and Python.

        I’ve had more bugs from missing braces than from misaligned whitespace because the latter is far more obvious when looking at a block of code.

      • Eager Eagle
        link
        English
        8
        edit-2
        4 months ago

        False dichotomy. Optional braces are bad practice because they mislead the programmer that is adding an additional clause to the block.

        This misleading behavior wouldn’t happen in Python, as it would either be invalid syntax, or it would be part of the block.

        Indentation problems are pretty obvious to the reader. Even more than missing or unbalanced braces.

        • @[email protected]
          link
          fedilink
          124 months ago

          They may be obvious to the reader but they may be impossible to see if tabs and spaces are mixed together.

          Closing tokens are always clearer.

          • Eager Eagle
            link
            English
            3
            edit-2
            4 months ago

            yes, from my other comment

            the only mistake of Python when it comes to whitespaces was allowing hard tabs

            but that’s easily fixed with an editor setting - on the other hand, unbalancing braces (and not realizing it) is too easy all the time.

        • @[email protected]
          link
          fedilink
          24 months ago

          That misleading behavior does happen in Python. The next programmer that comes along can’t tell if the original programmer fucked it up and didn’t unindent to put a statement outside of the block or if they meant to put it inside the block. I’ve debugged this one too many times and it takes hours each time because it’s impossible to see the bug at all!!

          • Eager Eagle
            link
            English
            2
            edit-2
            4 months ago

            The misleading behavior is about what you expect to execute in the source code you’re looking at vs what’s actually executed.

            What you describe is a logic ambiguity that can happen in any program / language.

            • @[email protected]
              link
              fedilink
              14 months ago

              I don’t agree. It’s a direct result of whitespace, which does not happen if you don’t use whitespace. For example it can happen in Java and kotlin, but only if you use if statements without braces, which you pretty much never see. If you do see it you know to look out for the exact issue I described. That’s not possible in Python, since there is no alternative.

    • @[email protected]
      link
      fedilink
      54 months ago

      To be pendantic, it’s level of indentation in Python that has semantic meaning, not whitespace.

      • @marcos
        link
        134 months ago

        The end of line also has semantic meaning. Both indentation and eol are whitespace.

        • @[email protected]
          link
          fedilink
          1
          edit-2
          4 months ago

          Indentation can be (and should be) tabs, EOL is it’s its own thing either \n or CRLF which Python source code did actually care about as recently as 2.3.

          Assumptions like this is why most people should stick to verbose languages with lots of guardrail braces.