Commit 086acd12 authored by obscuren's avatar obscuren

Added pre processing of script data

parent 11651615
...@@ -69,7 +69,7 @@ func (c *Closure) Address() []byte { ...@@ -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 { ...@@ -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 { ...@@ -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 { ...@@ -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 ...@@ -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) { ...@@ -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
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment