forth-stuff/ForthInterpreter.tl

46 lines
1.5 KiB
Plaintext
Raw Normal View History

local CoreWords = require("CoreWords")
local ds = require("DataStructures")
local istream = require("InputStream")
local Stack, Dictionary, WordInfo, State = ds.Stack, ds.Dictionary, ds.WordInfo, ds.State
2021-05-12 08:32:25 +00:00
local machineState = State:new()
2021-05-12 08:32:25 +00:00
function standardInputRefill(): string
local input = io.read().."\n"
return input
2021-05-12 08:32:25 +00:00
end
local standardInputStream = istream:new(standardInputRefill)
machineState.activeInputStream = standardInputStream
machineState.activeDataStack = Stack:new()
table.insert(machineState.dictionaries, CoreWords)
2021-05-12 08:32:25 +00:00
local getActiveDataStacks = (CoreWords:lookup("GetActiveData") as WordInfo).func
local areNumbers = (CoreWords:lookup("areNumbers") as WordInfo).func
local isNumber = (CoreWords:lookup("isNumber") as WordInfo).func
local isWhitespace = (CoreWords:lookup("isWhitespace") as WordInfo).func
local popTwoOperands = (CoreWords:lookup("popTwo") as WordInfo).func
local skipWhitespace = (CoreWords:lookup("skipWhitespace") as WordInfo).func
local parseToken = (CoreWords:lookup("parseToken") as WordInfo).func
2021-05-12 08:32:25 +00:00
while(true) do
skipWhitespace(machineState)
local token: string = parseToken(machineState)
if isNumber(machineState, token) then
machineState.activeDataStack:push(tonumber(token))
else
for i, dictionary in ipairs(machineState.dictionaries) do
local wordinfo = dictionary:lookup(token)
if wordinfo then
(wordinfo as WordInfo).func(machineState)
2021-05-13 05:40:08 +00:00
goto continue
end
end
print(string.format('%q ?', token))
2021-05-13 05:40:08 +00:00
::continue::
end
2021-05-12 08:32:25 +00:00
end