forth-stuff/Interpreters.tl

75 lines
2.0 KiB
Plaintext
Raw Normal View History

local ds = require("DataStructures")
local Stack, Dictionary, WordInfo, Environment = ds.Stack, ds.Dictionary, ds.WordInfo, ds.Environment
local helpers = require("CoreHelpers")
local isNumber, skipWhitespace, parseToken = helpers.isNumber, helpers.skipWhitespace, helpers.parseToken
2021-05-20 03:04:04 +00:00
local istream = require("InputStream")
local CoreWords = require("CoreWords")
local Pointer = ds.Pointer
local type Interpreters = record
inner: function(Environment)
outer: function(Environment)
end
function Interpreters.start(env: Environment)
table.insert(env.dictionaries, CoreWords)
2021-05-20 03:04:04 +00:00
local interpreterInstructions = {}
table.insert(interpreterInstructions, Interpreters.outer)
table.insert(interpreterInstructions, helpers.reset)
2021-05-26 04:27:18 +00:00
table.insert(env.recognizers, helpers.recNumber)
table.insert(env.recognizers, helpers.recWord)
2021-05-20 03:04:04 +00:00
local startPointer = Pointer:new()
startPointer.referant = interpreterInstructions
env.instructionPointer = startPointer
Interpreters.inner(env)
2021-05-20 03:04:04 +00:00
end
2021-05-26 04:27:18 +00:00
function selectRecXT(env: Environment): function(Environment)
local dataStack = env.activeDataStack
if env.compileState then
dataStack:pop()
local selected = dataStack:pop()
dataStack:pop()
return selected as function(Environment)
else
dataStack:pop()
dataStack:pop()
return dataStack:pop() as function(Environment)
end
end
function Interpreters.outer(env: Environment)
2021-05-26 04:27:18 +00:00
local dataStack = env.activeDataStack
skipWhitespace(env)
local token: string | nil = parseToken(env)
if not token then
env.running = false
return
end
2021-05-26 04:27:18 +00:00
for _, rec in ipairs(env.recognizers) do
dataStack:push(token)
rec(env)
local result = dataStack:pop() as boolean
if not result then
token = dataStack:pop() as string
end
if result then
(selectRecXT(env))(env)
return
end
end
2021-05-26 04:27:18 +00:00
-- We did not recognize the token.
io.write("\""..token.."\"?\n")
end
2021-05-26 04:27:18 +00:00
function Interpreters.inner(env: Environment)
while(env.running) do
env.instructionPointer:deref() as function(Environment)(env)
env.instructionPointer:inc()
end
end
return Interpreters