source/projects/shoggoth/src/python/ichor/bootstrap.py

89 lines
1.8 KiB
Python
Raw Normal View History

"""Shogoth bootstrap code.
Some utterly trivial functions and types that allow me to begin testing the VM.
Hopefully no "real" interpreter ever uses this code, since it's obviously replaceable.
"""
from .isa import Module, Opcode
2022-05-31 15:41:10 +00:00
2022-06-01 01:25:18 +00:00
from .typing import ProductExpr, SumExpr
2022-05-31 15:41:10 +00:00
BOOTSTRAP = Module()
NOT = BOOTSTRAP.define_function(
2022-06-01 01:04:14 +00:00
";/lang/shoggoth/v0/bootstrap/not;bool;bool",
[
Opcode.IF(target=3),
Opcode.FALSE(),
Opcode.RETURN(1),
Opcode.TRUE(),
Opcode.RETURN(1),
],
)
OR = BOOTSTRAP.define_function(
2022-06-01 01:04:14 +00:00
";/lang/shoggoth/v0/bootstrap/or;bool,bool;bool",
[
Opcode.IF(target=3),
Opcode.TRUE(),
Opcode.RETURN(1),
Opcode.IF(target=6),
Opcode.TRUE(),
Opcode.RETURN(1),
Opcode.FALSE(),
Opcode.RETURN(1)
],
)
AND = BOOTSTRAP.define_function(
2022-06-01 01:04:14 +00:00
";/lang/shoggoth/v0/bootstrap/and;bool,bool;bool",
[
Opcode.IF(target=3),
Opcode.IF(target=3),
Opcode.GOTO(target=5),
Opcode.FALSE(),
Opcode.RETURN(1),
Opcode.TRUE(),
Opcode.RETURN(1),
],
)
XOR = BOOTSTRAP.define_function(
2022-06-01 01:04:14 +00:00
";/lang/shoggoth/v0/bootstrap/xor;bool,bool;bool",
[
Opcode.DUP(nargs=2),
# !A && B
Opcode.CALLS(NOT),
Opcode.CALLS(AND),
Opcode.IF(target=6),
Opcode.TRUE(),
Opcode.RETURN(1),
# !B && A
Opcode.ROT(2),
Opcode.CALLS(NOT),
Opcode.CALLS(AND),
Opcode.IF(target=12),
Opcode.TRUE(),
Opcode.RETURN(1),
Opcode.FALSE(),
Opcode.RETURN(1),
],
)
TRUE = BOOTSTRAP.define_type(
2022-06-01 01:04:14 +00:00
"/lang/shoggoth/v0/true",
ProductExpr([]),
)
FALSE = BOOTSTRAP.define_type(
2022-06-01 01:04:14 +00:00
"/lang/shoggoth/v0/false",
ProductExpr([]),
)
BOOL = BOOTSTRAP.define_type(
2022-06-01 01:04:14 +00:00
"/lang/shoggoth/v0/bool",
SumExpr([TRUE, FALSE])
)