We've been evaluating a number of C++ successor languages for @ladybirdbrowser, and the one best suited to our needs appears to be @SwiftLang 🪶
Over the last few months, I've asked a bunch of folks to pick some little part of our project and try rewriting it in the different languages we were evaluating. The feedback was very clear: everyone preferred Swift!
Why do we like Swift?
First off, Swift has both memory & data race safety (as of v6). It's also a modern language with solid ergonomics.
Something that matters to us a lot is OO. Web specs & browser internals tend to be highly object-oriented, and life is easier when you can model specs closely in your code. Swift has first-class OO support, in many ways even nicer than C++.
The Swift team is also investing heavily in C++ interop, which means there's a real path to incremental adoption, not just gigantic rewrites.
Strong ties to Apple?
Swift has historically been strongly tied to Apple and their platforms, but in the last year, there's been a push for "swiftlang" to become more independent. (It's now in a separate GitHub org, no longer in "apple", for example).
Support for non-Apple platforms is also improving, as is the support for other, LSP-based development environments.
What happens next?
We aren't able to start using it just yet, as the current release of Swift ships with a version of Clang that's too old to grok our existing C++ codebase. But when Swift 6 comes out of beta this fall, we will begin using it!
No language is perfect, and there are a lot of things here that we don't know yet. I'm not aware of anyone doing browser engine stuff in Swift before, so we'll probably end up with feedback for the Swift team as well.
I'm super excited about this! We must steer Ladybird towards memory safety, and the first step is selecting a successor language that we can begin adopting very soon. 🤓🐞
• • •
Missing some Tweet in this thread? You can try to
force a refresh
When I was 7 years old, my schooled offered me to skip a grade and I accepted. My teachers (and parents) all made a big deal about how clever I was etc.
This quickly became a chip on my shoulder that took decades for me to articulate and admit to.
In retrospect, skipping 1st grade was a big mistake. Suddenly, I was the youngest person in every group, always the least physically and mentally mature, etc.
I became insecure about this, and would often act out to show my classmates how "mature" I was..
This was a major factor in me starting to drink excessively at 14. Proving to my 1-year-older mates that I could handle as much alcohol as them (or more!) seemed super important at the time.
I was the smallest & weakest guy in class, but at least I could out-self-destruct them!
Robin was the first major contributor and worked on all kinds of things:
- Sound card driver (SB16)
- AudioServer (mixing daemon)
- Event loops
- Thread scheduling
- Windowing system