aboutsummaryrefslogtreecommitdiffstats
path: root/ethutil/script.go
diff options
context:
space:
mode:
Diffstat (limited to 'ethutil/script.go')
-rw-r--r--ethutil/script.go50
1 files changed, 23 insertions, 27 deletions
diff --git a/ethutil/script.go b/ethutil/script.go
index 94e401406..af4ca6a38 100644
--- a/ethutil/script.go
+++ b/ethutil/script.go
@@ -3,39 +3,35 @@ package ethutil
import (
"fmt"
"github.com/obscuren/mutan"
+ "github.com/obscuren/mutan/backends"
+ "github.com/obscuren/serpent-go"
"strings"
)
// General compile function
-func Compile(script string) ([]byte, error) {
- byteCode, errors := mutan.Compile(strings.NewReader(script), false)
- if len(errors) > 0 {
- var errs string
- for _, er := range errors {
- if er != nil {
- errs += er.Error()
- }
- }
- return nil, fmt.Errorf("%v", errs)
- }
+func Compile(script string) (ret []byte, err error) {
+ c := strings.Split(script, "\n")[0]
- return byteCode, nil
-}
+ if c == "#!serpent" {
+ byteCode, err := serpent.Compile(script)
+ if err != nil {
+ return nil, err
+ }
-func CompileScript(script string) ([]byte, []byte, error) {
- // Preprocess
- mainInput, initInput := mutan.PreParse(script)
- // Compile main script
- mainScript, err := Compile(mainInput)
- if err != nil {
- return nil, nil, err
- }
+ return byteCode, nil
+ } else {
+ compiler := mutan.NewCompiler(backend.NewEthereumBackend())
+ byteCode, errors := compiler.Compile(strings.NewReader(script))
+ if len(errors) > 0 {
+ var errs string
+ for _, er := range errors {
+ if er != nil {
+ errs += er.Error()
+ }
+ }
+ return nil, fmt.Errorf("%v", errs)
+ }
- // Compile init script
- initScript, err := Compile(initInput)
- if err != nil {
- return nil, nil, err
+ return byteCode, nil
}
-
- return mainScript, initScript, nil
}