aboutsummaryrefslogtreecommitdiffstats
path: root/ethutil/script.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-05-05 21:55:43 +0800
committerobscuren <geffobscura@gmail.com>2014-05-05 21:55:43 +0800
commit2096b3a9edb3289a8f30da81704181dec7b39917 (patch)
tree1a38e845f32ecfc94a73546ec4cfdb971b740830 /ethutil/script.go
parent6a86c517c4f4b372cad0ae1d92e926a482eac5ba (diff)
parentfedd4c906ff9f6139cb2d88e4f1adefbf6ea81a6 (diff)
downloadgo-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.tar.gz
go-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.tar.zst
go-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.zip
Merge branch 'release/poc5-rc1'
Diffstat (limited to 'ethutil/script.go')
-rw-r--r--ethutil/script.go41
1 files changed, 41 insertions, 0 deletions
diff --git a/ethutil/script.go b/ethutil/script.go
new file mode 100644
index 000000000..620658025
--- /dev/null
+++ b/ethutil/script.go
@@ -0,0 +1,41 @@
+package ethutil
+
+import (
+ "fmt"
+ "github.com/obscuren/mutan"
+ "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)
+ }
+
+ return byteCode, nil
+}
+
+func CompileScript(script string) ([]byte, []byte, error) {
+ // Preprocess
+ mainInput, initInput := mutan.PreProcess(script)
+ // Compile main script
+ mainScript, err := Compile(mainInput)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ // Compile init script
+ initScript, err := Compile(initInput)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ return mainScript, initScript, nil
+}