diff options
| author | Marc Vertes <mvertes@free.fr> | 2024-03-13 16:05:35 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-03-13 16:05:35 +0100 |
| commit | cd75db8c69365ac5c8e967f9a941b9fb128b0b00 (patch) | |
| tree | 868788ae55507736784a1db73585d1536394c47e | |
| parent | 60170bad25f912e0ba44e4c0095b54f6e26e307e (diff) | |
| parent | a7f99d19978e5bf337be3e778f5376f346f69c4a (diff) | |
Merge pull request #5 from ajnavarro/fix/small-fixes
Fix: small README fixes and throw an error if expression not supported.
| -rw-r--r-- | parser/README.md | 2 | ||||
| -rw-r--r-- | parser/expr.go | 3 | ||||
| -rw-r--r-- | vm/README.md | 2 |
3 files changed, 5 insertions, 2 deletions
diff --git a/parser/README.md b/parser/README.md index 118d9aa..b233248 100644 --- a/parser/README.md +++ b/parser/README.md @@ -13,7 +13,7 @@ The input of parser is a list of tokens produced by the scanner. Multiple tokens are processed at once. The minimal set to get meaningful results (not an error or nil) is a complete statement. -The output of parser is also a list of tokens, to be consummed by +The output of parser is also a list of tokens, to be consumed by the compiler to produce bytecode. The output tokens set is identical to the bytecode instructions set except that: diff --git a/parser/expr.go b/parser/expr.go index 91c093f..e4cef1a 100644 --- a/parser/expr.go +++ b/parser/expr.go @@ -1,6 +1,7 @@ package parser import ( + "fmt" "log" "strconv" @@ -86,6 +87,8 @@ func (p *Parser) ParseExpr(in Tokens) (out Tokens, err error) { out = append(out, t) vl++ ops = append(ops, scanner.Token{Str: "index", Id: lang.Index, Pos: t.Pos}) + default: + return nil, fmt.Errorf("expression not supported yet: %q", t.Str) } if len(selectors) > 0 { out = append(out, selectors...) diff --git a/vm/README.md b/vm/README.md index 92b1ac8..127da45 100644 --- a/vm/README.md +++ b/vm/README.md @@ -28,7 +28,7 @@ Structurally, the vm implements logical and arithmetic operators, condional jumps for `if`, `for` and `switch` control flow, and function call, return and frame management. -the memory state of the vm is a slice of Go interfaces (`[]any`). +the memory state of the vm is a slice of (`[]Value`), where `Value` is similar to a `reflect.Value`, containing pointers to value data and type. The whole vm is coded in a single function of 80 lines with no dependencies. The size will grow as we add missing instructions, but the |
