f68b169feb
* ChangeLog: Add copyright header. * build-aux/GNUmakefile.in (generate-ChangeLog): Append it as copyright footer. * BOOTSTRAP: Add copyright header. * scaffold/boot/2f-define-second-lambda.scm: Likewise. * scaffold/boot/39-global-define-override.scm: Likewise. * scaffold/boot/3a-global-define-lambda-override.scm: Likewise. * scaffold/boot/4f-string-split.scm: Likewise. * scaffold/boot/numbers.scm: Likewise. * scaffold/gc.scm: Likewise. * scaffold/b-0.mes: Remove. * doc/GNU-EVAL-APPLY: Remove. * doc/announce/README: New file. * doc/announce/ANNOUNCE: Move from doc/ANNOUNCE. * doc/announce/ANNOUNCE-0.10: Likewise. * doc/announce/ANNOUNCE-0.11: Likewise. * doc/announce/ANNOUNCE-0.12: Likewise. * doc/announce/ANNOUNCE-0.13: Likewise. * doc/announce/ANNOUNCE-0.14: Likewise. * doc/announce/ANNOUNCE-0.15: Likewise. * doc/announce/ANNOUNCE-0.16: Likewise. * doc/announce/ANNOUNCE-0.3: Likewise. * doc/announce/ANNOUNCE-0.4: Likewise. * doc/announce/ANNOUNCE-0.5: Likewise. * doc/announce/ANNOUNCE-0.6: Likewise. * doc/announce/ANNOUNCE-0.7: Likewise. * doc/announce/ANNOUNCE-0.8: Likewise. * doc/announce/ANNOUNCE-0.9: Likewise. * doc/announce/ANNOUNCE-2: Likewise. * doc/announce/UPDATE-0.13: Likewise. * doc/fosdem/README: New file. * doc/fosdem/fosdem.org: Add legalese. * doc/fosdem/fosdem.pdf: Regenerate. * doc/images/README: New file. * mes/module/mes/psyntax.pp.header: New file. * mes/module/mes/psyntax.pp: Add it to generated file.
46 lines
1.7 KiB
Plaintext
46 lines
1.7 KiB
Plaintext
Subject: on bootstrapping: introducing Mes
|
|
Date: Sun, 19 Jun 2016 13:08:02 +0200
|
|
|
|
Hi,
|
|
|
|
I have a minimal LISP-1.5-resembling interpreter in C that now can
|
|
also interpret itself
|
|
|
|
https://gitlab.com/janneke/mes
|
|
|
|
It was inspired by the seemingly often ignored bootstrapping question
|
|
made so painfully visible by GuixSD and by OriansJ with their self
|
|
hosting hex assembler project.
|
|
|
|
As a next step after a hex assembler I was thinking of getting Scheme up
|
|
and running and use that to create a tiny C compiler, probably using
|
|
PEG. For that I think we need define-syntax, which I had a peek at and
|
|
still scares the all-sorts-of-things out of me :-)
|
|
|
|
I searched for minimal Lisp/Scheme to get that going and found an
|
|
article called the Maxwell Equations of Software 1) with a pointer to
|
|
the 1962 LISP 1.5 paper by John McCarthy 2).
|
|
|
|
First I `implemented' Mes/LISP-1.5: the bottom half of page 13 and the
|
|
necessary helper procedures defined on pages 8-12 using Guile, removing
|
|
all but the primitives needed to run LISP-1.5/Mes (I think): car, cdr,
|
|
cond, cons, define, eq?, '()/nil, null?, pair? and quote. I cheated
|
|
with read, and with display and newline for debugging.
|
|
|
|
Then I translated the program into C and got rid of read by using
|
|
getchar/ungetchar.
|
|
|
|
It's been great fun and now I'm kind of stuck a bit at the point of
|
|
implementing macros. I have a simplistic version in C but want to
|
|
remove that again --I like the idea of having the absolute minimal LISP
|
|
interpreter in C-- and only introduce macros after having bootstrapped
|
|
into the LISP/Mes domain.
|
|
|
|
Greetings,
|
|
Jan
|
|
|
|
1) http://www.michaelnielsen.org/ddi/lisp-as-the-maxwells-equations-of-software/
|
|
2)
|
|
http://www.softwarepreservation.org/projects/LISP/book/LISP%201.5%20Programmers%20Manual.pdf
|
|
|