You are viewing a single thread.
View all comments
44 points

Assembly code is for writing C compilers, and C compilers are for writing Lisp interpreters.

permalink
report
reply
19 points

I saw a Scheme interpreter written in assembly running a C compiler written in Scheme.

permalink
report
parent
reply
29 points

permalink
report
parent
reply
4 points
*

There’s actually good reasons for this design. It’s easy to write a Scheme interpreter in assembly, but it’s hard to write a C compiler in assembly that handles everything correctly. Much rather write it in higher level language if possible and Scheme lowers the bar to getting there, so you can get away from using assembly as quickly as possible. Or you can copy somebody else’s Scheme implementation of a C compiler because now you’re platform independent.

Then you can write your C compiler in C (or steal a better compiler already written in C) and close the loop. For your final step, you use the C compiler to compile itself.

permalink
report
parent
reply
14 points
*

Only the most very basic compilers. C compilers are in C mainly.

permalink
report
parent
reply
11 points
*

Not the first C compiler obviously. According to this Stack Overflow post, BCPL* begat B, which begat C. Language self-hosting is pretty fascinating.

*Perhaps BCPL was originally written in assembly; I’m not certain: https://github.com/SergeGris/BCPL-compiler

permalink
report
parent
reply
6 points

Talking about bootstrap here?

permalink
report
parent
reply
1 point

Indeed

permalink
report
parent
reply
2 points

And that’s how you get the Thompson hack

permalink
report
parent
reply
10 points
Deleted by creator
permalink
report
parent
reply
4 points

Back in High School in the 80’s me and a buddy wrote a Z-80 editor assembler in TRS-DOS BASIC.

It was not rocket science.

permalink
report
parent
reply
4 points
*

I never did get very far with the TRS-80 Editor Assembler, but that was my first exposure to such things.

I also remember the BASIC code for the Dancing Daemon which was replete with PEEKs and POKEs, such that much of it was written in machine code.

permalink
report
parent
reply

Programmer Humor

!programmerhumor@lemmy.ml

Create post

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

  • Posts must be relevant to programming, programmers, or computer science.
  • No NSFW content.
  • Jokes must be in good taste. No hate speech, bigotry, etc.

Community stats

  • 5.4K

    Monthly active users

  • 886

    Posts

  • 9K

    Comments

Community moderators