elm/libraries/Native/Show.js

96 lines
3.7 KiB
JavaScript
Raw Normal View History

Elm.Native.Show = {};
Elm.Native.Show.make = function(elm) {
2013-04-07 15:40:27 +00:00
elm.Native = elm.Native || {};
elm.Native.Show = elm.Native.Show || {};
if (elm.Native.Show.values) return elm.Native.Show.values;
var NList = Elm.Native.List.make(elm);
var List = Elm.List.make(elm);
var Maybe = Elm.Maybe.make(elm);
var JS = Elm.JavaScript.make(elm);
var Dict = Elm.Dict.make(elm);
var Json = Elm.Json.make(elm);
var Tuple2 = Elm.Native.Utils.make(elm).Tuple2;
2013-04-07 15:40:27 +00:00
var toString = function(v) {
2013-09-01 23:40:27 +00:00
var type = typeof v;
if (type === "function") {
2013-05-06 00:48:50 +00:00
var name = v.func ? v.func.name : v.name;
return '<function' + (name === '' ? '' : ': ') + name + '>';
2013-09-01 23:40:27 +00:00
} else if (type === "boolean") {
2013-04-07 15:40:27 +00:00
return v ? "True" : "False";
2013-09-01 23:40:27 +00:00
} else if (type === "number") {
2013-04-07 15:40:27 +00:00
return v+"";
} else if ((v instanceof String) && v.isChar) {
return "'" + addSlashes(v) + "'";
} else if (type === "string") {
return '"' + addSlashes(v) + '"';
2013-09-01 23:40:27 +00:00
} else if (type === "object" && '_' in v) {
2013-04-07 15:40:27 +00:00
var output = [];
for (var k in v._) {
for (var i = v._[k].length; i--; ) {
output.push(k + " = " + toString(v._[k][i]));
}
}
for (var k in v) {
if (k === '_') continue;
output.push(k + " = " + toString(v[k]));
}
if (output.length === 0) return "{}";
return "{ " + output.join(", ") + " }";
2013-09-01 23:40:27 +00:00
} else if (type === "object" && 'ctor' in v) {
if (v.ctor.substring(0,6) === "_Tuple") {
2013-04-07 15:40:27 +00:00
var output = [];
for (var k in v) {
if (k === 'ctor') continue;
output.push(toString(v[k]));
}
return "(" + output.join(",") + ")";
} else if (v.ctor === "::") {
var output = '[' + toString(v._0);
2013-04-07 15:40:27 +00:00
v = v._1;
while (v.ctor === "::") {
output += "," + toString(v._0);
2013-04-07 15:40:27 +00:00
v = v._1;
}
return output + ']';
} else if (v.ctor === "[]") {
2013-04-07 15:40:27 +00:00
return "[]";
} else if (v.ctor === "RBNode" || v.ctor === "RBEmpty") {
var cons = F3(function(k,v,acc){return NList.Cons(Tuple2(k,v),acc)});
var list = A3(Dict.foldr, cons, NList.Nil, v);
var name = "Dict";
if (list.ctor === "::" && list._0._1.ctor === "_Tuple0") {
2013-04-07 15:40:27 +00:00
name = "Set";
list = A2(List.map, function(x){return x._0}, list);
}
return name + ".fromList " + toString(list);
} else {
var output = "";
for (var i in v) {
if (i === 'ctor') continue;
var str = toString(v[i]);
var parenless = str[0] === '{' || str[0] === '<' || str.indexOf(' ') < 0;
2013-04-07 15:40:27 +00:00
output += ' ' + (parenless ? str : '(' + str + ')');
}
return v.ctor + output;
}
}
2013-09-01 23:40:27 +00:00
if (type === 'object' && 'recv' in v) return '<signal>';
return "<internal structure>";
2013-04-07 15:40:27 +00:00
};
function addSlashes(str) {
return str.replace(/\\/g, '\\\\')
.replace(/\n/g, '\\n')
.replace(/\t/g, '\\t')
.replace(/\r/g, '\\r')
.replace(/\v/g, '\\v')
.replace(/\0/g, '\\0')
.replace(/\'/g, "\\'")
.replace(/\"/g, '\\"');
2013-05-06 00:48:50 +00:00
}
2013-10-03 00:37:07 +00:00
return elm.Native.Show.values = { show:toString };
};