Add instruction pointers

This commit is contained in:
Starfflame 2021-05-17 20:59:46 -05:00
parent 6959c473f8
commit e8bcb186e3
3 changed files with 59 additions and 19 deletions

View File

@ -59,5 +59,9 @@ function CoreHelpers.parseToken(state: Environment): string
return token
end
function CoreHelpers.reset(env: Environment)
env.instructionPointer.index = 0 -- will get incremented after this instruction
end
return CoreHelpers

View File

@ -22,11 +22,18 @@ local type DataStructures = record
new: function(WordInfo, function(Environment), boolean): WordInfo
end
record Pointer
index: number
referant: {number: any}
deref: function(self: Pointer): any
inc: function(self: Pointer)
new: function(self: Pointer): Pointer
end
record Environment
dataStacks: {Stack}
compilerStack: Stack
returnStack: Stack
activeDataStack: Stack
interrupts: {function(Environment)}
activeInputStream: InputStream
@ -36,13 +43,14 @@ local type DataStructures = record
addDataStack: function(Environment, Stack)
changeCompilerStack: function(Environment, Stack)
changeActiveDataStack: function(Environment, number)
instructionPointer: Pointer
end
end
local Stack, Environment, Dictionary, WordInfo = DataStructures.Stack, DataStructures.Environment, DataStructures.Dictionary, DataStructures.WordInfo
local Pointer = DataStructures.Pointer
local wordi_mt = {__index = WordInfo}
function WordInfo:new(funct: function(Environment, ...: any), imm: boolean): WordInfo
return setmetatable({func = funct, immediate = imm} as WordInfo, wordi_mt)
@ -109,6 +117,17 @@ function Dictionary:new(): Dictionary
return setmetatable({contents = {}} as Dictionary, dict_mt)
end
function Pointer:deref(): any
return self.referant[self.index]
end
function Pointer:inc()
self.index = self.index + 1
end
local pointer_mt = {__index = Pointer}
function Pointer:new(): Pointer
return setmetatable({referant = {}, index = 1} as Pointer, pointer_mt)
end
return DataStructures

View File

@ -4,8 +4,9 @@ local istream = require("InputStream")
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
local reset = helpers.reset
local machineEnvironment = Environment:new()
local Pointer = ds.Pointer
function standardInputRefill(): string
local input = io.read().."\n"
return input
@ -17,23 +18,39 @@ machineEnvironment.activeInputStream = standardInputStream
machineEnvironment.activeDataStack = Stack:new()
table.insert(machineEnvironment.dictionaries, CoreWords)
while(true) do
skipWhitespace(machineEnvironment)
local token: string = parseToken(machineEnvironment)
if isNumber(token) then
machineEnvironment.activeDataStack:push(tonumber(token))
else
for i, dictionary in ipairs(machineEnvironment.dictionaries) do
local wordinfo = dictionary:lookup(token)
if wordinfo then
(wordinfo as WordInfo).func(machineEnvironment)
goto continue
function outerInterpreter(env: Environment)
while(true) do
skipWhitespace(env)
local token: string = parseToken(env)
if isNumber(token) then
env.activeDataStack:push(tonumber(token))
else
for i, dictionary in ipairs(env.dictionaries) do
local wordinfo = dictionary:lookup(token)
if wordinfo then
(wordinfo as WordInfo).func(env)
goto continue
end
end
print(string.format('%q ?', token))
::continue::
end
print(string.format('%q ?', token))
::continue::
end
end
end
function innerInterpreter(env: Environment)
while(true) do
(env.instructionPointer:deref() as function(Environment))(env)
env.instructionPointer:inc()
end
end
local interpreterInstructions = {outerInterpreter, reset}
local startPointer = Pointer:new()
startPointer.referant = interpreterInstructions
startPointer.index = 0
machineEnvironment.instructionPointer = startPointer
outerInterpreter(machineEnvironment)