diff options
| author | Marc Vertes <marc.vertes@tendermint.com> | 2023-10-12 10:51:58 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-10-12 10:51:58 +0200 |
| commit | 37b9da32d3b911091deb254f6cba2a137c471287 (patch) | |
| tree | b4451de0fa0473a937a77d39fd1f8a4f87c8f60d /codegen/interpreter.go | |
| parent | a21b9b12ad865a19ff687645082f9093c4101039 (diff) | |
move to a direct byte code compiler (#8)
* chore: refactor to keep only the new parser and bytecode vm
* scanner: remove Token.value field
* scanner: remove scanner.kind field
* chore: move language specification in lang package
This avoid a cyclic dependency in scanner_test which can now use
the golang/GoSpec language specification for Go.
* clean code
* scanner: export scanner fields
Also parser now generate function calls, including externals.
* chore: fix lint issues
* parser: handle strings
* wip
* parser: implement support for 'if, else, else if' statements
Resolving labels in the compiler still in progress.
* parser: support if statements, improve compiler
* improve handling of functions
* improve support of local variables
* scanner: trim leading and trailing spaces
* fixes to make fibonacci work
* parser: improve README, fix function parameters parsing
Diffstat (limited to 'codegen/interpreter.go')
| -rw-r--r-- | codegen/interpreter.go | 53 |
1 files changed, 0 insertions, 53 deletions
diff --git a/codegen/interpreter.go b/codegen/interpreter.go deleted file mode 100644 index 18cc5f8..0000000 --- a/codegen/interpreter.go +++ /dev/null @@ -1,53 +0,0 @@ -package codegen - -import ( - "os" - - "github.com/gnolang/parscan/parser" - "github.com/gnolang/parscan/vm1" -) - -const debug = true - -type Interpreter struct { - *parser.Parser - *Compiler - *vm1.Machine -} - -func NewInterpreter(p *parser.Parser) *Interpreter { - return &Interpreter{p, NewCompiler(), &vm1.Machine{}} -} - -func (i *Interpreter) Eval(src string) (res any, err error) { - n := &parser.Node{} - if n.Child, err = i.Parse(src, n); err != nil { - return res, err - } - if debug { - n.Dot(os.Getenv("DOT"), "") - } - codeOffset := len(i.Code) - dataOffset := 0 - if codeOffset > 0 { - // All data must be copied to the VM the first time only (re-entrance). - dataOffset = len(i.Data) - } - i.PopExit() // Remove last exit from previous run (re-entrance). - if err = i.CodeGen(n); err != nil { - return res, err - } - i.Push(i.Data[dataOffset:]...) - i.PushCode(i.Code[codeOffset:]...) - i.PushCode([]int64{0, vm1.Exit}) - i.SetIP(max(codeOffset, i.Entry)) - err = i.Run() - return i.Top(), err -} - -func max(a, b int) int { - if a > b { - return a - } - return b -} |
