Commit Graph

74 Commits

Author SHA1 Message Date
Kartik K. Agaram 9cbaad0811 obsolete argument 2022-01-09 07:50:09 -08:00
Kartik Agaram 53d69dd1c5 keep 'grapheme-stack'
We want to at least document intent there.
2021-11-09 09:29:56 -08:00
Kartik K. Agaram d253a31828 rename grapheme to code-point-utf8
Longer name, but it doesn't lie. We have no data structure right now for
combining multiple code points. And it makes no sense for the notion of
a grapheme to conflate its Unicode encoding.
2021-11-09 08:12:11 -08:00
Kartik K. Agaram d1808995b2 copy back some error messages from linux/ 2021-11-09 07:30:44 -08:00
Kartik K. Agaram 77207192ea . 2021-09-13 04:53:38 -07:00
Kartik K. Agaram 6e05a8fa27 fix bad terminology: grapheme -> code point
Unix text-mode terminals transparently support utf-8 these days, and so
I treat utf-8 sequences (which I call graphemes in Mu) as fundamental.

I then blindly carried over this state of affairs to bare-metal Mu,
where it makes no sense. If you don't have a terminal handling
font-rendering for you, fonts are most often indexed by code points and
not utf-8 sequences.
2021-08-29 22:20:09 -07:00
Kartik K. Agaram c45371b319 compute-offset: literal index 2021-08-25 22:19:24 -07:00
Kartik K. Agaram 9b62454975 . 2021-08-25 21:46:22 -07:00
Kartik K. Agaram 2d2c46da5c another long-overdue bugfix
If I forgot a 'var', Mu would interpret the ':' in the var declaration
as a named block, and all parsing after would be thrown off.

Perhaps I should use separate characters for defining blocks vs vars.
2021-08-22 23:06:51 -07:00
Kartik K. Agaram 791a71e27e fix a long-standing bug in Mu's translator
While all test pass, this change is disquieting. When I first designed
Mu I deliberately chose to exclude literal strings from most primitive
instructions both for type-checking and to avoid silently passing
through strange constructions. Nobody really needs to add a string to a
number, and am I sure no SubX instruction will cause a memory safety
issue when passed a string literal instead of a number?

But clearly I have no tests encoding this desire. And any string literal
could be replaced by an integer literal containing the exact same value,
so what are we protecting against anyway.

Let me fix the bug for now. If I run into problems I'll come back and do
this right.
2021-08-22 22:10:02 -07:00
Kartik K. Agaram ba4a3c5be7 start throwing error on labels too far for /disp8
While I'm doing this I might as well lay out a story I don't seem to
have told before in this commit log.

I translated Mu programs to Linux before I did so to bare metal like I
do in the top-level these days. The translator programs still run from
the linux/ directory. However they don't always have good error
messages. As long as I was translating to Linux this wasn't a huge deal
because I always translated Mu programs using the bootstrap translator
in linux/bootstrap/ -- which has great error messages. However,
linux/bootstrap/ can't build bare-metal programs because boot.subx uses
real-mode instructions that aren't supported. As a hack I created a
script called misc_checks that at least tries to run everything besides
boot.subx -- even though translation can never succeed. If I run it and
get to errors about unknown variables I know everything besides
boot.subx raised no errors.

Having labels too far in /disp8 args is is the single biggest reason we
need the misc_checks hack. Hopefully it's now obsolete.
2021-08-22 21:40:03 -07:00
Kartik K. Agaram 5c26d765c7 . 2021-08-22 21:24:36 -07:00
Kartik K. Agaram 827dd4a7fe start throwing error on duplicate label
One less error that's only in the bootstrap phase.

On the other hand, for simplicity I got rid of the ability to override
the Entry label. One less special case, but we're also going further
from the ability to run subsets of layers. We haven't really been
exercising it for a long time, though (commit 7842, March 2021 when we
made baremetal the default).
2021-08-22 21:09:28 -07:00
Kartik K. Agaram b41aed4a9a . 2021-08-22 20:24:37 -07:00
Kartik K. Agaram b625c6304e support non-line-oriented processing in next-word
Immediately this simplifies support for comments in image data.
2021-07-29 20:07:13 -07:00
Kartik K. Agaram d0f39e75ca . 2021-07-20 08:43:25 -07:00
Kartik K. Agaram 13ef425825 . 2021-07-20 08:43:25 -07:00
Kartik K. Agaram 5f254d0d02 .
Update run instructions for linux/app/ examples, and make sure they are
correct.
2021-07-20 08:43:25 -07:00
Kartik K. Agaram 0b9ea19c98 .
Delete the examples from Crenshaw. They're extremely rudimentary, and
they were really just trial runs for the Mu toolchain.
2021-07-20 08:43:25 -07:00
Kartik K. Agaram de5e1931ed start work on running the Mu toolchain atop Mu 2021-07-19 23:24:03 -07:00
Kartik K. Agaram 13ca31ba09 . 2021-07-16 09:24:02 -07:00
Kartik K. Agaram 44d26b77c4 . 2021-07-16 08:28:56 -07:00
Kartik K. Agaram c7e1fed2b9 . 2021-06-27 07:32:08 -07:00
Kartik Agaram 614d0ecff4 . 2021-06-15 20:56:41 -07:00
Kartik Agaram 10687ed8bb . 2021-06-15 20:50:55 -07:00
Kartik K. Agaram b28899fe37 .
Support newlines. Looks like we pasted the input from the browser window
during the pairing session.
2021-06-15 20:38:53 -07:00
Kartik K. Agaram 03e6248c14 example program by Sumeet Agarwal
https://adventofcode.com/2017/day/1
https://archive.org/details/2021-06-02-akkartik-sumeet
2021-06-15 20:38:45 -07:00
Kartik K. Agaram f99cd767a4 periodic run of misc_checks
I should really stop using /disp8 jumps at the top-level given how inconvenient
it is to check for overly large offsets.
2021-06-12 22:34:22 -07:00
Kartik K. Agaram e375f0104c shell: expand set of possible errors
Requires a change to mu.subx, to unify literal strings with generic
  (addr array _)
