PLASM compiler crashes if invoked with a space between "+" and PLASM
ZornsLemma opened this issue · 6 comments
If I invoke the PLASM self-hosted compiler as "+ PLASM TEST.PLA", it crashes; here's a screenshot of this in an Apple II emulator:
I think at least part of the issue is that the core VM strips away the space between the "+" and "PLASM", so it's able to successfully execute the PLASM module, but the argument parsing code in the ARGS module returns "+" and then "PLASM" as the first and second arguments.
I think the actual crash is caused by PLASM trying to load itself as source code, as if we'd typed "+PLASM PLASM", and crashing because the file is not text; I seem to be able to get a similar crash by typing that. I don't know if this is worth fixing; perhaps just changing the parsing so the core VM and ARGS are consistent in handling a space between the leading "+" and the module name would be adequate.
ETA: The commit in my repo which references this just notes that I found the problem; I am playing around with alternative implementation details on the Acorn port, that commit is not any kind of fix or suggestion for this issue and you should just ignore github being helpful and mentioning it...
Actually I've been unfair in calling this a crash, it seems to generate an odd message but maybe that's fair enough given the invalid input. But it does seem a bit odd to have this parsing inconsistency.
Hi Dave,
Thanks for the response, I didn't really expect one so quickly!
I may be missing something, but one fix (untested, of course) would simply be to remove the last call to stripspaces() in parsecmd() in cmd.pla. That would shrink the core VM, not grow it, and I think it would make args.pla consistent with the core VM and get rid of this inconsistency - "+ PLASM" would then simply be invalid at the PLASMA prompt.
As for the compiler itself, I overreacted by calling it a crash. On the Acorn VM it spews out some random text which happens to include the "turn printer on" control code, and then the output hangs because there's no printer connected and the printer buffer fills up. I misinterpreted this as the VM/compiler actually having crashed the machine and that primed my brain to misinterpret the even better behaviour of it on the Apple. The behaviour of the compiler is a little weird but it's being given weird input, and I think it actually copes pretty well, so there's probably no need to go fiddling with it.
Not that I want to discourage you from having another look at it, I'm sure you'll come up with some cool stuff if you do look at it with fresh eyes!
Cheers.
Steve
PS Yes, the emulator is a very nice piece of work - perfect too for someone like me who doesn't necessarily want the faff of installing an emulator on my machine but wants to play with something like PLASMA.
PPS In terms of freeing up space in the core VM, one thing I've just done in the Acorn VM is that I don't copy the command line into a separate buffer for use later by args.pla before parsing it in cmd.pla. I have a single copy of it and the command parsing in cmd.pla has been tweaked to avoid modifying the command line, so it's left intact for args.pla to parse later. This avoids the need to set memory aside for a second copy of the command line. It may be you could do something similar on the Apple. (Or it may be there's a hidden flaw in this approach I simply haven't noticed yet. :-)) You can see - though it's perhaps a bit noisy - this change on my rather misnamed jit2 branch: ZornsLemma@245d506