Added pre processing of script data
This commit is contained in:
parent
116516158d
commit
086acd122b
@ -69,7 +69,7 @@ func (c *Closure) Address() []byte {
|
|||||||
return c.object.Address()
|
return c.object.Address()
|
||||||
}
|
}
|
||||||
|
|
||||||
type DebugHook func(op OpCode, mem *Memory, stack *Stack)
|
type DebugHook func(step int, op OpCode, mem *Memory, stack *Stack)
|
||||||
|
|
||||||
func (c *Closure) Call(vm *Vm, args []byte, hook DebugHook) []byte {
|
func (c *Closure) Call(vm *Vm, args []byte, hook DebugHook) []byte {
|
||||||
c.Args = args
|
c.Args = args
|
||||||
|
@ -312,6 +312,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) []byte {
|
|||||||
stack.Push(val)
|
stack.Push(val)
|
||||||
|
|
||||||
pc.Add(pc, big.NewInt(31))
|
pc.Add(pc, big.NewInt(31))
|
||||||
|
step++
|
||||||
case oPUSH20:
|
case oPUSH20:
|
||||||
pc.Add(pc, ethutil.Big1)
|
pc.Add(pc, ethutil.Big1)
|
||||||
data := closure.Gets(pc, big.NewInt(20))
|
data := closure.Gets(pc, big.NewInt(20))
|
||||||
@ -321,7 +322,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) []byte {
|
|||||||
stack.Push(val)
|
stack.Push(val)
|
||||||
|
|
||||||
pc.Add(pc, big.NewInt(19))
|
pc.Add(pc, big.NewInt(19))
|
||||||
|
step++
|
||||||
case oPOP:
|
case oPOP:
|
||||||
stack.Pop()
|
stack.Pop()
|
||||||
case oDUP:
|
case oDUP:
|
||||||
@ -410,7 +411,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) []byte {
|
|||||||
pc.Add(pc, ethutil.Big1)
|
pc.Add(pc, ethutil.Big1)
|
||||||
|
|
||||||
if hook != nil {
|
if hook != nil {
|
||||||
hook(op, mem, stack)
|
hook(step-1, op, mem, stack)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package ethutil
|
|||||||
import (
|
import (
|
||||||
_ "fmt"
|
_ "fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
"regexp"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Op codes
|
// Op codes
|
||||||
@ -132,3 +133,33 @@ func Assemble(instructions ...interface{}) (script []byte) {
|
|||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
Prepocessing function that takes init and main apart:
|
||||||
|
init() {
|
||||||
|
// something
|
||||||
|
}
|
||||||
|
|
||||||
|
main() {
|
||||||
|
// main something
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
func PreProcess(data string) (mainInput, initInput string) {
|
||||||
|
reg := "\\(\\)\\s*{([\\d\\w\\W\\n\\s]+?)}"
|
||||||
|
mainReg := regexp.MustCompile("main" + reg)
|
||||||
|
initReg := regexp.MustCompile("init" + reg)
|
||||||
|
|
||||||
|
main := mainReg.FindStringSubmatch(data)
|
||||||
|
if len(main) > 0 {
|
||||||
|
mainInput = main[1]
|
||||||
|
} else {
|
||||||
|
mainInput = data
|
||||||
|
}
|
||||||
|
|
||||||
|
init := initReg.FindStringSubmatch(data)
|
||||||
|
if len(init) > 0 {
|
||||||
|
initInput = init[1]
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user