Lobsters.

We’ve been searching for a memory-safe programming language to replace C++ in Ladybird for a while now. We previously explored Swift, but the C++ interop never quite got there, and platform support outside the Apple ecosystem was limited. Rust is a different story. The ecosystem is far more mature for systems programming, and many of our contributors already know the language. Going forward, we are rewriting parts of Ladybird in Rust.

  • fuzzywombat@lemmy.world
    link
    fedilink
    English
    arrow-up
    11
    arrow-down
    2
    ·
    1 day ago

    I’ve suddenly lost all interest in this browser’s development. From what I’ve heard, LLMs are pretty bad at generating Rust code for some reason. If they used LLM to bulk convert C++ code to Rust, the quality of the code is questionable at best.

    • greyfrog@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      3
      arrow-down
      1
      ·
      1 day ago

      Surely you read the article?

      "The requirement from the start was byte-for-byte identical output from both pipelines. "

      The bytecode from C++ is identical to the Rust output.

      • WhyJiffie@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        2
        ·
        edit-2
        23 hours ago

        I don’t think it’s possible to write rust code that compiles to the exact same binary as c++. compilers make different optimizations, and make overall a different structure, especially across languages.

        I think they meant the rust library produces the same output from the same input as the c++ library.

        if llms indeed generate worse rust code than for other languages, that’s not that big of a problem because the compiler will catch a lot of mistakes. if it compiles, it will run, and no memory safety bugs unless unsafe is also used. the llm could pick the wrong functions for some uses, but that should be caught relatively easily with testing, which can be automated partly

        edit: I was wrong, they indeed say that. this is weird.

  • chunes@lemmy.world
    link
    fedilink
    English
    arrow-up
    8
    ·
    1 day ago

    The things people criticize are so fucking brainless these days. AI this, slop that.

    Not a single one of you made fun of “let’s rewrite it in Rust.” You can’t even elevate to the level of mildly funny parroting.

    • baggachipz@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      5
      arrow-down
      1
      ·
      1 day ago

      “Let’s stop halfway through our multi-year project to rewrite it in another language” is peak nerd shiny distraction. I say this as one who resists the urge every day. Way to delay your project by several more years, clown.

      • Zangoose@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        ·
        1 day ago

        All things considered the way they’re approaching the migration is fine enough - they’re only moving specific portions at a time, they’re not stopping C++ development, and they’re making sure it doesn’t introduce regressions. Adopting a memory-safe language for something like a browser makes sense because it completely eliminates that class of vulnerabilities.

        The problem is the way they’re approaching the code itself. From their wording, it sounds like they’re relying on AI heavily for both writing and reviewing the code. Rust has a steeper learning curve than most languages and is very different from C++. They even mention in the blog that their current Rust code looks like C++ code ported over. If they don’t take the time to actually learn Rust before adopting it, it’ll just lead to security logic issues that their AI couldn’t catch because C++ and Rust don’t always behave the same way. And that’s completely ignoring all of the other ethical/technical issues with AI

        • baggachipz@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          3
          ·
          1 day ago

          Be that as it may, the time to choose Rust was at the beginning. It existed then, but they made their technology choice. Continuing to develop in C++ while doing the migration just means more throwaway code and duplicated effort. This decision is truly the worst of both worlds.

  • arcine@jlai.lu
    link
    fedilink
    English
    arrow-up
    72
    arrow-down
    5
    ·
    2 days ago

    I was enthusiastic about LadyBird until I learnt that the guy leading the project i s a white supremacist, via pivot-to-ai.

    Now I hope either someone else takes it over, or that it crashes and burns.

    • greyfrog@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      5
      arrow-down
      1
      ·
      1 day ago

      I don’t think you should be able to make claims like this without hard proof.

      Do you have any information about this?

      Edit: So I found out where you read that, and that article is wayyy over thinking that comment.

      I think the Twitter comment could be taken multiple ways and it would be fair to give them the benefit of the doubt.

      • Zangoose@lemmy.world
        link
        fedilink
        English
        arrow-up
        11
        ·
        1 day ago

        How many times do I have to give him the benefit of the doubt though?

        First it was the “using they in documentation is political ideology” Github issue, then he publicly defended DHH when people called him out for being a white supremacist, he implied tech companies are discriminating against white people with diversity policies, and he tweeted that he hopes young people will carry on Charlie Kirk’s legacy.

        If one or two of these things happened in isolation, I could maybe understand giving him the benefit of the doubt as a non-American (for that last one) non-native English speaker. But all of these things taken together? I personally don’t think I can look past that.

        • greyfrog@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          3
          ·
          edit-2
          24 hours ago

          To be fair I hadn’t heard of some of these, so I think you’re right. I wouldn’t go so far as as to say he’s a white supremacist but it definitely seems like he has an “ideology”

          Edit: The more I read about it the more it’s pissing me off. Especially defending DHH who wrote that trash article about London (I’m not a Londoner but I’m a Brit who’s there enough with work to know he’s talking absolute shit).

          • Zangoose@lemmy.world
            link
            fedilink
            English
            arrow-up
            2
            ·
            24 hours ago

            That’s fair, I assume most people probably aren’t following ladybird that closely so it’s easy to miss. It just bothers me because shrugging off small individual problems and ignoring a bigger trend is arguably what let people like DHH get a platform in the first place.

    • 0x0@infosec.pub
      link
      fedilink
      English
      arrow-up
      8
      arrow-down
      22
      ·
      2 days ago

      If any creator can separate work from personal and the product is good I really couldn’t care less with what they use their own time for.

      I’m pretty sure you could find people with other unsavoury opinions in the devteams for both chrome and firefox, what then?

  • TheOneCurly@feddit.online
    link
    fedilink
    English
    arrow-up
    139
    arrow-down
    3
    ·
    2 days ago

    Yeah seems about right for this project. I really wanted this to be a serious browser, but nothing about this dude is serious.

    Also I know he backed this statement up with much better testing but these AI brainrot things people say kill me: “I ran multiple passes of adversarial review, asking different models to analyze the code for mistakes and bad patterns.”

      • XLE@piefed.social
        link
        fedilink
        English
        arrow-up
        8
        ·
        2 days ago

        Based on the content of that article alone (especially near the bottom), I don’t think it’s run by a racist at all. Can confirm via their social media presence.

        • Fizz@lemmy.nz
          link
          fedilink
          English
          arrow-up
          2
          arrow-down
          2
          ·
          2 days ago

          Weird. I would not feel comfortable using that domain. I thought i was reading a neo Nazis blog on the issue.

          • Telorand@reddthat.com
            link
            fedilink
            English
            arrow-up
            7
            ·
            2 days ago

            Can you explain why you feel that way? “Hyperborea” is not a term I’m familiar with vis a vis Nazism.

              • Telorand@reddthat.com
                link
                fedilink
                English
                arrow-up
                11
                ·
                2 days ago

                Sigh of course it’s a Nordic thing. I should have guessed. White nationalists also love other Heathen/Norse symbolism.

                Good to be careful, so thanks for educating me.

              • blankwire@lemmy.world
                link
                fedilink
                English
                arrow-up
                4
                ·
                2 days ago

                The author explains why he chose the name on his site. I don’t think this is a neo-nazi / white nationalist thing despite the irony.

                • Fizz@lemmy.nz
                  link
                  fedilink
                  English
                  arrow-up
                  4
                  ·
                  2 days ago

                  Yeah he picked it back in 2000s and its aged badly. Not his fault

    • 0x0@infosec.pub
      link
      fedilink
      English
      arrow-up
      2
      arrow-down
      20
      ·
      2 days ago

      If any creator can separate work from personal and the product is good I really couldn’t care less with what they use their own time for.

      I’m pretty sure you could find people with other unsavoury opinions in the devteams for both chrome and firefox, what then? Lynx?

  • cabbage@piefed.social
    link
    fedilink
    English
    arrow-up
    38
    ·
    2 days ago

    I would of course love to see ladybird succeed, but it has seemed problematic from the start in my opinion. Servo seems much more serious.

    I also like that Servo is developing an engine, not a browser as such. Seems like a good idea to keep the two separated.

  • Matty_r@programming.dev
    link
    fedilink
    English
    arrow-up
    16
    arrow-down
    1
    ·
    2 days ago

    The worst part is they are doing themselves a disservice by not rewriting it by hand - have they really learnt enough Rust to know how to effectively rewrite the other parts of the engine as they say? Doubtful - they’ll probably just do everything through AI stuff going forward.

  • tocano@piefed.social
    link
    fedilink
    English
    arrow-up
    16
    arrow-down
    1
    ·
    2 days ago

    I was enthusiastic about this project. But I am afraid these recent tangents will only reduce momentum.

  • Dæmon S.@calckey.world
    link
    fedilink
    arrow-up
    11
    arrow-down
    5
    ·
    2 days ago

    @[email protected] @[email protected]

    Ah, the smell of irony by the morning! Adopting a programming language often praised by its “safety”, while the entire pretension of “safety” is alchemically transmuted into a sewage and deliberately flushed up (not down) by a clanker who drinks from the cesspool with the same determination and thirst that of a Chevy Opala gurgling down entire Olympic pools worth of gasoline.

    Being serious now, the foreseeable future for Web browsing is definitely depressing: Chromium needs no introduction (used to be an interesting browser until Google’s mask “don’t be evil” fell and straightforwardly revealed their corporate face and farce), Firefox have been “welcoming the new AI overlords” for a while, text browsers (such as Lynx) are far from feasible for a CAPTCHA(and Anubis)-driven web… now, one of the latest and fewest glimmers of hope, an alternative Web browser engine, is becoming the very monster the fight against which was promised to be the launchpad purpose (“They who fights with monsters should be careful lest they thereby become a monster”). I wouldn’t be surprised if Servo were to enshittify, too. Being able to choose among the sameness is such a wonderful thing, isn’t it?

    I mean, I’m not the average Lemmy user who got this (understandably) deep hatred against AI, I am able to hold a nuanced view and finding quite interesting uses (especially when it comes to linguistics) for the clankers (especially the “open-weighted” ones). However, this, to shoving AI everywhere and using AI to “code for you”, it’s a whole different story. A software should be programmed in the way programming (as posited by Ada Lovelace) was intended to, not “vibe coded” by a fancy auto-completer who can’t (yet) deal with Turing completeness, especially when it comes to a whole miniature operational system that browsers became nowadays. When coding a whole OS, AI shouldn’t even be touched by a two million light-years pole, let alone by a two-feet pole.

    • INeedMana@piefed.zip
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 day ago

      Chromium needs no introduction (used to be an interesting browser until Google’s mask “don’t be evil” fell and straightforwardly revealed their corporate face and farce), Firefox have been “welcoming the new AI overlords” for a while, text browsers (such as Lynx) are far from feasible for a CAPTCHA(and Anubis)-driven web…

      To me the hope lies in Firefox forks

      • Dæmon S.@calckey.world
        link
        fedilink
        arrow-up
        2
        ·
        1 day ago

        @[email protected] @[email protected]

        Yeah, me too. Unfortunately, the forks can only get so far in removing upstream AI garbage and other proprietary/corporate-oriented whistles-and-bells. If, say, some AI feature becomes so ingrained inside Firefox upstream, so deeply it ends up becoming some hard dependency for fundamental functioning of the browser (i.e. a feature that, if removed at the code-level, would render Firefox simply unable to function), no WaterFox, IronFox, Fennec or LibreWolf would be able to keep up with the latest versions: they’d either need to do a hard fork trying to independently maintain an entire codebase for a browser, or they’d need to use downgraded versions.

        Not even to say about licensing shenanigans. We’ve seen many open-source projects suddenly changing their licensing to include legalese thin letters. We’ve seen open-source projects requiring developers to sign up some kind of NDA before being allowed to contribute with code. Seems like initially-open licenses aren’t written on stone when it comes to big projects, and Firefox is a big project.

        The universe of open-source software is being slowly hijacked by corporate interests. This is not different with Firefox, which (as I said in another reply to someone in this thread a few minutes ago) is Mozilla’s main product (if not the main product, it’s certainly among their main projects). The same Mozilla which has been pivoting to AI (e.g. acquisition of Anonym; subtle phrasing changes from “About Firefox” page which used to state how “Firefox will never sell your data”, now this phrase is gone).

        I use WaterFox on a daily basis. It’s by far the best browser I’ve been using. I tried LibreWolf but it doesn’t really likes my Portuguese ABNT2 keyboard (which has accents I use often), even after disabling ResistFingerprint, so I ended up sticking with WaterFox. On mobile, I use Fennec on a daily basis, and I’m worried about the end of “sideloading” on Android which will likely mess with its installation. But I’m aware of how both browsers rely on upstream code from Mozilla Firefox, whose enshittification is already an ongoing phenomenon. And that’s really depressing when it comes to the future of browser landscape, because we’re hoping for a true alternative. Servo is the last bastion of said hope (until it gets EEE’d by corporate interests, given how Linux Foundation itself is increasingly surrounded by corpos.

        I’m more of a GNU/Stallman person who values autonomy and libreness as non-negotiable principles. I’m only using Android because I’m stuck with it due to certain societal impositions (banks and gov apps), otherwise I’d be long using a custom phone, which wouldn’t even be Linux, but something way more “unorthodox” for a phone such as FreeBSD or Illumos/OpenIndianna, systems of which I already used on a PC environment and got quite fond of.

        • WhyJiffie@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          1
          ·
          12 hours ago

          We’ve seen open-source projects requiring developers to sign up some kind of NDA before being allowed to contribute with code.

          you mean the DCOs? those are nothing like NDAs. if not, which ones you mean?

      • Dæmon S.@calckey.world
        link
        fedilink
        arrow-up
        0
        ·
        2 days ago

        @[email protected] @[email protected]

        Oh, right, WebKit, I forgot mentioning it, thanks for reminding me of it!

        It’s the engine I likely used the least throughout my digital existence. I mean, I likely used Lynx more than I used WebKit, hence my forgetfulness.

        However, if we’re talking about the WebKit-based Linux browsers (such as Konqueror), IIRC, they’re a bit out of spec when it comes to the “modern Web”: WebKit’s adoption of latest specs tends to be slower than Firefox and Chromium.

        Now, if we’re talking about Safari specifically, then… it’s part of Apple’s walled garden, one where even “Firefox from App Store” is actually a reskinned Safari (at least in iOS).

        Be it Safari or Konqueror, deep inside, the WebKit engine seems to me like the “Apple’s Chromium”, so mentioning WebKit doesn’t really improve the awful prospect for browser engines that we’re facing nowadays.

        • woelkchen@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          ·
          1 day ago

          However, if we’re talking about the WebKit-based Linux browsers (such as Konqueror), IIRC, they’re a bit out of spec when it comes to the “modern Web”: WebKit’s adoption of latest specs tends to be slower than Firefox and Chromium.

          WebKit-GTK is up to date. 30 seconds of research in your favorite search engine and you would have found it out.

          • Dæmon S.@calckey.world
            link
            fedilink
            arrow-up
            1
            ·
            1 day ago

            @[email protected] @[email protected]

            It takes the same 30 seconds of using caniuse.com (screenshot below), which doesn’t list WebKit-GTK specifically, but lists Safari (which is WebKit under the hood), for it to become clear how many things are missing from Safari implementation (which is WebKit).

            To be fair, yes, there are many bleeding edge features, some of them implemented only on WebKit/Safari, but those Safari-only features are kind of proprietary features (prefixed by -webkit-). Similarly, there are indeed many features still missing from Firefox while already implemented for the two other engines (such as CSS @function).

            But my point, which I should’ve gone into further detail earlier, is that WebKit, primarily maintained by Apple (originally authored by Apple, and a trademark of Apple since 2013), doesn’t have the same, browser-focused teams found on Mozilla (whose main product is Firefox) and Google (whose main product is advertisement through their platforms, including Chrome, so Chrome is part of their main focus just because that’s essential to keep the ads running and telemetry sneaking on the user). Apple is more focused on other businesses, such as hardware and UI, Safari and WebKit are their side-project.

            Screenshot of the "Mixed support" section of caniuse.com comparing Chrome, Safari and Firefox browsers side-by-side.