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
    16 days ago

    It’s docs are garbage, but the language is quite simple and human readable even for non-techies. I think it’s a bit too easy at times, resulting in people just kinda winging it

  • @Kissaki
    link
    English
    17 days ago

    Somehow it’s clunky to use.

    huh?

    I find developing GitHub CI in YAML clunky.

    I don’t find configuring a simple service via YAML config, with a preset showing me and explaining what I can do clunky.

  • @[email protected]
    link
    fedilink
    8310 days ago

    Any language in which whitespace has syntactic value is intrinsically flawed.

    Can’t speak to your specific issues, but that’s why yaml will always suck.

    • @[email protected]
      link
      fedilink
      2510 days ago

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

      • magic_lobster_party
        link
        fedilink
        6210 days 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
          129 days 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
          510 days 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
            49 days 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.

          • @hex
            link
            39 days 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!

        • @[email protected]
          link
          fedilink
          1
          edit-2
          9 days 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
        2910 days 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
          1710 days 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
          fedilink
          English
          8
          edit-2
          10 days 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
            1210 days 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
              fedilink
              English
              3
              edit-2
              10 days 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.

          • @tyler
            link
            29 days 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
              fedilink
              English
              2
              edit-2
              9 days 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.

              • @tyler
                link
                12 days 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.

      • @MajorHavoc
        link
        16
        edit-2
        10 days ago

        would Python really be better if it switched to braces?

        Yes. A thousand times, yes.

      • @[email protected]
        link
        fedilink
        510 days ago

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

          • @[email protected]
            link
            fedilink
            1
            edit-2
            9 days 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.

    • Eager Eagle
      link
      fedilink
      English
      6
      edit-2
      10 days ago

      YAML sucks because, among other things, indenting it is not obvious.

      In contrast, the only mistake of Python when it comes to whitespaces was allowing hard tabs, which makes it too easy to mix them if your editor is not configured.

      Improper indentation stands out more than missing or unbalanced braces and it’s really not an issue to delimit code blocks.

      • @[email protected]
        link
        fedilink
        89 days ago

        Hard tabs are the only accessible option though. If you care about developers with a different vision capability than yours, the only correct indentation choice is tabs.

        If, because of bad vision, someone needs to crank the font size way up, it’s very possible that they might need to work with a tabstop of 3, 2, or even just 1 space.

        With tabs, this is user configurable. With spaces it isn’t.

        • @tyler
          link
          19 days ago

          In any modern editor it is configurable with spaces too

          • @[email protected]
            link
            fedilink
            18 days ago

            What “it” is configurable? If the code is indented with 4 spaces, it is indented with 4 spaces. You can configure your editor to indent with 1 space if you want, but then your code is not going to respect the 4 spaces of indentation used by the rest of the code.

            I repeat, the only accessible indentation option is using tabs. This is not an opinion because every other option forces extra painful steps for those with vision issues (including, but not limited to, having to reformat the source files to tabs so they can work on them and then reformat them back to using spaces in order to commit them)

    • @[email protected]
      link
      fedilink
      6
      edit-2
      10 days ago

      Haskell supports both semantic whitespace and explicit delimiters, and somehow almost everybody that uses the language disagrees with you.

      But anyway, for all the problems of YAML, this one isn’t even relevant enough to point out. Even if you agree it’s a problem. (And I agree that the YAML semantic whitespace is horrible.) If YAML was a much better language, it would be worth arguing whether semantic whitespace breaks it or not.

      • @hex
        link
        19 days ago

        Yeah but Haskell is mostly used by mathematicians…

    • @[email protected]
      link
      fedilink
      English
      110 days ago

      It’s the only time that tabs Vs spaces really riles me up. So annoying when everyone has different tab lengths

    • @[email protected]
      link
      fedilink
      English
      19 days ago

      Not any language. I code professionally in F# which has semantic whitespace and it has literally never been an issue for me or my team. In contrast to Python, it’s a compiled language and the compiler is quite strict, so that probably helps.

    • Ben Matthews
      link
      fedilink
      Português
      -110 days ago

      I now use Scala 3, and very happy with syntactic whitespace (combined with an intelligent compiler)

  • @[email protected]
    link
    fedilink
    62
    edit-2
    9 days ago

    Can people stop hating on shit?

    FOR FUCKS SAKE, negative reinforcement dopamine has RUINED THE FUCKING NET.

    EVERYWHERE I GO there’s someone bitching about something, hate circlejerks are unbelievably popular, people just love to hate on stuff.

    You’re ruining your thought patterns with all these social media negativity bullshit.

    Fucking TOML users hate on fucking YAML fucking C++ users hate Rust fucking Rust users hate literally everything under the sun and are insufferable to work with

    EVERYONE, fucking CHILL

    • @sip
      link
      269 days ago

      stop hating on rust devs

    • Sir Gareth
      link
      119 days ago

      Yeah TBH I like yaml. Sure its not the best ever, but its not the worst it could possibly be.

      For config its not terrible. For ansible playbooks its again… not terrible.

      Why is everyone always hating on something which is just kinda mid.

      • @[email protected]
        link
        fedilink
        English
        89 days ago

        Config is fine, but Yamls biggest problem is people use it to describe programs. For example: playbooks. For example: CI steps.

        If YAML wasn’t abused in this way it would have a lot less hate.

        • @derpgon
          link
          49 days ago

          What’s wrong with using YAML for CI? I mean, I use it for Gitlab CI, the underlying script it runs is just Bash.

          • @[email protected]
            link
            fedilink
            49 days ago

            You’re doing it right by avoiding as much of Gitlab’s CI features. I’ve seen versions where scripts are inlined in the YAML with expressions in random rule fields and pipeline variables thrown all over the place. And don’t get me started on their “includes” keyword, it’s awful in practice, gives me nightmares.

            Then I write a Kubernetes manifest in YAML with JSON schema validation and the heart rate goes down again.

          • @[email protected]
            link
            fedilink
            English
            49 days ago

            Right, so you just have a single step and then hand over to a proper script. I’ve seen many people try to put much more complex logic in there before handing over to a proper language.

      • @[email protected]
        link
        fedilink
        English
        19 days ago

        I dream of a life where I use YAML but all my configs are stuck in XML. People can complain but there’s always worse options.

        • @FizzyOrange
          link
          29 days ago

          One nice thing about XML is that there’s an official way to link to the schema from within the document. If you do that you can easily automatically validate it, and even better you get fantastic IDE support via Red Hat’s LSP server. Live validation, hover for keys, etc.

          It’s a really nice experience and JSON schema can’t really match it.

          That said, XML just has the wrong data model for 99% of use cases.

    • @[email protected]
      link
      fedilink
      68 days ago

      No seeds no stems no stress my guy. The Internet is a great place for complaining. Readers can downvote and move on, everyone gets what they want.

  • @[email protected]
    link
    fedilink
    English
    43
    edit-2
    9 days ago

    Programmers hate everything. You could design a spec which serenades you with angel song and feeds you chocolate dipped grapes and someone would be like: This is awful, my usecase is being a dog.

    • @FizzyOrange
      link
      79 days ago

      Sure there aren’t many things that are universally loved. I mean I can’t really think of anything that doesn’t have some flaw.

      But that doesn’t mean everything is equal! What would you rather program with, Visual Basic or Go? PHP or Typescript? If you polled people there are obvious winners.

      • @[email protected]
        link
        fedilink
        English
        -29 days ago

        Hey would you rather build from wood or steel?

        What glue is better: 2 part epoxy or PVA?

        Do you prefer soap or bleach as cleaning agent?

        • @FizzyOrange
          link
          49 days ago

          Would you rather build from wood or tissue paper?

          What glue is better: 2 part epoxy or pritt stick?

          Do you prefer soap or ash as a cleaning agent?

          • @[email protected]
            link
            fedilink
            English
            09 days ago

            Unlike tissue paper yaml is actually fit for purpose. I actually don’t know of any lang that literally can’t run a program. The most you could stretch what you’re saying to is that some esolangs are akin to making bricks of packed tissues to build with. They are art projects not serious submissions though.

            I don’t like js as much as anyone else but as evidenced by reality it works. Programmers need to stop sniffing their own farts, you have such strong opinions about the most insane shit when at most you should be talking about narrower scopes for use and trade offs.

            • @[email protected]
              link
              fedilink
              18 days ago

              Different user here.

              My only criteria for a backend language is it tells me something went wrong and where. Hence my distaste for JS.

    • @MajorHavoc
      link
      1710 days ago

      That is amazing.

      I don’t know what I just read.

      If my website ever gets married, I’m going to invite this website to stand next to it as a bridesmaid - because it makes my website look pretty by comparison.

    • @[email protected]
      link
      fedilink
      79 days ago

      Sadly, unreadable on mobile. Text doesn’t word wrap, dragging to pan it is annoying and makes the keyboard show up.

    • @hex
      link
      29 days ago

      Most of the stuff here can be avoided by using quotes for strings…

  • @[email protected]
    link
    fedilink
    3510 days ago

    Because people over use it. YAML is pretty good for short config files that need to be human readable but it falls apart with complex multi line strings and escaping.

    I think there are much better clearly delimited for machine reading purposes formats out there that you should prefer if you’re writing a really heavy config file and, tbh, I think for everything else .ini is probably “good enough”.

      • @[email protected]
        link
        fedilink
        1010 days ago

        Strong agree. It’s also the absolute best at expressing really long documents of configuration/data.

    • hallettj
      link
      fedilink
      English
      13
      edit-2
      10 days ago

      I agree - YAML is not suitable for complex cases that people use it in, like Terraform and Home Assistant. My pet peeve is a YAML config in a situation that really calls for more abstraction, like functions and variables. I’d like to see more use of the class of configuration languages that support that stuff, like Dhall, Cue, and Nickel.

      There is another gotcha which is that YAML has more room for ambiguity than, say, JSON. YAML has a lot of ways to say true and false, and it’s implicit quoting is a bit complex. So some values that you expect to be strings might be interpreted as something els.

      • @[email protected]
        link
        fedilink
        5
        edit-2
        10 days ago

        For those highly complex situations is Lua still viewed as the ideal solution? Lua is sort of legendary for game configuration and seems to strike a good expressiveness/accessibility balance for modders and the casually technical.

        • hallettj
          link
          fedilink
          English
          19 days ago

          I think it depends. Lua is great for scripting - like when X happens do Y. I agree that makes sense for a case like Home Assistant. Sometimes you really want the result to be a data structure, not an interactive program, in which case I think more sophisticated configuration (as opposed to scripting) languages might be better.

        • hallettj
          link
          fedilink
          English
          410 days ago

          Oh, thanks for calling that out. I think I may have mixed up some of the frustrations I experienced at an old job.

  • @[email protected]
    link
    fedilink
    319 days ago

    Following along with the style of your own post: YAML doesn’t suck, because I feel so.

    Thanks for asking.

  • magic_lobster_party
    link
    fedilink
    2610 days ago

    I don’t like YAML because it’s overly complicated. The specification is like 80 pages long. How the hell did they think that was a good idea?

    JSON on the other hand is super simple. It doesn’t do more than it needs to.

    Just compare this: https://yaml.org/spec/1.2.2/

    With this: https://www.json.org/json-en.html

    The entire JSON specification is shorter than just the table of contents of the YAML specification!

    Another thing I like about JSON is that you can format it however you want with the whitespace. Want everything on one line? Just write everything on one line!

    If data can be represented as a JSON, then there’s generally only one way to represent it in JSON (apart from whitespace). In YAML the same data can be represented in 1000s of different ways. You pick one.

    • lemmyng
      link
      fedilink
      English
      269 days ago

      I will never forgive JSON for not allowing commas after the last element in a list.

      • NostraDavid
        link
        39 days ago

        That lack of trailing comma has been the bane of my existence.

    • @verstra
      link
      1310 days ago

      This is the major reason for me. I really liked yaml, because it is way more readable to me than JSON. But then I kept finding new and more confusing yaml features and have realized how over-engineered it is.

      Yaml would be great language if it had its features prunned heavy.

  • mox
    link
    fedilink
    26
    edit-2
    9 days ago

    One pattern I’ve noticed is people seeking a language that’s better than {JSON,XML,INI,etc} at wrangling their slightly complex configuration files, noticing the additional features and type support offered by YAML, and assuming it will be a good solution.

    Then, as their configs grow ever larger and more complex, they discover that expressing them in YAML requires large sections of deep nesting, long item sequences, and line wrapping. The syntax style that they saw working well in other places (e.g. certain programming languages) breaks down quickly at that level of complexity, making it difficult for humans to correctly write and follow, and leading to frequent errors.

    YAML doesn’t suck for small stuff, IMHO. (But it is more complex than necessary for small stuff.)

    For things likely to grow to medium-large size or complexity, I would recommend either breaking up the data into separate files, or looking for a different config/serialization language.

  • @[email protected]
    link
    fedilink
    209 days ago

    To paraphrase: There are two kinds of markup languages. Those that people complain about and those that nobody uses.

    There is no silver bullet that will work perfectly for all use cases and we also don’t want to use 100 different tools. So people use things that aren’t perfect. But they’re good enough. I don’t think YAML is perfect and I still use it, because people know it and there are tons of tools already available.

    • @hex
      link
      -39 days ago

      But it’s not a markup language… It’s for data serialisation…

  • @[email protected]
    link
    fedilink
    199 days ago

    YAML works great for small config files, or situations where your configuration is fully declarative. Go look at the Kubernetes API with its resources.

    People think YAML sucks because everyone loves creating spaghetti config/templates with it.

    One reason it tends to become an absolute unholy mess is because people work around the declarative nature of those APIs by shoving imperative code into it. Think complicated Helm charts with little snippets of logic and code all over the place. It just isn’t really made for doing that.

    It also forces your brain to switch back and forth between the two different paradigms. It doesn’t just become hard to read, it becomes hard to reason about.

  • UnfortunateShort
    link
    fedilink
    19
    edit-2
    9 days ago

    Tons of people making Python comparisons regarding indentation here. I disagree. If you make an indentation error in Python, you will usually notice it right away. On the one hand because the logic is off or you’re referencing stuff that’s not in scope, on the other because if you are a sane person, you use a formatter and a linter when writing code.

    The places you can make these error are also very limited. At most at the very beginning and very end of a block. I can remember a single indentation error I only caught during debugging and that’s it. 99% of the time your linter will catch them.

    YAML is much worse in that regard, because you are not programming, you are structuring data. There is a high chance nothing will immediately go wrong. Items have default values, high-level languages might hide mistakes, badly trained programmers might be quick to cast stuff and don’t question it, and most of the time tools can’t help you either, because they cannot know you meant to create a different structure.

    That said, while I much prefer TOML for being significantly simpler, I can’t say YAML doesn’t get the job done. It’s also very readable as long as you don’t go crazy with nesting. What’s annoying about it is the amount of very subtle mistakes it allows you to make. I get super anxious when writing YAML.

  • @[email protected]
    link
    fedilink
    1810 days ago

    I think TOML should replace YAML for config files, it is much clearer, easier to parse for a human.

    • NostraDavid
      link
      29 days ago

      Depends on the data structure. If you want to save a table of sorts, you’re getting a bunch of unreadable [[[]]] nonsense.

      For flat structures it’s great though.