From 78a29c41098db5e5f8291e0345a3cd443c52b329 Mon Sep 17 00:00:00 2001 From: Mel Date: Mon, 30 May 2022 02:02:53 +0000 Subject: Specify arg count on VM Functions --- pkg/lang/vm/value/cells.go | 2 +- pkg/lang/vm/value/data.go | 11 ++++++++--- pkg/lang/vm/value/value.go | 8 ++++---- 3 files changed, 13 insertions(+), 8 deletions(-) (limited to 'pkg/lang/vm/value') diff --git a/pkg/lang/vm/value/cells.go b/pkg/lang/vm/value/cells.go index 146402d..a700940 100644 --- a/pkg/lang/vm/value/cells.go +++ b/pkg/lang/vm/value/cells.go @@ -37,7 +37,7 @@ func (t TypeCell) DropCell(m mem.Mem) { typ := t.Get() for _, f := range typ.Methods { // Wrap data in a Value to drop it. - val := NewFunction(0).WithData(f) + val := NewFunction(0, 0).WithData(f) val.Drop(m) } diff --git a/pkg/lang/vm/value/data.go b/pkg/lang/vm/value/data.go index c0e5e9a..13716fd 100644 --- a/pkg/lang/vm/value/data.go +++ b/pkg/lang/vm/value/data.go @@ -116,6 +116,7 @@ type NullData struct{} type FunctionData struct { pc int + args uint env mem.Ptr native NativeFunc } @@ -126,6 +127,10 @@ func (f FunctionData) Pc() int { return f.pc } +func (f FunctionData) Args() uint { + return f.args +} + func (f FunctionData) Env() mem.Ptr { return f.env } @@ -135,14 +140,14 @@ func (f FunctionData) Native() NativeFunc { } func (f FunctionData) WithEnv(env mem.Ptr) FunctionData { - return FunctionData{pc: f.pc, env: env, native: f.native} + return FunctionData{pc: f.pc, args: f.args, env: env, native: f.native} } func (f FunctionData) String(_ mem.Mem) (string, error) { if f.native != nil { - return "", nil + return fmt.Sprintf("", f.args), nil } else { - return fmt.Sprintf("", f.pc), nil + return fmt.Sprintf("", f.args, f.pc), nil } } } diff --git a/pkg/lang/vm/value/value.go b/pkg/lang/vm/value/value.go index eb63503..05d3f09 100644 --- a/pkg/lang/vm/value/value.go +++ b/pkg/lang/vm/value/value.go @@ -48,12 +48,12 @@ func NewNull() Value { return Value{t: CORE_TYPE_NULL} } -func NewFunction(pc int) Value { - return Value{t: CORE_TYPE_FUNCTION, d: FunctionData{pc: pc}} +func NewFunction(pc int, args uint) Value { + return Value{t: CORE_TYPE_FUNCTION, d: FunctionData{pc: pc, args: args}} } -func NewNativeFunction(f NativeFunc) Value { - return Value{t: CORE_TYPE_FUNCTION, d: FunctionData{native: f}} +func NewNativeFunction(f NativeFunc, args uint) Value { + return Value{t: CORE_TYPE_FUNCTION, d: FunctionData{native: f, args: args}} } func NewObject() Value { -- cgit 1.4.1