2021-06-08 20:21:39 -07:00
Kartik K. Agaram 0ab5f6fb3a mu.subx: support bitwise not 2021-05-16 21:47:47 -07:00
Kartik K. Agaram eede9e222f . 2021-05-14 23:15:46 -07:00
Kartik K. Agaram 7bad89bdf9 free up '_' for top-level SubX functions 2021-05-14 22:36:38 -07:00
Kartik K. Agaram a3f5da0333 . 2021-05-14 20:29:22 -07:00
Kartik K. Agaram ff8ec9bcff insert a compile phase to emit some debug info 2021-05-14 11:54:42 -07:00
Kartik K. Agaram 2df1d1a730 . 2021-05-14 09:06:06 -07:00
Kartik K. Agaram 63a9263aff .
Fix a stack bug in survey_baremetal. I'm not sure how my tests weren't
crashing, but I won't bother digging further.
2021-05-14 08:09:04 -07:00
Kartik K. Agaram a42f4613f7 . 2021-05-14 08:05:24 -07:00
Kartik K. Agaram 9b37c03de9 . 2021-05-14 07:59:32 -07:00
Kartik K. Agaram cd6412129f .
Yet another step in the slow divergence of survey_baremetal from its survey_elf
roots.
2021-05-09 13:21:08 -07:00
Kartik K. Agaram f9f419af71 support checking overflow flag everywhere 2021-05-08 21:49:50 -07:00
Kartik K. Agaram 888b4cd8ea always check for null in 'index' instructions 2021-05-07 21:04:45 -07:00
Kartik K. Agaram e74050ade4 always check for null in 'get' instructions 2021-05-07 18:25:43 -07:00
Kartik K. Agaram 25791d9032 opt: don't clear streams of bytes on the stack
All over the Mu code I reflexively initialize all variables just to keep
unsafe SubX easy to debug. However I don't really need to do this for safe
Mu code, since the type- and memory-safety already ensures we can't read
from streams beyond what we've written to them. For now I'll continue mostly
with the same approach, but with one exception for streams of bytes.

Mu programs often emit traces, and in doing so they often use temporary
streams of bytes that can get quite long. I'm hoping avoiding initializing
KBs of data all over the place will measurably speed up the Mu shell.
2021-04-21 19:30:28 -07:00
Kartik K. Agaram 7b2d39b8d4 an interface approximating stack traces 2021-04-20 23:27:13 -07:00
Kartik K. Agaram 316bf37541 undo previous commit 2021-04-05 21:16:45 -07:00
Kartik K. Agaram 928fd47d68 snapshot: stupid debugging session
I spent a while building a little keyboard scancode printer:

  $ ./translate ex1.mu &&  qemu-system-i386 disk.img

..and wondering why up-arrow was 0x48 in hex but 724 in decimal. I ended
up paranoidly poking at a bunch of crap (though there _is_ a cool chromatography-based
debugging technique in 126write-int-decimal.subx) before I realized:

  - 724 just has one extra digit over the correct answer
  - the 0xe0 scan code is a 3-digit number in decimal -- and the final digit is '4'

There's nothing actually wrong.
2021-04-05 21:15:06 -07:00
Kartik Agaram 40c1a2b595 . 2021-04-04 20:14:43 -07:00
Kartik Agaram 77c747379e make online help more obvious 2021-04-04 20:12:43 -07:00
Kartik K. Agaram d8d9dfa855 some hacky checks for common errors
They're not really baked into the regular compilation process; I have to
remember to run them if I see strange behavior.
2021-03-31 23:16:01 -07:00
Kartik Agaram 16f2bd1174 . 2021-03-29 18:47:52 -07:00