Since February this year, I’ve been working on a project that I’ve wanted to work on for quite some time now - a new programming language. After about 200 commits, things are now in working condition!
The project has just reached the 0.1.0 release and it doesn’t do much yet - it certainly isn’t useful. But it’s got all the absolute basics of a programming language: values of different types, variables, conditionals, loops, functions (closures) and even a proof-of-concept HTTP server! :P
My motivation for the project was (and still is) two-fold. One was a desire to learn how to make a real-world, usable programming language. And the second was because there were things that I did not like in all the other programming languages I’ve worked with and I wanted to see if it was possible to solve those problems.
The general complaint I have about dynamically typed scripting languages is that code written in them seems somewhat (for the lack of a better word) “weak”. Sure, sometimes the overhead of type annotations and similar things isn’t worth it (behold Python’s duck typing), but sometimes, you’d prefer to have some kind of checking for your code. On the other hand, statically typed languages tend to be overly verbose with all their type declarations (though inference has gotten pretty darn good), even for code that should ideally be very concise. And both of these tend to have
None, or even crazy old
The compromise that TypeScript provides seemed great for handling types. Don’t explicitly use them when you don’t want to - either by preference or because you’re prototyping - and use them if you want to - because you want some type safety, or because you’re done prototyping and now want production-ready code. And sum types like
Option seem great for handling cases where you’d otherwise use
This is the direction along which I’m trying to build Balloon. Similar to Rust’s (which Balloon is written in) “choosing your guarantees", I think it’s a great idea to let the programmer choose what level of safety - or any other guarantee - they want in their program and try to provide the best guarantees you can anyway. Along those lines, Balloon does not currently have anything like
null at all (but it also does not have declaration without initialization yet, nor does it have sum types or
Option, there’s definitely lots more work to do :P) and it already has a typchecker that type checks programs without being given any type annotations or declarations (similar to what Facebook’s Flow does).
There’s definitely quite some way to go before Balloon becomes real-world “usable” and a long way to go before it becomes “useful”, but I’m happy with where it’s gotten to right now. I’ll probably be writing more about the kind of things I want to see in Balloon in the future, but for now, I look forward to someone wanting to help me out with the project given this very brief introduction.