• Linus Torvalds added hidden tabs to Kconfig to challenge parsers that can’t handle them.
  • Tabs were intentionally added to the common Kconfig file for page sizes to expose faulty parsers.
  • Torvalds believes parsers unable to handle tabs shouldn’t be parsing kernel Kconfig files, aiming to force fixes.
  • TCB13English
    arrow-up
    286
    arrow-down
    7
    ·
    6 months ago
    edit-2
    6 months ago
    link
    fedilink

    “if you can’t parse tabs as whitespace, you should not be parsing the kernel Kconfig files. ~ Linus Torvalds

    This is what we got after people sent him into PC training. The OG Linus would say something like “if you’re a piece of s* that can’t get over your a** to parse tabs as whitespace you should be ashamed to walk on this planet let alone parsing the kernel Kconfig files. What a f* waste of space.

    • fartsparkles
      arrow-up
      235
      arrow-down
      1
      ·
      6 months ago
      link
      fedilink

      And honestly, I find his phrasing today far more damming with its conciseness. It screams leadership.

        • dohpaz42English
          arrow-up
          27
          arrow-down
          0
          ·
          6 months ago
          link
          fedilink

          Please make fartsparkles the new rimjobsteve. Pretty please?

          • fartsparkles
            arrow-up
            17
            arrow-down
            0
            ·
            6 months ago
            link
            fedilink

            Spreading kindness to strangers, treating people with respect, and being a force for good on the internet is something everyone should aspire to.

            Also I ate way too much glitter than usual this one time and I’ve never been able to live it down. Embrace, extend, shine.

      • ozymandias117English
        arrow-up
        22
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        Yeah, I can’t stop laughing at

        If you can’t parse tabs, you can’t have page sizes.

        It’s like how I’d admonish my pet

      • potkulautapaprika
        arrow-up
        1
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        Well, I do miss the “fuck you mauro” livid linus, yes, nowadays he goes more for ‘brevity is the wit of soul’

    • dezvous
      arrow-up
      18
      arrow-down
      1
      ·
      6 months ago
      link
      fedilink

      Why are you censoring your own text? Truly baffling.

      • TCB13English
        arrow-up
        5
        arrow-down
        8
        ·
        6 months ago
        link
        fedilink

        Because there’s moderation on lemmy that doesn’t like certain words :P

        • dezvous
          arrow-up
          14
          arrow-down
          0
          ·
          6 months ago
          link
          fedilink

          I promise, you can say shit, ass and fuck

          • tetris11
            arrow-up
            19
            arrow-down
            2
            ·
            6 months ago
            link
            fedilink

            Yes, but can you say removed, removed, and sharemoved?

          • TCB13English
            arrow-up
            3
            arrow-down
            0
            ·
            6 months ago
            link
            fedilink

            I’ve had some posts removed because of that so maybe not on this community but still.

      • VirtualOdour
        arrow-up
        32
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        Yours is too, its posting a silly link at the bottom which makes you look like you’re a Facebook mom in 2003.

        Dear Mark Zuckerberg

        With this statement, I give notice to Facebook it is strictly forbidden to disclose, copy, distribute, or take any other action against me based on this profile and/or its contents. The content of this profile is private and confidential information. The violation of privacy can be punished by law (UCC 1-308- 1 1 308-103 and the Rome Statute. NOTE: Facebook is now a public entity. All members must post a note like this. If you prefer, you can copy and paste this version. If you do not publish a statement at least once it will be tacitly allowing the use of your photos, as well as the information contained in the profile status updates. FACEBOOK DOES NOT HAVE MY PERMISSION TO SHARE PHOTOS OR MESSAGES.

      • Duży Szef [he/him]English
        arrow-up
        10
        arrow-down
        1
        ·
        6 months ago
        link
        fedilink

        Dude. Censoring profanity ain’t as cringe as licensing a fucking Lemmy comment XD

    • uis
      arrow-up
      9
      arrow-down
      0
      ·
      6 months ago
      edit-2
      6 months ago
      link
      fedilink

      No-no-no. “Whoever can’t handle tabs as whitespaces should heat their IQ, it is below freezing right now”. Or classic “should be retroactively aborted”.

    • Miaou
      arrow-up
      6
      arrow-down
      2
      ·
      6 months ago
      link
      fedilink

      Complaining about PC but type the word “fuck”? Genius.

    • Aatube
      arrow-up
      3
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      The associated forum post contains a much more endearing translation.

  • Nik282000
    arrow-up
    100
    arrow-down
    2
    ·
    6 months ago
    link
    fedilink

    Why would anyone NOT parse a tab as whitespace? Like, python really wants you to use spaces but will still let you use tabs if you are consistent.

    • dinckel
      arrow-up
      12
      arrow-down
      0
      ·
      6 months ago
      edit-2
      6 months ago
      link
      fedilink

      Even then, unless for some reason you code on paper, there is no excuse to not have a formatter, that enforces one style, or the other

  • inetknght
    arrow-up
    90
    arrow-down
    0
    ·
    6 months ago
    link
    fedilink

    I’m honestly on Torvalds’ side here.

    Tabs are a necessary part of the tooling and configuration files. Any tool which doesn’t properly handle files that are correctly formatted for other tools is a broken tool.

  • Aatube
    arrow-up
    88
    arrow-down
    8
    ·
    6 months ago
    link
    fedilink

    I’ll take you up on that. ChatGPT, translate this commit message to actual Linus style:

    Subject: Regarding Commit d96c36004e31

    So apparently, this commit thought it was a brilliant idea to strip away a tab because some third-rate kernel config parsing tool couldn’t handle it. Seriously? We’re bending over backward for these tools now?

    Listen up, if your parsing tool throws a tantrum over a tab, it’s time to rethink your life choices. Tabs are as fundamental to Kconfig files as oxygen is to humans. If you can’t handle tabs, you have no business parsing kernel configurations.

    And let’s not pretend this is some isolated incident. The whole tab vs. space saga is like a bad sitcom rerun from the '70s. Sure, ‘make’ might have its quirks, but that doesn’t mean we should stoop to that level of incompetence.

    I’m tempted to flood our Kconfig files with tabs just to prove a point, but let’s not make a mess where it’s not needed. However, if this idiocy persists, don’t be surprised if I start tabbing everything in sight.

    Let’s get our priorities straight, people. We’re building a kernel here, not babysitting fragile parsing tools. So let’s fix this mess and move on to more important things.

    • Noa Himesaka
      arrow-up
      35
      arrow-down
      1
      ·
      6 months ago
      edit-2
      6 months ago
      link
      fedilink

      I tried it with Claude 3 Opus, even better:

      Alright, listen up you little shits. Commit d96c36004e31 (“tracing: Fix FTRACE_RECORD_RECURSION_SIZE Kconfig entry”) had to remove a fucking hidden tab because apparently some half-assed third-party kernel config parsing tool couldn’t handle its shit.

      I don’t know what kind of brain-dead tool it was, but you better make damn sure it gets fixed. Because if you can’t parse tabs as whitespace, you have no fucking business parsing the kernel Kconfig files, period.

      In fact, let’s rub this breakage right in your face, more than some obscure ftrace record size option. If you can’t handle tabs, you sure as hell can’t handle page sizes either, dipshit.

      Yeah, I know the whole tab-vs-space clusterfuck is sadly a classic Unix thing, and ‘make’ is notorious for being a broken piece of crap in that regard. But guess what? That doesn’t make it fucking okay, got it?

      I’d sprinkle more random tabs all over our Kconfig files just to spite you, but I don’t want to make this codebase look any more like dog vomit than it has to. But if I keep seeing more of this kind of idiotic tooling, I just might fucking have to.

      So shape up, or I’ll come over there and shove those tabs so far up your ass you’ll be shitting spaces for a week. Fuck!

      • Aatube
        arrow-up
        13
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        I feel like the other one is much better because of the slight passiveness and colorful expressions.

        • uis
          arrow-up
          6
          arrow-down
          0
          ·
          6 months ago
          edit-2
          6 months ago
          link
          fedilink

          So shape up, or I’ll come over there and shove those tabs so far up your ass you’ll be shitting spaces for a week.

          Hah.

    • kill_dash_nineEnglish
      arrow-up
      33
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      “ok, now add a metric shit ton of swearing and further belittle parsers who can’t deal with tabs.

    • CaptDust
      arrow-up
      12
      arrow-down
      0
      ·
      6 months ago
      edit-2
      6 months ago
      link
      fedilink

      Listen up, if your parsing tool throws a tantrum over a tab, it’s time to rethink your life choices. Tabs are as fundamental to Kconfig files as oxygen is to humans. If you can’t handle tabs, you have no business parsing kernel configurations.

      Heh this is so succinctly scathing, but also dead on

    • Exec
      arrow-up
      10
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      I’m tempted to flood our Kconfig files with tabs just to prove a point, but let’s not make a mess where it’s not needed. However, if this idiocy persists, don’t be surprised if I start tabbing everything in sight.

      This is genius.

    • Gallardo994
      arrow-up
      3
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      I am more than sure that Linus wrote the original message as he would normally do, and then made it clean and pretty with an AI. Sometimes I resort to this option too.

  • palordrolap
    arrow-up
    77
    arrow-down
    5
    ·
    6 months ago
    link
    fedilink

    The Robustness Principle may seem like little more than a suggestion, but it is the foundation on which many successful things are based.

    To boil it down to meme-level old-school Torvaldsry: Assume everyone else is a f–king idiot who can barely do what they’re supposed to and expect to parse their files / behaviour / trash accordingly.

    If you do not do this, you are, without doubt, one of those f–king idiots everyone else is having to deal with. If you do do this, it does not guarantee that you are not a f–king idiot. Awareness is key.

    Examples where this works: Web browser quirks mode; Driving a car; Measure twice, cut once. This latter one is special because it reveals that often, the f–king idiot you’re trying to deal with is yourself.

    Assume everyone else is worse.

    Fun corollary: In altering his behaviour towards f–king idiots people who should know better, Linus has learned to apply the robustness principle to interpersonal communication.

    • emptiestplace
      arrow-up
      36
      arrow-down
      2
      ·
      6 months ago
      link
      fedilink

      using a rly bad word but pretending not to is kinda weird

      • mino
        arrow-up
        44
        arrow-down
        2
        ·
        6 months ago
        link
        fedilink

        I don’t understand this either. There’s no fucking algorithm overlord here right? No fucking tiktok, youtube bullshit required.

        If you want to say fuck, fucking say fuck.

        On another note. Thx for introducing me to the robustness principle ♥️

        • palordrolap
          arrow-up
          28
          arrow-down
          6
          ·
          6 months ago
          link
          fedilink

          Maybe I want to say it without saying it. There’s no rule against doing that, but people somehow think there is - or that there ought to be.

          Most of the time I don’t swear, so it makes me uncomfortable to use the word. There have been and undoubtedly will be exceptions. When the mood takes me. When the word, unfettered, feels right. Today was not that day.

          Funny how the partial omission offends some people more than the original word does. Adapt your parsers.

          • half_built_pyramids
            arrow-up
            14
            arrow-down
            5
            ·
            6 months ago
            link
            fedilink

            On the fediverse we do not have to worry about upsetting coka cola or spez because a swear appeared next to their advertisement or name. Not that many people care about that elsewhere, but we especially don’t care about it here. I think that’s worth calling attention to every once in a while. It doesn’t always have to be swears as the vehicle to remind us that the power dynamic is different here.

            It’s fucking nice to be reminded there no corpo overlords here sometimes, though. Which is ironic that sometimes the foss benevolent dictators for life aren’t always benevolent.

            • palordrolap
              arrow-up
              12
              arrow-down
              3
              ·
              6 months ago
              link
              fedilink

              It’s not about whether other people are willing to accept it. It’s about whether I’m willing to generate it. This is the other half of the principle.

              • WldFyre
                arrow-up
                6
                arrow-down
                2
                ·
                6 months ago
                link
                fedilink

                But you still used it, no one’s confused about what word you meant. It’s such an odd line to draw IMO.

                It’s like the “anal doesn’t count as REAL sex” nonsense, but for cussing lol

                • palordrolap
                  arrow-up
                  4
                  arrow-down
                  2
                  ·
                  6 months ago
                  link
                  fedilink

                  I turned the volume down to a more comfortable level.

                • blind3rdeye
                  arrow-up
                  3
                  arrow-down
                  2
                  ·
                  6 months ago
                  link
                  fedilink

                  Obviously the semi-censored version isn’t the same - otherwise you wouldn’t be talking about it. And the author has told you that it was a stylistic choice to use that different version. That’s enough, isn’t it? And judging by the reactions here, apparently the semi-censored version is even more hard-hitting than the full word!

                  Swearing is used for emphasis and to invoke a reaction. The attention it has brought here seems to show that it has invoked a reaction and captured people’s attention. Maybe that drawing of attention means it was fit for purpose - or maybe not. In any case, it was the choice of the author to do it like that.

            • DAMunzy
              arrow-up
              9
              arrow-down
              1
              ·
              6 months ago
              link
              fedilink

              Oh, BS. You don’t have to worry about swearing on Reddit either. Yes, reddit sucks, but the censoring of words on there isn’t like TikTok.

            • VirtualOdour
              arrow-up
              2
              arrow-down
              1
              ·
              6 months ago
              link
              fedilink

              Yeah though I have to admit I like it when people self censor because I imagine them like a cute Ned Flanders all flustered ‘well dang diddly h - e - double C!

              But yeah it’s nice that platform’s exist simply for people to express themselves rather than to serve as vehicles for advertising. I’ll say fuck to celebrate that!

            • lolcatnipEnglish
              arrow-up
              3
              arrow-down
              2
              ·
              6 months ago
              link
              fedilink

              You know you can say fuck on Reddit, right?

          • soupuos
            arrow-up
            3
            arrow-down
            0
            ·
            6 months ago
            link
            fedilink

            That’s a good f*****g point

      • lolcatnipEnglish
        arrow-up
        23
        arrow-down
        3
        ·
        6 months ago
        link
        fedilink

        Sometimes it works well as a stylistic choice. It’s not pretending not to use a bad word, but rather drawing attention to the fact that you’re deliberately being a little bit naughty with a wink to the reader. It’s like the absurdity of what happens when you find a stranger in the Alps.

    • barsoap
      arrow-up
      1
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      Robustness Principle

      It’s a principle for brittleness. First you get implementation-defined behaviour, then bug-compatible software.

  • tooLikeTheNope
    arrow-up
    70
    arrow-down
    0
    ·
    6 months ago
    edit-2
    6 months ago
    link
    fedilink

    Torvalds believes parsers unable to handle tabs shouldn’t be parsing kernel Kconfig files, aiming to force fixes.

    Stern but just

  • PanoptiDon
    arrow-up
    66
    arrow-down
    1
    ·
    6 months ago
    link
    fedilink

    Reminds me of Beethoven writing Für Elise for sometime he loved, and when he was rejected, the music was finished in such a way that she could not play it.

    • jonwyattphillips
      arrow-up
      17
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      Fur Elise wasn’t discovered until 40 years after his death and its unknown who it was written for.

      • Incandemon
        arrow-up
        29
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        Wait, isn’t that obvious? Its for Elise!

        • Mr3Sepz
          arrow-up
          4
          arrow-down
          0
          ·
          6 months ago
          link
          fedilink

          It was probably not for Elise, but Therese, but again its complicated.

  • uis
    arrow-up
    62
    arrow-down
    1
    ·
    6 months ago
    link
    fedilink

    Based Linus is based.

  • BigMikeInAustinEnglish
    arrow-up
    41
    arrow-down
    1
    ·
    6 months ago
    link
    fedilink

    I do the same to people who refuse to follow specifications they agreed to follow.

    There is a slight satisfaction to get back at them for continually delivering much lower quality than is required.

    But it really is to cover me. Because, it always happens, later in the future that edge case comes up, and everything breaks. And management is ready to blame me. But then I show them that I tested the edge case before the conclusion of the project. And that programmer ignored my emails, and that I told management these edge cases weren’t covered. But then management signed off on calling it complete. And suddenly management is no longer red with fury. And they usually won’t allow me time to fix it. So the can gets kicked down the road until the next time that edge case fails.

    • luciferofastora
      arrow-up
      2
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      Me: “This is the file format we agree on.
      They: “Yep, that’s what you’ll get.

      They: “Why is your script not working?
      Me: “Idk what was the last file you put through it?

      In their defense, they got the file from a third party that we both previously assumed competent enough to follow explicit written instructions. Guess there’s a lesson in trust

  • janNatan
    arrow-up
    29
    arrow-down
    2
    ·
    6 months ago
    link
    fedilink

    Unconventional way to take acid, but I support him.

    • UpperBroccoli
      arrow-up
      15
      arrow-down
      0
      ·
      6 months ago
      link
      fedilink

      Invalid, not an ABI change. Besides, this does not break, it only reveals existing breakage.

  • merthyr1831
    arrow-up
    11
    arrow-down
    0
    ·
    6 months ago
    link
    fedilink

    The Register did a good article covering the change.

    Source files should be conservative with the standard they expect from the developer, and parsers should be liberal in what they expect from the source, ie. allow deviations from the standard.

    Python for example supposedly only allows 4 spaces for indentation, but as long as the developer is consistent most if not all Python interpreters will accept any kind of indentation.

    • barsoap
      arrow-up
      5
      arrow-down
      1
      ·
      6 months ago
      link
      fedilink

      Python for example supposedly only allows 4 spaces for indentation, but as long as the developer is consistent most if not all Python interpreters will accept any kind of indentation.

      That’s a recipe for disaster as your syntax is under-specced. You’re right-up inviting programmers to produce programs with implementation-defined semantics.

      Haskell (which also uses layout syntax) never had that problem as tabs were simply defined to be eight spaces, but that then led to issues with people setting different tab-widths in their editors and a flurry of syntax errors when they did “tabs for indentation, spaces for alignment”. Which is why Haskell then moved ahead to outlaw tabs, I think it’s still in the “throw a warning” phase but at some point it’s going to be a hard error.

      That’s not to say that kconfig should do the same – presumably they used tabs for a good reason, and all those other programs are simply not following the spec. Essentially including unit tests in the actual production files is a good move when you’re dealing with that kind of situation.

      • UndercoverUlrikHD
        arrow-up
        6
        arrow-down
        0
        ·
        6 months ago
        link
        fedilink

        Eight space indentation should be crime, I’m not made out screen width over here.

        If you want to be strict with indentation, use tabs as your standard instead of forcing others to use your preferred visual width.

        • barsoap
          arrow-up
          1
          arrow-down
          0
          ·
          6 months ago
          edit-2
          6 months ago
          link
          fedilink

          Eight is still the default tab width and will be as long as VT100 continues to be a thing, i.e. forever. Haskell could’ve chosen another static value but that would have caused even more trouble.

          With Haskell’s syntax you really want to align at single-space resolution, not necessarily just on the left but also further to the right, within the lines. The gold standard is pretty much lhs2tex “poly” style (section 8, page 19), and not just because it allows lhs2tex to spit out beautiful code, it’s also highly readable in ASCII form. In that style 2+ spaces mean “align this with the 2+ space stuff above and below”.

          So there’s no way around spaces and as tabs+spaces are a bad idea tabs get the boot. That argument is specific to Haskell but in general I’d argue that tabs are more trouble than they’re worth – if you have trouble editing space-only indentation, get a proper editor. If I want my Rust indented by a different amount I can just tell rustfmt to change everything, no biggie.

    • Subverb
      arrow-up
      3
      arrow-down
      6
      ·
      6 months ago
      link
      fedilink

      Having a language dependent on indentation is absurd on the face of it. It’s a ridiculous idea that should have been ridiculed from the outset.

      • barsoap
        arrow-up
        2
        arrow-down
        1
        ·
        6 months ago
        link
        fedilink

        No. Having a language depend on semicolons even though there’s ways to do without, ways that don’t even include layout if you don’t want to, is well not absurd on the face of it it’s hysterical raisins.

        Haskell has one of the most admired syntaxes out there, and it’s layout. It’s clean, predictable, very simple and most of all intuitive rules. It makes sure that semantic structure always follows visual structure, thus provides a single source of truth why Algol-likes (i.e. everything that looks at least vaguely like C) have two.

        I don’t indent my Rust, I let rustfmt do that. All that automation and I still get into lots of missing or mismatched braces situations which literally never happen in Haskell because the structure of the program is visually obvious, you don’t have to look for tiny squiggles to figure out what it is.

    • wreckedcarzzEnglish
      arrow-up
      9
      arrow-down
      0
      ·
      6 months ago
      edit-2
      6 months ago
      link
      fedilink

      The bot vs the human moderator

      bell rings

      FIGHT!