Linux people doing Linux things, it seems.

  • kbal
    link
    fedilink
    68 months ago

    Switching everything from C to Rust because it has better memory safety is more akin to changing languages from English to Esperanto because it has gender neutral pronouns and other cool features. Maybe it’s a good idea, but it’s understandable that some people are reluctant.

    • Snot Flickerman
      link
      fedilink
      English
      74
      edit-2
      8 months ago

      Maybe it’s a good idea, but it’s understandable that some people are reluctant.

      I understand that position. I also understand how the words and phrases that the C community has used to communicate with the Rust community seems to be completely dismissive, not just reluctant.

      I quoted what I did explicitly because of how a statement like that comes off to the person it’s aimed at. It doesn’t make them feel like they’re on an even footing working on the same project with the overall goal of it becoming better.

      memory safety is more akin to changing languages from English to Esperanto because it has gender neutral pronouns.

      I mean… not at all? Memory safety is huge for cybersecurity, buffer overflows and the like are common attack surfaces. C requires you to have deep knowledge of safe memory management practices and even then you can end up with memory issues. Rust was developed to avoid such issues entirely. I understand the reluctance but it feels to me like arguing “we should just stick with COBOL because it works.”

      • kbal
        link
        fedilink
        148 months ago

        Gender neutral pronouns are pretty huge too. Sure you can do them in English without too many problems usually, just as it’s also possible to code safely in C. It requires everyone to change their old habits, but it’s much less of a change than is involved in adopting a whole new language.

        Anyway, I do like Rust better personally.

        • @explore_broaden@midwest.social
          link
          fedilink
          248 months ago

          I would still say that getting people to the point where they can write safe C code every time is harder than learning Rust, as it’s equivalent to being able to write rust code that compiles without any safety issues (compiler errors) every single time, which is very difficult to do.

        • Snot Flickerman
          link
          fedilink
          English
          13
          edit-2
          8 months ago

          Ok, that made your analogy make more sense to me. I can agree with that. Thanks.

        • @boonhet@lemm.ee
          link
          fedilink
          10
          edit-2
          8 months ago

          Gender neutral pronouns might be pretty huge too, but nobody’s private data is getting hacked because of gendered pronoun use.

        • @Auli@lemmy.ca
          link
          fedilink
          English
          17 months ago

          Don’t thinknits possible by on write safe c code. Otherwise we would not have these issues time and time again. But yes its only the idiots begin don’t know how to code. Projects are big and complicated itsneasy to make mistakes.

      • @refalo@programming.dev
        link
        fedilink
        13
        edit-2
        8 months ago

        People prefer what’s familiar to them. Rust is completely foreign to them, the syntax is very different, the community is different (and often much younger), it still has many issues and is not ubiquitous, and many people are just slow/averse to change in general. So I absolutely understand the hesitation. And some just don’t like it for other reasons like the syntax, learning curve or other reasons. There’s also still a host of memory-related things Rust doesn’t fix like stack overflows, leaks, bitflips, unsafe context code, and just bad coding practices in general.

        • @Octorine@midwest.social
          link
          fedilink
          English
          28 months ago

          I blame C++. When these kernel hackers hear about how they should switch to this shiny new language that’s going to make their code so much cleanser and more manageable, I don’t blame them for thinking it’s all bullshit. It was last time.

          • @refalo@programming.dev
            link
            fedilink
            5
            edit-2
            8 months ago

            To be fair, there’s nothing wrong with only using the parts of C++ you want. If you avoid things like templates, exceptions, RTTI etc. then e.g. your compile times will not suffer like people always complain about, your error messages will not be cryptic, plus you’ll have stronger typing, easier/safer lifetime management with ctor/dtors and easier to read code from class usage.

            Personally I think Swift has great potential if it can get past the speed and cross-platform issues, as it was designed by (among others) some C++ committee folks, and so it feels a lot more familiar than say, Rust, plus it fixes a lot of long-standing issues.

            There is also an Indian kernel fork that allows C++ drivers.

      • rhabarbaOP
        link
        fedilink
        38 months ago

        I understand the reluctance but it feels to me like arguing “we should just stick with COBOL because it works.”

        For those depending on COBOL code that does the job and has been doing it just well for a few decades, there are approximately zero good reasons to not stick with it.

        • @linearchaos@lemmy.world
          link
          fedilink
          English
          138 months ago
          1. Eventually all the people who know and are good at cobol will die.
          2. A while before that happens, the people who know it will continually demand more money for their rare skills.
          3. Eventually, the cobol systems out there will need to interface new systems in some way it wasn’t designed to and it’ll be more expensive to shoehorn the remote system than to let the ancient beast retire.
          • @mryessir@lemmy.sdf.org
            link
            fedilink
            18 months ago

            Even if, we are talking about the Linux kernel. Our entire ecosystem builds upon C. People choosing C for new projects because it is the common denominator.

            If Rust should be adopted in the kernel faster, patches should be send which comment how each line addresses issues of memory management solved and elaborations for rust specific patterns unfamiliar to a C dev.

            Lurkers will pick up Rust that way as well.

            Each Rust dev had to pick it up and therefore should be able to enable other - probably more experienced - Linux kernel hacker to provide reviewable patches.

            It shouldn’t be the other way around, else you are just stepping on the efforts the other human provided to that project.

            • @linearchaos@lemmy.world
              link
              fedilink
              English
              18 months ago

              I’m not against Rust. I’d like to see something less dangerous with memory than C, but I don’t think it’s time yet for the kernel to leave C.

              It’s pretty clean, stable, it’s working well at the moment and the C language (or variants of it) is/are still actively used everywhere. I think the kernel universally going Rust will be a long road of everything under the sun going there first before it’s ported in earnest.

              • @nous@programming.dev
                link
                fedilink
                English
                28 months ago

                The goal ATM is simply to allow people to write new drivers in rust, not convert the whole kernel to rust. It will be a very long time, before more core parts would be allowed to be written in rust let alone rewriting any existing core kernel code. Which is all fine as new drivers are a large part where bugs are added - older parts have had a long time for bugs to be found and fixed and so it is far less important to need to rewrite them.

                • @Auli@lemmy.ca
                  link
                  fedilink
                  English
                  17 months ago

                  Yes there is never old code with bugs that have been sitting there for decades.

        • @ayyy@sh.itjust.works
          link
          fedilink
          38 months ago

          Does it count as “doing it well” when every release has fixes for previous releases’ memory bugs?

    • @Petter1@lemm.ee
      link
      fedilink
      -28 months ago

      😂i wish my country switched from german to English because of how difficult it is to talk genderless in that language. Like, every fucking word seems to be gendered here.