aboutsummaryrefslogtreecommitdiffstats
path: root/jsre/pp_js.go
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2015-03-15 14:13:39 +0800
committerzelig <viktor.tron@gmail.com>2015-03-15 14:13:39 +0800
commitda44097800caf2e20ec8e067f8700e59a43a5e06 (patch)
tree59caea58032056fbc42395cf3a1eb53f5f75e46c /jsre/pp_js.go
parent2a5fbced7fb1fe976367f3f9f334c6ca657e7917 (diff)
downloadgo-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar.gz
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar.bz2
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar.lz
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar.xz
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.tar.zst
go-tangerine-da44097800caf2e20ec8e067f8700e59a43a5e06.zip
jsre:
- require became loadScript(), no require is supplied - bignumber_js.go: heredoc v2.0.3 minified fixed for otto Regexp incompatibility https://github.com/robertkrimen/otto#regular-expression-incompatibility - bignumber.min.js also updated in mist/assets/ext - ethereum_js.go: latest master minified - assetPath in constructor - Eval/Exec/Handle/ToVal nice API - jsre tests
Diffstat (limited to 'jsre/pp_js.go')
-rw-r--r--jsre/pp_js.go55
1 files changed, 55 insertions, 0 deletions
diff --git a/jsre/pp_js.go b/jsre/pp_js.go
new file mode 100644
index 000000000..fd80ae68b
--- /dev/null
+++ b/jsre/pp_js.go
@@ -0,0 +1,55 @@
+package jsre
+
+const pp_js = `
+function pp(object) {
+ var str = "";
+
+ if(object instanceof Array) {
+ str += "[ ";
+ for(var i = 0, l = object.length; i < l; i++) {
+ str += pp(object[i]);
+
+ if(i < l-1) {
+ str += ", ";
+ }
+ }
+ str += " ]";
+ } else if(typeof(object) === "object") {
+ str += "{ ";
+ var last = Object.keys(object).pop()
+ for(var k in object) {
+ str += k + ": " + pp(object[k]);
+
+ if(k !== last) {
+ str += ", ";
+ }
+ }
+ str += " }";
+ } else if(typeof(object) === "string") {
+ str += "\033[32m'" + object + "'";
+ } else if(typeof(object) === "undefined") {
+ str += "\033[1m\033[30m" + object;
+ } else if(typeof(object) === "number") {
+ str += "\033[31m" + object;
+ } else if(typeof(object) === "function") {
+ str += "\033[35m[Function]";
+ } else {
+ str += object;
+ }
+
+ str += "\033[0m";
+
+ return str;
+}
+
+function prettyPrint(/* */) {
+ var args = arguments;
+ var ret = "";
+ for(var i = 0, l = args.length; i < l; i++) {
+ ret += pp(args[i]) + "\n";
+ }
+ return ret;
+}
+
+var print = prettyPrint;
+`