Mu now type-checks calls to functions implemented in unsafe SubX machine code. I have to provide signatures explicitly, and they look like this:
http://akkartik.github.io/mu/html/linux/400.mu.html
https://github.com/akkartik/mu
Mu now type-checks calls to functions implemented in unsafe SubX machine code. I have to provide signatures explicitly, and they look like this:
http://akkartik.github.io/mu/html/linux/400.mu.html
https://github.com/akkartik/mu
Since the language is starting to seem stable, and the error messages have been getting better, and I managed to build some little programs without too much trouble, I figured it was time to start actually talking about the Mu language in the documentation. So make way SubX, and yield center-stage to Mu.
https://github.com/akkartik/mu/blob/master/README.md#toolchain
https://github.com/akkartik/mu/blob/master/mu.md
https://archive.org/details/akkartik-2min-2020-07-01
Mini rant on prototypes. While a prototype like this would possibly be less work to build on say Python, I think building it atop Mu provides some significant advantages. Research prototypes are not entirely throw-away; the goal with them is to accumulate learning even while the codebase churns. Because it relies on so few dependencies, Mu is more robust to bitrot. This makes it easy for someone else to reproduce an experiment. Even relatively far in the future. I really hope we can converge on a shared platform something like this for research prototypes. It does still need graphics and sound, though..
https://github.com/akkartik/mu
Mu now checks for most variable accesses if the variable is still live, and it's register hasn't been clobbered by some other variable. The extra-burdensome parts of programming in Mu are hopefully now not very burdensome.
Next up: testable syscalls for screen and keyboard. But I might take a break first. My RSI has been acting up.
https://github.com/akkartik/mu
Mu now checks all function calls.
Pass in the wrong type = error.
Save a result to the wrong type = error.
Save a result to the wrong register = error.
There are automated tests for error messages.
I estimate this change protects against 60% of the most common mistakes. Checking the most recent variable in a register should provide another 20%. And I hopefully have TODOs for the remainder to gradually whack away.
https://github.com/akkartik/mu
For the most part, Mu is exclusively 32-bit. No long/short nonsense here. However, I do like strings. Eventually even UTF-8 strings. So, minimal byte support. Mostly they behave like 32-bit values. You can't store them on the stack. (Because x86 reasons.)
As a test, I built a little calculator app: http://akkartik.github.io/mu/html/linux/apps/arith.mu.html. This app also shows off multiple return values.
Read more: https://github.com/akkartik/mu
https://archive.org/details/akkartik-2min-2020-06-07
The code is terribly ugly, and there are zero tests. But it did help flush out three bugs in Mu. Next steps:
(Background. Repo.)
Alice in Wonderland by Lewis Carroll
Poems by e e cummings (https://en.wikipedia.org/wiki/E._E._Cummings)
A text-mode paginator for text files. Think `more`, but no ncurses, no termbox, no libc, just Linux syscalls.
2-minute demo video:
https://archive.org/details/akkartik-2min-2020-05-29