Created
May 30, 2014 17:38
-
-
Save Apanatshka/4992ef379d9a82318035 to your computer and use it in GitHub Desktop.
Stresstest that shows the influence of duplicate tracking
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
time = fps 60 | |
longList = [1..1000000] | |
sumSig = sum <~ (sampleOn time <| constant longList) | |
main = asText <~ ((,) <~ time ~ sumSig) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE HTML> | |
<html> | |
<head> | |
<meta charset="UTF-8"> | |
<title>stresstest</title> | |
<script type="text/javascript"> | |
'use strict'; | |
var Elm = {}; Elm.Native = {}; Elm.Native.Graphics = {}; | |
var ElmRuntime = {}; ElmRuntime.Render = {}; | |
Elm.Native.Error = {}; | |
Elm.Native.Error.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Error = elm.Native.Error || {}; | |
if (elm.Native.Error.values) return elm.Native.Error.values; | |
function indent(lines) { | |
var msg = ''; | |
for (var i = 0; i < lines.length; ++i) { | |
msg += '<br/> ' + lines[i]; | |
} | |
return msg; | |
} | |
function Case(moduleName, span) { | |
var msg = indent(['Non-exhaustive pattern match in case-expression.', | |
'Make sure your patterns cover every case!']); | |
throw new Error('Runtime error in module ' + moduleName + ' (' + span + '):' + msg); | |
} | |
function If(moduleName, span) { | |
var msg = indent(['Non-exhaustive pattern match in multi-way-if expression.', | |
'It is best to use \'otherwise\' as the last branch of multi-way-if.']); | |
throw new Error('Runtime error in module ' + moduleName + ' (' + span + '):' + msg); | |
} | |
function raise(str) { throw new Error(str); } | |
return elm.Native.Error.values = { Case: Case, If: If, raise: raise }; | |
}; | |
Elm.Native.Trampoline = {}; | |
Elm.Native.Trampoline.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Trampoline = elm.Native.Trampoline || {}; | |
if (elm.Native.Trampoline.values) return elm.Native.Trampoline.values; | |
// trampoline : Trampoline a -> a | |
function trampoline(t) { | |
var tramp = t; | |
while(true) { | |
switch(tramp.ctor) { | |
case "Done": | |
return tramp._0; | |
case "Continue": | |
tramp = tramp._0({ctor: "_Tuple0"}); | |
continue; | |
} | |
} | |
} | |
return elm.Native.Trampoline.values = { | |
trampoline:trampoline | |
}; | |
}; | |
Elm.Native.Char = {}; | |
Elm.Native.Char.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Char = elm.Native.Char || {}; | |
if (elm.Native.Char.values) return elm.Native.Char.values; | |
function isBetween(lo,hi) { return function(chr) { | |
var c = chr.charCodeAt(0); | |
return lo <= c && c <= hi; | |
}; | |
} | |
var isDigit = isBetween('0'.charCodeAt(0),'9'.charCodeAt(0)); | |
var chk1 = isBetween('a'.charCodeAt(0),'f'.charCodeAt(0)); | |
var chk2 = isBetween('A'.charCodeAt(0),'F'.charCodeAt(0)); | |
return elm.Native.Char.values = { | |
fromCode : function(c) { return String.fromCharCode(c); }, | |
toCode : function(c) { return c.toUpperCase().charCodeAt(0); }, | |
toUpper : function(c) { return c.toUpperCase(); }, | |
toLower : function(c) { return c.toLowerCase(); }, | |
toLocaleUpper : function(c) { return c.toLocaleUpperCase(); }, | |
toLocaleLower : function(c) { return c.toLocaleLowerCase(); }, | |
isLower : isBetween('a'.charCodeAt(0),'z'.charCodeAt(0)), | |
isUpper : isBetween('A'.charCodeAt(0),'Z'.charCodeAt(0)), | |
isDigit : isDigit, | |
isOctDigit : isBetween('0'.charCodeAt(0),'7'.charCodeAt(0)), | |
isHexDigit : function(c) { return isDigit(c) || chk1(c) || chk2(c); } | |
}; | |
}; | |
Elm.Native.Debug = {}; | |
Elm.Native.Debug.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Debug = elm.Native.Debug || {}; | |
if (elm.Native.Debug.values) return elm.Native.Debug.values; | |
var show = Elm.Native.Show.make(elm).show; | |
function log(tag,value) { | |
var msg = tag + ': ' + show(value); | |
var process = process || {}; | |
if (process.stdout) { | |
process.stdout.write(msg); | |
} else { | |
console.log(msg); | |
} | |
return value; | |
} | |
return elm.Native.Debug.values = { | |
log: F2(log) | |
}; | |
}; | |
function F2(fun) { | |
function wrapper(a) { return function(b) { return fun(a,b) } } | |
wrapper.arity = 2; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F3(fun) { | |
function wrapper(a) { | |
return function(b) { return function(c) { return fun(a,b,c) }} | |
} | |
wrapper.arity = 3; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F4(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return fun(a,b,c,d) }}} | |
} | |
wrapper.arity = 4; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F5(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return function(e) { return fun(a,b,c,d,e) }}}} | |
} | |
wrapper.arity = 5; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F6(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return function(e) { return function(f) { | |
return fun(a,b,c,d,e,f) }}}}} | |
} | |
wrapper.arity = 6; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F7(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return function(e) { return function(f) { | |
return function(g) { return fun(a,b,c,d,e,f,g) }}}}}} | |
} | |
wrapper.arity = 7; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F8(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return function(e) { return function(f) { | |
return function(g) { return function(h) {return fun(a,b,c,d,e,f,g,h)}}}}}}} | |
} | |
wrapper.arity = 8; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function F9(fun) { | |
function wrapper(a) { return function(b) { return function(c) { | |
return function(d) { return function(e) { return function(f) { | |
return function(g) { return function(h) { return function(i) { | |
return fun(a,b,c,d,e,f,g,h,i) }}}}}}}} | |
} | |
wrapper.arity = 9; | |
wrapper.func = fun; | |
return wrapper; | |
} | |
function A2(fun,a,b) { | |
return fun.arity === 2 ? fun.func(a,b) : fun(a)(b); | |
} | |
function A3(fun,a,b,c) { | |
return fun.arity === 3 ? fun.func(a,b,c) : fun(a)(b)(c); | |
} | |
function A4(fun,a,b,c,d) { | |
return fun.arity === 4 ? fun.func(a,b,c,d) : fun(a)(b)(c)(d); | |
} | |
function A5(fun,a,b,c,d,e) { | |
return fun.arity === 5 ? fun.func(a,b,c,d,e) : fun(a)(b)(c)(d)(e); | |
} | |
function A6(fun,a,b,c,d,e,f) { | |
return fun.arity === 6 ? fun.func(a,b,c,d,e,f) : fun(a)(b)(c)(d)(e)(f); | |
} | |
function A7(fun,a,b,c,d,e,f,g) { | |
return fun.arity === 7 ? fun.func(a,b,c,d,e,f,g) : fun(a)(b)(c)(d)(e)(f)(g); | |
} | |
function A8(fun,a,b,c,d,e,f,g,h) { | |
return fun.arity === 8 ? fun.func(a,b,c,d,e,f,g,h) : fun(a)(b)(c)(d)(e)(f)(g)(h); | |
} | |
function A9(fun,a,b,c,d,e,f,g,h,i) { | |
return fun.arity === 9 ? fun.func(a,b,c,d,e,f,g,h,i) | |
: fun(a)(b)(c)(d)(e)(f)(g)(h)(i); | |
} | |
Elm.Native.Color = {}; | |
Elm.Native.Color.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Color = elm.Native.Color || {}; | |
if (elm.Native.Color.values) return elm.Native.Color.values; | |
var Utils = Elm.Native.Utils.make(elm); | |
function toCss(c) { | |
var format = ''; | |
var colors = ''; | |
if (c.ctor === 'RGBA') { | |
format = 'rgb'; | |
colors = c._0 + ', ' + c._1 + ', ' + c._2; | |
} else { | |
format = 'hsl'; | |
colors = (c._0 * 180 / Math.PI) + ', ' + | |
(c._1 * 100) + '%, ' + | |
(c._2 * 100) + '%'; | |
} | |
if (c._3 === 1) { | |
return format + '(' + colors + ')'; | |
} else { | |
return format + 'a(' + colors + ', ' + c._3 + ')'; | |
} | |
} | |
return elm.Native.Color.values = { | |
toCss:toCss | |
}; | |
}; | |
Elm.Native.Json = {}; | |
Elm.Native.Json.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Json = elm.Native.Json || {}; | |
if (elm.Native.Json.values) return elm.Native.Json.values; | |
var Maybe = Elm.Maybe.make(elm); | |
var Dict = Elm.Dict.make(elm); | |
var List = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function toJS(v) { | |
switch (v.ctor) { | |
case 'Null' : return null; | |
case 'String' : return v._0; | |
case 'Number' : return v._0; | |
case 'Boolean': return v._0; | |
case 'Object' : | |
var obj = {}; | |
var array = List.toArray(Dict.toList(v._0)); | |
for (var i = array.length; i--; ) { | |
var entry = array[i]; | |
obj[entry._0] = toJS(entry._1); | |
} | |
return obj; | |
case 'Array' : | |
var array = List.toArray(v._0); | |
for (var i = array.length; i--; ) { | |
array[i] = toJS(array[i]); | |
} | |
return array; | |
} | |
} | |
function toString(sep, value) { | |
return JSON.stringify(toJS(value), null, sep); | |
} | |
function fromJS(v) { | |
switch (typeof v) { | |
case 'string' : return { ctor:"String" , _0: v }; | |
case 'number' : return { ctor:"Number" , _0: v }; | |
case 'boolean': return { ctor:"Boolean", _0: v }; | |
case 'object' : | |
if (v === null) return { ctor:"Null" }; | |
if (v instanceof Array) { | |
var array = new Array(v.length); | |
for (var i = v.length; i--; ) { | |
array[i] = fromJS(v[i]); | |
} | |
return { | |
ctor:"Array", | |
_0: List.fromArray(array) | |
}; | |
} | |
var array = []; | |
for (var key in v) { | |
var value = fromJS(v[key]); | |
array.push(Utils.Tuple2(key, value)); | |
} | |
var list = List.fromArray(array); | |
return { | |
ctor:"Object", | |
_0: Dict.fromList(list) | |
}; | |
} | |
} | |
function fromString(str) { | |
try { | |
return Maybe.Just(fromJS(JSON.parse(str))); | |
} catch (e) { | |
return Maybe.Nothing; | |
} | |
} | |
return elm.Native.Json.values = { | |
toString : F2(toString), | |
fromString : fromString, | |
fromJS : fromJS, | |
toJS : toJS | |
}; | |
}; | |
Elm.Native.List = {}; | |
Elm.Native.List.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.List = elm.Native.List || {}; | |
if (elm.Native.List.values) return elm.Native.List.values; | |
if ('values' in Elm.Native.List) | |
return elm.Native.List.values = Elm.Native.List.values; | |
var Utils = Elm.Native.Utils.make(elm); | |
// TODO: Improve Nil handling | |
// We can change places like: if (xs.ctor === '[]') ... to if (xs === Nil) ... | |
// but only if we're confident Nil can only be defined once. | |
// Currently (27Mar2013) each module can have different instantiations, so multiple Nil objects can exist | |
// (and if they're used interchangeably then direct object comparison fails where ctor doesn't). | |
// So, this can only be fixed when modules initialisation is also fixed. | |
// The performance overhead of the .ctor calls is 5-10% according to jsperf (depending on fn + list size) | |
// (on firefox 19) | |
var Nil = { ctor:'[]' }; | |
// using freeze for every cons would be nice but is a huge (9x on firefox 19) | |
// performance penalty | |
function Cons(hd,tl) { return { ctor:"::", _0:hd, _1:tl }; } | |
function throwError(f) { | |
throw new Error("Function '" + f + "' expects a non-empty list!"); | |
} | |
function toArray(xs) { | |
var out = []; | |
while (xs.ctor !== '[]') { | |
out.push(xs._0); | |
xs = xs._1; | |
} | |
return out; | |
} | |
function fromArray(arr) { | |
var out = Nil; | |
for (var i = arr.length; i--; ) { | |
out = Cons(arr[i], out); | |
} | |
return out; | |
} | |
function range(lo,hi) { | |
var lst = Nil; | |
if (lo <= hi) { | |
do { lst = Cons(hi,lst) } while (hi-->lo); | |
} | |
return lst | |
} | |
function append(xs,ys) { | |
// append Text | |
if (xs.text || ys.text) { | |
return Utils.txt(Utils.makeText(xs) + Utils.makeText(ys)); | |
} | |
// append Strings | |
if (typeof xs === "string") return xs + ys; | |
// append Lists | |
if (xs.ctor === '[]') { return ys; } | |
var root = Cons(xs._0, Nil); | |
var curr = root; | |
xs = xs._1; | |
while (xs.ctor !== '[]') { | |
curr._1 = Cons(xs._0, Nil); | |
xs = xs._1; | |
curr = curr._1; | |
} | |
curr._1 = ys; | |
return root; | |
} | |
function head(v) { return v.ctor === '[]' ? throwError('head') : v._0; } | |
function tail(v) { return v.ctor === '[]' ? throwError('tail') : v._1; } | |
function last(xs) { | |
if (xs.ctor === '[]') { throwError('last'); } | |
var out = xs._0; | |
while (xs.ctor !== '[]') { | |
out = xs._0; | |
xs = xs._1; | |
} | |
return out; | |
} | |
function map(f, xs) { | |
var arr = []; | |
while (xs.ctor !== '[]') { | |
arr.push(f(xs._0)); | |
xs = xs._1; | |
} | |
return fromArray(arr); | |
} | |
// f defined similarly for both foldl and foldr (NB: different from Haskell) | |
// ie, foldl : (a -> b -> b) -> b -> [a] -> b | |
function foldl(f, b, xs) { | |
var acc = b; | |
while (xs.ctor !== '[]') { | |
acc = A2(f, xs._0, acc); | |
xs = xs._1; | |
} | |
return acc; | |
} | |
function foldr(f, b, xs) { | |
var arr = toArray(xs); | |
var acc = b; | |
for (var i = arr.length; i--; ) { | |
acc = A2(f, arr[i], acc); | |
} | |
return acc; | |
} | |
function foldl1(f, xs) { | |
return xs.ctor === '[]' ? throwError('foldl1') : foldl(f, xs._0, xs._1); | |
} | |
function foldr1(f, xs) { | |
if (xs.ctor === '[]') { throwError('foldr1'); } | |
var arr = toArray(xs); | |
var acc = arr.pop(); | |
for (var i = arr.length; i--; ) { | |
acc = A2(f, arr[i], acc); | |
} | |
return acc; | |
} | |
function scanl(f, b, xs) { | |
var arr = toArray(xs); | |
arr.unshift(b); | |
var len = arr.length; | |
for (var i = 1; i < len; ++i) { | |
arr[i] = A2(f, arr[i], arr[i-1]); | |
} | |
return fromArray(arr); | |
} | |
function scanl1(f, xs) { | |
return xs.ctor === '[]' ? throwError('scanl1') : scanl(f, xs._0, xs._1); | |
} | |
function filter(pred, xs) { | |
var arr = []; | |
while (xs.ctor !== '[]') { | |
if (pred(xs._0)) { arr.push(xs._0); } | |
xs = xs._1; | |
} | |
return fromArray(arr); | |
} | |
function length(xs) { | |
var out = 0; | |
while (xs.ctor !== '[]') { | |
out += 1; | |
xs = xs._1; | |
} | |
return out; | |
} | |
function member(x, xs) { | |
while (xs.ctor !== '[]') { | |
if (Utils.eq(x,xs._0)) return true; | |
xs = xs._1; | |
} | |
return false; | |
} | |
function reverse(xs) { return fromArray(toArray(xs).reverse()); } | |
function concat(xss) { | |
if (xss.ctor === '[]') return xss; | |
var arr = toArray(xss); | |
var xs = arr[arr.length-1]; | |
for (var i = arr.length-1; i--; ) { | |
xs = append(arr[i], xs); | |
} | |
return xs; | |
} | |
function all(pred, xs) { | |
while (xs.ctor !== '[]') { | |
if (!pred(xs._0)) return false; | |
xs = xs._1; | |
} | |
return true; | |
} | |
function any(pred, xs) { | |
while (xs.ctor !== '[]') { | |
if (pred(xs._0)) return true; | |
xs = xs._1; | |
} | |
return false; | |
} | |
function zip(xs, ys) { | |
var arr = []; | |
while (xs.ctor !== '[]' && ys.ctor !== '[]') { | |
arr.push(Utils.Tuple2(xs._0, ys._0)); | |
xs = xs._1; | |
ys = ys._1; | |
} | |
return fromArray(arr); | |
} | |
function zipWith(f, xs, ys) { | |
var arr = []; | |
while (xs.ctor !== '[]' && ys.ctor !== '[]') { | |
arr.push(A2(f, xs._0, ys._0)); | |
xs = xs._1; | |
ys = ys._1; | |
} | |
return fromArray(arr); | |
} | |
function zipWith3(f, xs, ys, zs) { | |
var arr = []; | |
while (xs.ctor !== '[]' && ys.ctor !== '[]' && zs.ctor !== '[]') { | |
arr.push(A3(f, xs._0, ys._0, zs._0)); | |
xs = xs._1; | |
ys = ys._1; | |
zs = zs._1; | |
} | |
return fromArray(arr); | |
} | |
function zipWith4(f, ws, xs, ys, zs) { | |
var arr = []; | |
while ( ws.ctor !== '[]' | |
&& xs.ctor !== '[]' | |
&& ys.ctor !== '[]' | |
&& zs.ctor !== '[]') | |
{ | |
arr.push(A4(f, ws._0, xs._0, ys._0, zs._0)); | |
ws = ws._1; | |
xs = xs._1; | |
ys = ys._1; | |
zs = zs._1; | |
} | |
return fromArray(arr); | |
} | |
function zipWith5(f, vs, ws, xs, ys, zs) { | |
var arr = []; | |
while ( vs.ctor !== '[]' | |
&& ws.ctor !== '[]' | |
&& xs.ctor !== '[]' | |
&& ys.ctor !== '[]' | |
&& zs.ctor !== '[]') | |
{ | |
arr.push(A5(f, vs._0, ws._0, xs._0, ys._0, zs._0)); | |
vs = vs._1; | |
ws = ws._1; | |
xs = xs._1; | |
ys = ys._1; | |
zs = zs._1; | |
} | |
return fromArray(arr); | |
} | |
function sort(xs) { | |
return fromArray(toArray(xs).sort(Utils.cmp)); | |
} | |
function sortBy(f, xs) { | |
return fromArray(toArray(xs).sort(function(a,b){ | |
return Utils.cmp(f(a), f(b)); | |
})); | |
} | |
function sortWith(f, xs) { | |
return fromArray(toArray(xs).sort(function(a,b){ | |
var ord = f(a)(b).ctor; | |
return ord === 'EQ' ? 0 : ord === 'LT' ? -1 : 1; | |
})); | |
} | |
function nth(xs, n) { | |
return toArray(xs)[n]; | |
} | |
function take(n, xs) { | |
var arr = []; | |
while (xs.ctor !== '[]' && n > 0) { | |
arr.push(xs._0); | |
xs = xs._1; | |
--n; | |
} | |
return fromArray(arr); | |
} | |
function drop(n, xs) { | |
while (xs.ctor !== '[]' && n > 0) { | |
xs = xs._1; | |
--n; | |
} | |
return xs; | |
} | |
function repeat(n, x) { | |
var arr = []; | |
var pattern = [x]; | |
while (n > 0) { | |
if (n & 1) arr = arr.concat(pattern); | |
n >>= 1, pattern = pattern.concat(pattern); | |
} | |
return fromArray(arr); | |
} | |
function join(sep, xss) { | |
if (sep.text) { | |
sep = Utils.makeText(sep); | |
xss = toArray(xss); | |
for (var i = xss.length; i--; ) { | |
xss[i] = Utils.makeText(xss[i]); | |
} | |
return Utils.txt(xss.join(sep)); | |
} | |
if (typeof sep === 'string') return toArray(xss).join(sep); | |
if (xss.ctor === '[]') return Nil; | |
var s = toArray(sep); | |
var out = toArray(xss._0); | |
xss = xss._1; | |
while (xss.ctor !== '[]') { | |
out = out.concat(s, toArray(xss._0)); | |
xss = xss._1; | |
} | |
return fromArray(out); | |
} | |
/* | |
* Only to be used internally; do some side effects for each elem | |
*/ | |
function each(action, xs) { | |
while(xs.ctor !== '[]') { | |
action(xs._0); | |
xs = xs._1; | |
} | |
} | |
Elm.Native.List.values = { | |
Nil:Nil, | |
Cons:Cons, | |
cons:F2(Cons), | |
toArray:toArray, | |
fromArray:fromArray, | |
range:range, | |
append:append, | |
head:head, | |
tail:tail, | |
last:last, | |
map:F2(map), | |
foldl:F3(foldl), | |
foldr:F3(foldr), | |
foldl1:F2(foldl1), | |
foldr1:F2(foldr1), | |
scanl:F3(scanl), | |
scanl1:F2(scanl1), | |
filter:F2(filter), | |
length:length, | |
member:F2(member), | |
reverse:reverse, | |
concat:concat, | |
all:F2(all), | |
any:F2(any), | |
zipWith :F3(zipWith ), | |
zipWith3:F4(zipWith3), | |
zipWith4:F5(zipWith4), | |
zipWith5:F6(zipWith5), | |
zip:F2(zip), | |
sort:sort, | |
sortBy:F2(sortBy), | |
sortWith:F2(sortWith), | |
nth:F2(nth), | |
take:F2(take), | |
drop:F2(drop), | |
repeat:F2(repeat), | |
join:F2(join), | |
each:each | |
}; | |
return elm.Native.List.values = Elm.Native.List.values; | |
}; | |
Elm.Native.Array = {}; | |
Elm.Native.Array.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Array = elm.Native.Array || {}; | |
if (elm.Native.Array.values) return elm.Native.Array.values; | |
if ('values' in Elm.Native.Array) | |
return elm.Native.Array.values = Elm.Native.Array.values; | |
var List = Elm.Native.List.make(elm); | |
// A RRB-Tree has two distinct data types. | |
// Leaf -> "height" is always 0 | |
// "table" is an array of elements | |
// Node -> "height" is always greater than 0 | |
// "table" is an array of child nodes | |
// "lengths" is an array of accumulated lengths of the child nodes | |
// M is the maximal table size. 32 seems fast. E is the allowed increase | |
// of search steps when concatting to find an index. Lower values will | |
// decrease balancing, but will increase search steps. | |
var M = 32; | |
var E = 2; | |
// An empty array. | |
var empty = { ctor:"_Array", height:0, table:new Array() }; | |
function get(i, array) { | |
if (i < 0 || i >= length(array)) { | |
throw new Error("Index " + i + " is out of range. Check the length of " + | |
"your array first or use getMaybe or getWithDefault."); | |
} | |
return unsafeGet(i, array); | |
} | |
function unsafeGet(i, array) { | |
for (var x = array.height; x > 0; x--) { | |
var slot = i >> (x * 5); | |
if (slot > 0) { | |
while (array.lengths[slot - 1] > i) { slot--; } | |
i -= array.lengths[slot - 1]; | |
} | |
array = array.table[slot]; | |
} | |
return array.table[i]; | |
} | |
// Sets the value at the index i. Only the nodes leading to i will get | |
// copied and updated. | |
function set(i, item, array) { | |
if (i < 0 || length(array) <= i) { | |
return array; | |
} | |
return unsafeSet(i, item, array); | |
} | |
function unsafeSet(i, item, array) { | |
array = nodeCopy(array); | |
if (array.height == 0) { | |
array.table[i] = item; | |
} else { | |
var slot = getSlot(i, array); | |
if (slot > 0) { | |
i -= array.lengths[slot - 1]; | |
} | |
array.table[slot] = unsafeSet(i, item, array.table[slot]); | |
} | |
return array; | |
} | |
function initialize(len, f) { | |
if (len == 0) { return empty; } | |
var h = Math.floor(Math.log(len)/Math.log(M)); | |
return initialize_(f, h, 0, len); | |
} | |
function initialize_(f, h, from, to) { | |
if (h == 0) { | |
var table = new Array((to - from) % (M + 1)); | |
for (var i = 0; i < table.length; i++) { | |
table[i] = f(from + i); | |
} | |
return { ctor:"_Array", height:0, table:table }; | |
} | |
var step = Math.pow(M, h); | |
var table = new Array(Math.ceil((to - from) / step)); | |
var lengths = new Array(table.length); | |
for (var i = 0; i < table.length; i++) { | |
table[i] = initialize_( f, h - 1, from + (i * step) | |
, Math.min(from + ((i + 1) * step), to)); | |
lengths[i] = length(table[i]) + (i > 0 ? lengths[i-1] : 0); | |
} | |
return { ctor:"_Array", height:h, table:table, lengths:lengths }; | |
} | |
function fromList(list) { | |
if (list == List.Nil) { return empty; } | |
// Allocate M sized blocks (table) and write list elements to it. | |
var table = new Array(M); | |
var nodes = new Array(); | |
var i = 0; | |
while (list.ctor !== '[]') { | |
table[i] = list._0; | |
list = list._1; | |
i++; | |
// table is full, so we can push a leaf containing it into the | |
// next node. | |
if (i == M) { | |
fromListPush({ ctor:"_Array", height:0, table:table } | |
, nodes); | |
table = new Array(M); | |
i = 0; | |
} | |
} | |
// Maybe there is something left on the table. | |
if (i > 0) { | |
fromListPush({ ctor:"_Array", height:0, table:table.splice(0,i) } | |
, nodes); | |
} | |
// Go through all of the nodes and eventually push them into higher nodes. | |
for (var h = 0; h < nodes.length - 1; h++) { | |
if (nodes[h].table.length > 0) { | |
fromListPush(nodes[h], nodes); | |
} | |
} | |
var head = nodes[nodes.length - 1]; | |
if (head.height > 0 && head.table.length == 1) { | |
return head.table[0]; | |
} else { | |
return head; | |
} | |
} | |
// Push a node into a higher node as a child. | |
function fromListPush(toPush, nodes) { | |
var h = toPush.height; | |
// Maybe the node on this height does not exist. | |
if (nodes.length == h) { | |
nodes.push({ ctor:"_Array", height:h + 1 | |
, table:new Array() | |
, lengths:new Array() }); | |
} | |
nodes[h].table.push(toPush); | |
var len = length(toPush); | |
if (nodes[h].lengths.length > 0) { | |
len += nodes[h].lengths[nodes[h].lengths.length - 1]; | |
} | |
nodes[h].lengths.push(len); | |
if (nodes[h].table.length == M) { | |
fromListPush(nodes[h], nodes); | |
nodes[h] = { ctor:"_Array", height:h + 1 | |
, table:new Array() | |
, lengths:new Array() }; | |
} | |
} | |
// Pushes an item via push_ to the bottom right of a tree. | |
function push(item, a) { | |
var pushed = push_(item, a); | |
if (pushed !== null) { | |
return pushed; | |
} | |
var newTree = create(item, a.height); | |
return siblise(a, newTree); | |
} | |
// Recursively tries to push an item to the bottom-right most | |
// tree possible. If there is no space left for the item, | |
// null will be returned. | |
function push_(item, a) { | |
// Handle resursion stop at leaf level. | |
if (a.height == 0) { | |
if (a.table.length < M) { | |
var newA = { ctor:"_Array", height:0, table:a.table.slice() }; | |
newA.table.push(item); | |
return newA; | |
} else { | |
return null; | |
} | |
} | |
// Recursively push | |
var pushed = push_(item, botRight(a)); | |
// There was space in the bottom right tree, so the slot will | |
// be updated. | |
if (pushed != null) { | |
var newA = nodeCopy(a); | |
newA.table[newA.table.length - 1] = pushed; | |
newA.lengths[newA.lengths.length - 1]++; | |
return newA | |
} | |
// When there was no space left, check if there is space left | |
// for a new slot with a tree which contains only the item | |
// at the bottom. | |
if (a.table.length < M) { | |
var newSlot = create(item, a.height - 1); | |
var newA = nodeCopy(a); | |
newA.table.push(newSlot); | |
newA.lengths.push(newA.lengths[newA.lengths.length - 1] + length(newSlot)); | |
return newA | |
} else { | |
return null; | |
} | |
} | |
// Converts an array into a list of elements. | |
function toList(a) { | |
return toList_(List.Nil, a); | |
} | |
function toList_(list, a) { | |
for (var i = a.table.length - 1; i >= 0; i--) { | |
list = a.height == 0 ? List.Cons(a.table[i], list) : toList_(list, a.table[i]); | |
} | |
return list; | |
} | |
// Maps a function over the elements of an array. | |
function map(f, a) { | |
var newA = { ctor:"_Array", height:a.height, table:new Array(a.table) }; | |
if (a.height > 0) { newA.lengths = a.lengths; } | |
for (var i = 0; i < a.table.length; i++) { | |
newA.table[i] = a.height == 0 ? f(a.table[i]) : map(f, a.table[i]); | |
} | |
return newA; | |
} | |
// Maps a function over the elements with their index as first argument. | |
function indexedMap(f, a) { | |
return indexedMap_(f, a, 0); | |
} | |
function indexedMap_(f, a, from) { | |
var newA = { ctor:"_Array", height:a.height, table:new Array(a.table) }; | |
if (a.height > 0) { newA.lengths = a.lengths; } | |
for (var i = 0; i < a.table.length; i++) { | |
newA.table[i] = a.height == 0 ? A2(f, from + i, a.table[i]) | |
: indexedMap_( f, a.table[i] | |
, i == 0 ? 0 : a.lengths[i - 1]); | |
} | |
return newA; | |
} | |
function foldl(f, b, a) { | |
for (var i = 0; i < a.table.length; i++) { | |
b = A2(f, a.height == 0 ? a.table[i] : foldl(f, b, a.table[i]), b); | |
} | |
return b; | |
} | |
function foldr(f, b, a) { | |
for (var i = a.table.length; i--; ) { | |
b = A2(f, a.height == 0 ? a.table[i] : foldr(f, b, a.table[i]), b); | |
} | |
return b; | |
} | |
// TODO: currently, it slices the right, then the left. This can be | |
// optimized. | |
function slice(from, to, a) { | |
if (from < 0) { from += length(a); } | |
if (to < 0) { to += length(a); } | |
return sliceLeft(from, sliceRight(to, a)); | |
} | |
function sliceRight(to, a) { | |
if (to == length(a)) { | |
return a; | |
} | |
// Handle leaf level. | |
if (a.height == 0) { | |
var newA = { ctor:"_Array", height:0 }; | |
newA.table = a.table.slice(0, to); | |
return newA; | |
} | |
// Slice the right recursively. | |
var right = getSlot(to, a); | |
var sliced = sliceRight(to - (right > 0 ? a.lengths[right - 1] : 0), a.table[right]); | |
// Maybe the a node is not even needed, as sliced contains the whole slice. | |
if (right == 0) { | |
return sliced; | |
} | |
// Create new node. | |
var newA = { ctor:"_Array", height:a.height | |
, table:a.table.slice(0, right + 1) | |
, lengths:a.lengths.slice(0, right + 1) }; | |
newA.table[right] = sliced; | |
newA.lengths[right] = length(sliced) + (right > 0 ? newA.lengths[right - 1] : 0); | |
return newA; | |
} | |
function sliceLeft(from, a) { | |
if (from == 0) { | |
return a; | |
} | |
// Handle leaf level. | |
if (a.height == 0) { | |
var newA = { ctor:"_Array", height:0 }; | |
newA.table = a.table.slice(from, a.table.length + 1); | |
return newA; | |
} | |
// Slice the left recursively. | |
var left = getSlot(from, a); | |
var sliced = sliceLeft(from - (left > 0 ? a.lengths[left - 1] : 0), a.table[left]); | |
// Maybe the a node is not even needed, as sliced contains the whole slice. | |
if (left == a.table.length - 1) { | |
return sliced; | |
} | |
// Create new node. | |
var newA = { ctor:"_Array", height:a.height | |
, table:a.table.slice(left, a.table.length + 1) | |
, lengths:new Array(a.table.length - left) }; | |
newA.table[left] = sliced; | |
var len = 0; | |
for (var i = 0; i < newA.table.length; i++) { | |
len += length(newA.table[i]); | |
newA.lengths[i] = len; | |
} | |
return newA; | |
} | |
// Appends two trees. | |
// TODO: Add support for appending trees of different sizes. Current | |
// behavior will just rise the lower tree and then append them. | |
function append(a,b) { | |
if (b.height > a.height) { return append(parentise(a, b.height), b); } | |
if (a.height > b.height) { return append(a, parentise(b, a.height)); } | |
if (a.height == 0) { return append(parentise(a, 1), parentise(b, 1)); } | |
var c = append_(a, b); | |
if (c[1].table.length > 0) { | |
return siblise(c[0], c[1]); | |
} else { | |
return c[0]; | |
} | |
} | |
// Returns an array of two nodes. The second node _may_ be empty. This case | |
// needs to be handled by the function, that called append_. May be only | |
// called for trees with an minimal height of 1. | |
function append_(a, b) { | |
if (a.height == 1) { | |
// Check if balancing is needed and return based on that. | |
var toRemove = calcToRemove(a, b); | |
if (toRemove <= E) { | |
return [a,b]; | |
} | |
return shuffle(a, b, toRemove); | |
} | |
var appended = append_(botRight(a), botLeft(b)); | |
a = nodeCopy(a), b = nodeCopy(b); | |
// Adjust the bottom right side of the new tree. | |
a.table[a.table.length - 1] = appended[0]; | |
a.lengths[a.lengths.length - 1] = length(appended[0]) | |
a.lengths[a.lengths.length - 1] += a.lengths.length > 1 ? a.lengths[a.lengths.length - 2] : 0; | |
// Adjust the bottom left side of the new tree. | |
if (appended[1].table.length > 0) { | |
b.table[0] = appended[1]; | |
b.lengths[0] = length(appended[1]); | |
for (var i = 1, len = length(b.table[0]); i < b.lengths.length; i++) { | |
len += length(b.table[i]); | |
b.lengths[i] = len; | |
} | |
} else { | |
b.table.shift(); | |
for (var i = 1; i < b.lengths.length; i++) { | |
b.lengths[i] = b.lengths[i] - b.lengths[0]; | |
} | |
b.lengths.shift(); | |
} | |
// Check if balancing is needed and return based on that. | |
var toRemove = calcToRemove(a, b); | |
if (toRemove <= E || b.table.length == 0) { | |
return [a,b]; | |
} | |
return shuffle(a, b, toRemove); | |
} | |
// Returns the extra search steps for E. Refer to the paper. | |
function calcToRemove(a, b) { | |
var subLengths = 0; | |
for (var i = 0; i < a.table.length; i++) { | |
subLengths += a.table[i].table.length; | |
} | |
for (var i = 0; i < b.table.length; i++) { | |
subLengths += b.table[i].table.length; | |
} | |
var toRemove = a.table.length + b.table.length | |
return toRemove - (Math.floor((subLengths - 1) / M) + 1); | |
} | |
// get2, set2 and saveSlot are helpers for accessing elements over two arrays. | |
function get2(a, b, index) { | |
return index < a.length ? a[index] : b[index - a.length]; | |
} | |
function set2(a, b, index, value) { | |
if (index < a.length) { | |
a[index] = value; | |
} else { | |
b[index - a.length] = value; | |
} | |
} | |
function saveSlot(a, b, index, slot) { | |
set2(a.table, b.table, index, slot); | |
var l = (index == 0 || index == a.lengths.length) ? | |
0 : get2(a.lengths, a.lengths, index - 1); | |
set2(a.lengths, b.lengths, index, l + length(slot)); | |
} | |
// Creates a node or leaf with a given length at their arrays for perfomance. | |
// Is only used by shuffle. | |
function createNode(h, length) { | |
if (length < 0) { length = 0; } | |
var a = { ctor:"_Array", height:h, table:new Array(length) }; | |
if (h > 0) { | |
a.lengths = new Array(length); | |
} | |
return a; | |
} | |
// Returns an array of two balanced nodes. | |
function shuffle(a, b, toRemove) { | |
var newA = createNode(a.height, Math.min(M, a.table.length + b.table.length - toRemove)); | |
var newB = createNode(a.height, newA.table.length - (a.table.length + b.table.length - toRemove)); | |
// Skip the slots with size M. More precise: copy the slot references | |
// to the new node | |
var read = 0; | |
while (get2(a.table, b.table, read).table.length % M == 0) { | |
set2(newA.table, newB.table, read, get2(a.table, b.table, read)); | |
set2(newA.lengths, newB.lengths, read, get2(a.lengths, b.lengths, read)); | |
read++; | |
} | |
// Pulling items from left to right, caching in a slot before writing | |
// it into the new nodes. | |
var write = read; | |
var slot = new createNode(a.height - 1, 0); | |
var from = 0; | |
// If the current slot is still containing data, then there will be at | |
// least one more write, so we do not break this loop yet. | |
while (read - write - (slot.table.length > 0 ? 1 : 0) < toRemove) { | |
// Find out the max possible items for copying. | |
var source = get2(a.table, b.table, read); | |
var to = Math.min(M - slot.table.length, source.table.length) | |
// Copy and adjust size table. | |
slot.table = slot.table.concat(source.table.slice(from, to)); | |
if (slot.height > 0) { | |
var len = slot.lengths.length; | |
for (var i = len; i < len + to - from; i++) { | |
slot.lengths[i] = length(slot.table[i]); | |
slot.lengths[i] += (i > 0 ? slot.lengths[i - 1] : 0); | |
} | |
} | |
from += to; | |
// Only proceed to next slots[i] if the current one was | |
// fully copied. | |
if (source.table.length <= to) { | |
read++; from = 0; | |
} | |
// Only create a new slot if the current one is filled up. | |
if (slot.table.length == M) { | |
saveSlot(newA, newB, write, slot); | |
slot = createNode(a.height - 1,0); | |
write++; | |
} | |
} | |
// Cleanup after the loop. Copy the last slot into the new nodes. | |
if (slot.table.length > 0) { | |
saveSlot(newA, newB, write, slot); | |
write++; | |
} | |
// Shift the untouched slots to the left | |
while (read < a.table.length + b.table.length ) { | |
saveSlot(newA, newB, write, get2(a.table, b.table, read)); | |
read++; write++; | |
} | |
return [newA, newB]; | |
} | |
// Navigation functions | |
function botRight(a) { return a.table[a.table.length - 1]; } | |
function botLeft(a) { return a.table[0]; } | |
// Copies a node for updating. Note that you should not use this if | |
// only updating only one of "table" or "lengths" for performance reasons. | |
function nodeCopy(a) { | |
var newA = { ctor:"_Array", height:a.height | |
, table:a.table.slice() }; | |
if (a.height > 0) { newA.lengths = a.lengths.slice(); } | |
return newA; | |
} | |
// Returns how many items are in the tree. | |
function length(array) { | |
if (array.height == 0) { | |
return array.table.length; | |
} else { | |
return array.lengths[array.lengths.length - 1]; | |
} | |
} | |
// Calculates in which slot of "table" the item probably is, then | |
// find the exact slot via forward searching in "lengths". Returns the index. | |
function getSlot(i, a) { | |
var slot = i >> (5 * a.height); | |
while (a.lengths[slot - 1] > i) { slot--; } | |
return slot; | |
} | |
// Recursively creates a tree with a given height containing | |
// only the given item. | |
function create(item, h) { | |
if (h == 0) { | |
return { ctor:"_Array", height:0 | |
, table:[item] }; | |
} else { | |
return { ctor:"_Array", height:h | |
, table:[create(item, h - 1)] | |
, lengths:[1] }; | |
} | |
} | |
// Recursively creates a tree that contains the given tree. | |
function parentise(tree, h) { | |
if (h == tree.height) { | |
return tree; | |
} else { | |
return { ctor:"_Array", height:h | |
, table:[parentise(tree, h - 1)] | |
, lengths:[length(tree)] }; | |
} | |
} | |
// Emphasizes blood brotherhood beneath two trees. | |
function siblise(a, b) { | |
return { ctor:"_Array", height:a.height + 1 | |
, table:[a, b] | |
, lengths:[length(a), length(a) + length(b)] }; | |
} | |
function toJSArray(a) { | |
var jsArray = new Array(length(a)); | |
toJSArray_(jsArray, 0, a); | |
return jsArray; | |
} | |
function toJSArray_(jsArray, i, a) { | |
for (var t = 0; t < a.table.length; t++) { | |
if (a.height == 0) { | |
jsArray[i + t] = a.table[t]; | |
} else { | |
var inc = t == 0 ? 0 : a.lengths[t - 1]; | |
toJSArray_(jsArray, i + inc, a.table[t]); | |
} | |
} | |
} | |
function fromJSArray(jsArray) { | |
if (jsArray.length == 0) { return empty; } | |
var h = Math.floor(Math.log(jsArray.length) / Math.log(M)); | |
return fromJSArray_(jsArray, h, 0, jsArray.length); | |
} | |
function fromJSArray_(jsArray, h, from, to) { | |
if (h == 0) { | |
return { ctor:"_Array", height:0 | |
, table:jsArray.slice(from, to) }; | |
} | |
var step = Math.pow(M, h); | |
var table = new Array(Math.ceil((to - from) / step)); | |
var lengths = new Array(table.length); | |
for (var i = 0; i < table.length; i++) { | |
table[i] = fromJSArray_( jsArray, h - 1, from + (i * step) | |
, Math.min(from + ((i + 1) * step), to)); | |
lengths[i] = length(table[i]) + (i > 0 ? lengths[i-1] : 0); | |
} | |
return { ctor:"_Array", height:h, table:table, lengths:lengths }; | |
} | |
Elm.Native.Array.values = { | |
empty:empty, | |
fromList:fromList, | |
toList:toList, | |
initialize:F2(initialize), | |
append:F2(append), | |
push:F2(push), | |
slice:F3(slice), | |
get:F2(get), | |
set:F3(set), | |
map:F2(map), | |
indexedMap:F2(indexedMap), | |
foldl:F3(foldl), | |
foldr:F3(foldr), | |
length:length, | |
toJSArray:toJSArray, | |
fromJSArray:fromJSArray | |
}; | |
return elm.Native.Array.values = Elm.Native.Array.values; | |
} | |
Elm.Native.JavaScript = {}; | |
Elm.Native.JavaScript.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.JavaScript = elm.Native.JavaScript || {}; | |
if (elm.Native.JavaScript.values) return elm.Native.JavaScript.values; | |
var List = Elm.Native.List.make(elm); | |
var Render = ElmRuntime.use(ElmRuntime.Render.Element); | |
function fromJS(v) { | |
var type = typeof v; | |
if (type === 'number' ) return v; | |
if (type === 'boolean') return v; | |
if (type === 'string' ) return v; | |
if (v instanceof Array) { | |
var arr = []; | |
var len = v.length; | |
for (var i = 0; i < len; ++i) { | |
var x = fromJS(v[i]); | |
if (x !== null) arr.push(x); | |
} | |
return List.fromArray(arr); | |
} | |
if (type === 'object') { | |
var rec = { _:{} }; | |
for (var f in v) { | |
var x = fromJS(v[f]); | |
if (x !== null) rec[f] = x; | |
} | |
return rec; | |
} | |
return null; | |
} | |
function toJS(v) { | |
var type = typeof v; | |
if (type === 'number' || type === 'boolean' || type === 'string') return v; | |
if (type === 'object' && '_' in v) { | |
var obj = {}; | |
for (var k in v) { | |
var x = toJS(v[k]); | |
if (x !== null) obj[k] = x; | |
} | |
return obj; | |
} | |
if (type === 'object' && (v.ctor === '::' || v.ctor === '[]')) { | |
var array = List.toArray(v); | |
for (var i = array.length; i--; ) { | |
array[i] = toJS(array[i]); | |
} | |
return array; | |
} | |
return null; | |
} | |
function fromRecord(r) { | |
if (typeof r === 'object' && '_' in r) { | |
return toJS(r); | |
} | |
throw new Error("'fromRecord' must be called on a record."); | |
} | |
return elm.Native.JavaScript.values = { | |
toRecord : fromJS, | |
fromRecord : fromRecord | |
}; | |
}; | |
Elm.Native.Utils = {}; | |
Elm.Native.Utils.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Utils = elm.Native.Utils || {}; | |
if (elm.Native.Utils.values) return elm.Native.Utils.values; | |
function eq(l,r) { | |
var stack = [{'x': l, 'y': r}] | |
while (stack.length > 0) { | |
var front = stack.pop(); | |
var x = front.x; | |
var y = front.y; | |
if (x === y) continue; | |
if (typeof x === "object") { | |
var c = 0; | |
for (var i in x) { | |
++c; | |
if (i in y) { | |
if (i !== 'ctor') { | |
stack.push({ 'x': x[i], 'y': y[i] }); | |
} | |
} else { | |
return false; | |
} | |
} | |
if ('ctor' in x) { | |
stack.push({'x': x.ctor, 'y': y.ctor}); | |
} | |
if (c !== Object.keys(y).length) { | |
return false; | |
}; | |
} else if (typeof x === 'function') { | |
throw new Error('Equality error: general function equality is ' + | |
'undecidable, and therefore, unsupported'); | |
} else { | |
return false; | |
} | |
} | |
return true; | |
} | |
// code in Generate/JavaScript.hs depends on the particular | |
// integer values assigned to LT, EQ, and GT | |
var LT = -1, EQ = 0, GT = 1, ord = ['LT','EQ','GT']; | |
function compare(x,y) { return { ctor: ord[cmp(x,y)+1] } } | |
function cmp(x,y) { | |
var ord; | |
if (typeof x !== 'object'){ | |
return x === y ? EQ : x < y ? LT : GT; | |
} | |
else if (x.isChar){ | |
var a = x.toString(); | |
var b = y.toString(); | |
return a === b ? EQ : a < b ? LT : GT; | |
} | |
else if (x.ctor === "::" || x.ctor === "[]") { | |
while (true) { | |
if (x.ctor === "[]" && y.ctor === "[]") return EQ; | |
if (x.ctor !== y.ctor) return x.ctor === '[]' ? LT : GT; | |
ord = cmp(x._0, y._0); | |
if (ord !== EQ) return ord; | |
x = x._1; | |
y = y._1; | |
} | |
} | |
else if (x.ctor.slice(0,6) === '_Tuple') { | |
var n = x.ctor.slice(6) - 0; | |
var err = 'cannot compare tuples with more than 6 elements.'; | |
if (n === 0) return EQ; | |
if (n >= 1) { ord = cmp(x._0, y._0); if (ord !== EQ) return ord; | |
if (n >= 2) { ord = cmp(x._1, y._1); if (ord !== EQ) return ord; | |
if (n >= 3) { ord = cmp(x._2, y._2); if (ord !== EQ) return ord; | |
if (n >= 4) { ord = cmp(x._3, y._3); if (ord !== EQ) return ord; | |
if (n >= 5) { ord = cmp(x._4, y._4); if (ord !== EQ) return ord; | |
if (n >= 6) { ord = cmp(x._5, y._5); if (ord !== EQ) return ord; | |
if (n >= 7) throw new Error('Comparison error: ' + err); } } } } } } | |
return EQ; | |
} | |
else { | |
throw new Error('Comparison error: comparison is only defined on ints, ' + | |
'floats, times, chars, strings, lists of comparable values, ' + | |
'and tuples of comparable values.'); | |
} | |
} | |
var Tuple0 = { ctor: "_Tuple0" }; | |
function Tuple2(x,y) { return { ctor:"_Tuple2", _0:x, _1:y } } | |
function chr(c) { | |
var x = new String(c); | |
x.isChar = true; | |
return x; | |
} | |
function txt(str) { | |
var t = new String(str); | |
t.text = true; | |
return t; | |
} | |
function makeText(text) { | |
var style = ''; | |
var href = ''; | |
while (true) { | |
if (text.style) { | |
style += text.style; | |
text = text.text; | |
continue; | |
} | |
if (text.href) { | |
href = text.href; | |
text = text.text; | |
continue; | |
} | |
if (href) text = '<a href="' + href + '">' + text + '</a>'; | |
if (style) text = '<span style="' + style + '">' + text + '</span>'; | |
return text; | |
} | |
} | |
var count = 0; | |
function guid(_) { return count++ } | |
function copy(r) { | |
var o = {}; | |
for (var i in r) { o[i] = r[i]; } | |
return o; | |
} | |
function remove(x,r) { | |
var o = copy(r); | |
if (x in o._) { | |
o[x] = o._[x][0]; | |
o._[x] = o._[x].slice(1); | |
if (o._[x].length === 0) { delete o._[x]; } | |
} else { | |
delete o[x]; | |
} | |
return o; | |
} | |
function replace(kvs,r) { | |
var o = copy(r); | |
for (var i = kvs.length; i--; ) { | |
var kvsi = kvs[i]; | |
o[kvsi[0]] = kvsi[1]; | |
} | |
return o; | |
} | |
function insert(x,v,r) { | |
var o = copy(r); | |
if (x in o) o._[x] = [o[x]].concat(x in o._ ? o._[x].slice(0) : []); | |
o[x] = v; | |
return o; | |
} | |
function max(a,b) { return a > b ? a : b } | |
function min(a,b) { return a < b ? a : b } | |
function mod(a,b) { | |
if (b === 0) { | |
throw new Error("Cannot perform mod 0. Division by zero error."); | |
} | |
var r = a % b; | |
var m = a === 0 ? 0 : (b > 0 ? (a >= 0 ? r : r+b) : -mod(-a,-b)); | |
return m === b ? 0 : m; | |
} | |
function htmlHeight(width, rawHtml) { | |
// create dummy node | |
var html = rawHtml.html; | |
var t = document.createElement('div'); | |
t.innerHTML = html; | |
if (width > 0) { t.style.width = width + "px"; } | |
t.style.visibility = "hidden"; | |
t.style.styleFloat = "left"; | |
t.style.cssFloat = "left"; | |
document.body.appendChild(t); | |
// insert interpolated values | |
var args = rawHtml.args; | |
var guid = rawHtml.guid; | |
for (var i = args.length; i--; ) { | |
var arg = args[i]; | |
var span = document.getElementById('md-' + guid + '-' + i); | |
if (arg.isElement) { | |
span.style.width = arg.props.width + 'px'; | |
span.style.height = arg.props.height + 'px'; | |
} else { | |
span.innerHTML = arg; | |
} | |
} | |
// get dimensions | |
var style = window.getComputedStyle(t, null); | |
var w = Math.ceil(style.getPropertyValue("width").slice(0,-2) - 0); | |
var h = Math.ceil(style.getPropertyValue("height").slice(0,-2) - 0); | |
document.body.removeChild(t); | |
return Tuple2(w,h); | |
} | |
function getXY(e) { | |
var posx = 0; | |
var posy = 0; | |
if (e.pageX || e.pageY) { | |
posx = e.pageX; | |
posy = e.pageY; | |
} else if (e.clientX || e.clientY) { | |
posx = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft; | |
posy = e.clientY + document.body.scrollTop + document.documentElement.scrollTop; | |
} | |
if (elm.display === ElmRuntime.Display.COMPONENT) { | |
var rect = elm.node.getBoundingClientRect(); | |
var relx = rect.left + document.body.scrollLeft + document.documentElement.scrollLeft; | |
var rely = rect.top + document.body.scrollTop + document.documentElement.scrollTop; | |
// TODO: figure out if there is a way to avoid rounding here | |
posx = posx - Math.round(relx) - elm.node.clientLeft; | |
posy = posy - Math.round(rely) - elm.node.clientTop; | |
} | |
return Tuple2(posx, posy); | |
} | |
function isJSArray(a) { | |
return a instanceof Array; | |
} | |
return elm.Native.Utils.values = { | |
eq:eq, | |
cmp:cmp, | |
compare:F2(compare), | |
Tuple0:Tuple0, | |
Tuple2:Tuple2, | |
chr:chr, | |
txt:txt, | |
makeText:makeText, | |
copy: copy, | |
remove: remove, | |
replace: replace, | |
insert: insert, | |
guid: guid, | |
max : F2(max), | |
min : F2(min), | |
mod : F2(mod), | |
htmlHeight: F2(htmlHeight), | |
getXY: getXY, | |
isJSArray: isJSArray, | |
toFloat: function(x) { return +x; } | |
}; | |
}; | |
Elm.Native.Regex = {}; | |
Elm.Native.Regex.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Regex = elm.Native.Regex || {}; | |
if (elm.Native.Regex.values) return elm.Native.Regex.values; | |
if ('values' in Elm.Native.Regex) | |
return elm.Native.Regex.values = Elm.Native.Regex.values; | |
var List = Elm.Native.List.make(elm); | |
var Maybe = Elm.Maybe.make(elm); | |
function escape(str) { | |
return str.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'); | |
} | |
function caseInsensitive(re) { | |
return new RegExp(re.source, 'gi'); | |
} | |
function regex(raw) { | |
return new RegExp(raw, 'g'); | |
} | |
function contains(re, string) { | |
return string.match(re) !== null; | |
} | |
function find(n, re, str) { | |
n = n.ctor === "All" ? Infinity : n._0; | |
var out = []; | |
var number = 0; | |
var string = str; | |
var result; | |
while (number++ < n && (result = re.exec(string))) { | |
var i = result.length - 1; | |
var subs = new Array(i); | |
while (i > 0) { | |
var submatch = result[i]; | |
subs[--i] = submatch === undefined | |
? Maybe.Nothing | |
: Maybe.Just(submatch); | |
} | |
out.push({ | |
_:{}, | |
match: result[0], | |
submatches: List.fromArray(subs), | |
index: result.index, | |
number: number | |
}); | |
} | |
return List.fromArray(out); | |
} | |
function replace(n, re, replacer, string) { | |
n = n.ctor === "All" ? Infinity : n._0; | |
var count = 0; | |
function jsReplacer(match) { | |
if (count++ > n) return match; | |
var i = arguments.length-3; | |
var submatches = new Array(i); | |
while (i > 0) { | |
var submatch = arguments[i]; | |
submatches[--i] = submatch === undefined | |
? Maybe.Nothing | |
: Maybe.Just(submatch); | |
} | |
return replacer({ | |
_:{}, | |
match:match, | |
submatches:List.fromArray(submatches), | |
index:arguments[i-1], | |
number:count | |
}); | |
} | |
return string.replace(re, jsReplacer); | |
} | |
function split(n, re, str) { | |
if (n === Infinity) { | |
return List.fromArray(string.split(re)); | |
} | |
var string = str; | |
var result; | |
var out = []; | |
var start = re.lastIndex; | |
while (n--) { | |
if (!(result = re.exec(string))) break; | |
out.push(string.slice(start, result.index)); | |
start = re.lastIndex; | |
} | |
out.push(string.slice(start)); | |
return List.fromArray(out); | |
} | |
return Elm.Native.Regex.values = { | |
regex: regex, | |
caseInsensitive: caseInsensitive, | |
escape: escape, | |
contains: F2(contains), | |
find: F3(find), | |
replace: F4(replace), | |
split: F3(split) | |
}; | |
}; | |
Elm.Native.Ports = {}; | |
Elm.Native.Ports.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Ports = elm.Native.Ports || {}; | |
if (elm.Native.Ports.values) return elm.Native.Ports.values; | |
var Signal = Elm.Signal.make(elm); | |
function incomingSignal(converter) { | |
converter.isSignal = true; | |
return converter; | |
} | |
function outgoingSignal(converter) { | |
return function(signal) { | |
var subscribers = [] | |
function subscribe(handler) { | |
subscribers.push(handler); | |
} | |
function unsubscribe(handler) { | |
subscribers.pop(subscribers.indexOf(handler)); | |
} | |
A2( Signal.lift, function(value) { | |
var val = converter(value); | |
var len = subscribers.length; | |
for (var i = 0; i < len; ++i) { | |
subscribers[i](val); | |
} | |
}, signal); | |
return { subscribe:subscribe, unsubscribe:unsubscribe }; | |
} | |
} | |
function portIn(name, converter) { | |
var jsValue = elm.ports.incoming[name]; | |
if (jsValue === undefined) { | |
throw new Error("Initialization Error: port '" + name + | |
"' was not given an input!"); | |
} | |
elm.ports.uses[name] += 1; | |
try { | |
var elmValue = converter(jsValue); | |
} catch(e) { | |
throw new Error("Initialization Error on port '" + name + "': \n" + e.message); | |
} | |
// just return a static value if it is not a signal | |
if (!converter.isSignal) { | |
return elmValue; | |
} | |
// create a signal if necessary | |
var signal = Signal.constant(elmValue); | |
function send(jsValue) { | |
try { | |
var elmValue = converter(jsValue); | |
} catch(e) { | |
throw new Error("Error sending to port '" + name + "': \n" + e.message); | |
} | |
setTimeout(function() { | |
elm.notify(signal.id, elmValue); | |
}, 0); | |
} | |
elm.ports.outgoing[name] = { send:send }; | |
return signal; | |
} | |
function portOut(name, converter, value) { | |
try { | |
elm.ports.outgoing[name] = converter(value); | |
} catch(e) { | |
throw new Error("Initialization Error on port '" + name + "': \n" + e.message); | |
} | |
return value; | |
} | |
return elm.Native.Ports.values = { | |
incomingSignal: incomingSignal, | |
outgoingSignal: outgoingSignal, | |
portOut: portOut, | |
portIn: portIn | |
}; | |
}; | |
Elm.Native.Basics = {}; | |
Elm.Native.Basics.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Basics = elm.Native.Basics || {}; | |
if (elm.Native.Basics.values) return elm.Native.Basics.values; | |
var JS = Elm.Native.JavaScript.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function div(a,b) { return (a/b)|0; } | |
function rem(a,b) { return a % b; } | |
var mod = Utils.mod; | |
function abs(x) { return x < 0 ? -x : x; } | |
function logBase(base,n) { return Math.log(n) / Math.log(base); } | |
function min(a,b) { return Utils.cmp(a,b) < 0 ? a : b; } | |
function max(a,b) { return Utils.cmp(a,b) > 0 ? a : b; } | |
function clamp(lo,hi,n) { | |
return Utils.cmp(n,lo) < 0 ? lo : Utils.cmp(n,hi) > 0 ? hi : n; } | |
function xor(a,b) { return a !== b; } | |
function not(b) { return !b; } | |
function isInfinite(n) { return n === Infinity || n === -Infinity } | |
function truncate(n) { return n|0; } | |
var basics = { | |
div:F2(div), | |
rem:F2(rem), | |
mod:mod, | |
pi:Math.PI, | |
e:Math.E, | |
cos:Math.cos, | |
sin:Math.sin, | |
tan:Math.tan, | |
acos:Math.acos, | |
asin:Math.asin, | |
atan:Math.atan, | |
atan2:F2(Math.atan2), | |
sqrt:Math.sqrt, | |
abs:abs, | |
logBase:F2(logBase), | |
min:F2(min), | |
max:F2(max), | |
clamp:F3(clamp), | |
compare:Utils.compare, | |
xor:F2(xor), | |
not:not, | |
truncate:truncate, | |
ceiling:Math.ceil, | |
floor:Math.floor, | |
round:Math.round, | |
toFloat:function(x) { return x; }, | |
isNaN:isNaN, | |
isInfinite:isInfinite | |
}; | |
return elm.Native.Basics.values = basics; | |
}; | |
Elm.Native.Text = {}; | |
Elm.Native.Text.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Text = elm.Native.Text || {}; | |
if (elm.Native.Text.values) return elm.Native.Text.values; | |
var toCss = Elm.Native.Color.make(elm).toCss; | |
var Element = Elm.Graphics.Element.make(elm); | |
var List = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function makeSpaces(s) { | |
if (s.length == 0) { return s; } | |
var arr = s.split(''); | |
if (arr[0] == ' ') { arr[0] = " " } | |
for (var i = arr.length; --i; ) { | |
if (arr[i][0] == ' ' && arr[i-1] == ' ') { | |
arr[i-1] = arr[i-1] + arr[i]; | |
arr[i] = ''; | |
} | |
} | |
for (var i = arr.length; i--; ) { | |
if (arr[i].length > 1 && arr[i][0] == ' ') { | |
var spaces = arr[i].split(''); | |
for (var j = spaces.length - 2; j >= 0; j -= 2) { | |
spaces[j] = ' '; | |
} | |
arr[i] = spaces.join(''); | |
} | |
} | |
arr = arr.join(''); | |
if (arr[arr.length-1] === " ") { | |
return arr.slice(0,-1) + ' '; | |
} | |
return arr; | |
} | |
function properEscape(str) { | |
if (str.length == 0) return str; | |
str = str //.replace(/&/g, "&") | |
.replace(/"/g, '"') | |
.replace(/'/g, "'") | |
.replace(/</g, "<") | |
.replace(/>/g, ">") | |
.replace(/\n/g, "<br/>"); | |
var arr = str.split('<br/>'); | |
for (var i = arr.length; i--; ) { | |
arr[i] = makeSpaces(arr[i]); | |
} | |
return arr.join('<br/>'); | |
} | |
function toText(str) { return Utils.txt(properEscape(str)); } | |
// conversions from Elm values to CSS | |
function toTypefaces(list) { | |
var typefaces = List.toArray(list); | |
for (var i = typefaces.length; i--; ) { | |
var typeface = typefaces[i]; | |
if (typeface.indexOf(' ') > -1) { | |
typefaces[i] = "'" + typeface + "'"; | |
} | |
} | |
return typefaces.join(','); | |
} | |
function toLine(line) { | |
var ctor = line.ctor; | |
return ctor === 'Under' ? 'underline' : | |
ctor === 'Over' ? 'overline' : 'line-through'; | |
} | |
// setting styles of Text | |
function style(style, text) { | |
var newText = '<span style="color:' + toCss(style.color) + ';' | |
if (style.typeface.ctor !== '[]') { | |
newText += 'font-family:' + toTypefaces(style.typeface) + ';' | |
} | |
if (style.height.ctor !== "Nothing") { | |
newText += 'font-size:' + style.height._0 + 'px;'; | |
} | |
if (style.bold) { | |
newText += 'font-weight:bold;'; | |
} | |
if (style.italic) { | |
newText += 'font-style:italic;'; | |
} | |
if (style.line.ctor !== 'Nothing') { | |
newText += 'text-decoration:' + toLine(style.line._0) + ';'; | |
} | |
newText += '">' + Utils.makeText(text) + '</span>' | |
return Utils.txt(newText); | |
} | |
function height(px, text) { | |
return { style: 'font-size:' + px + 'px;', text:text } | |
} | |
function typeface(names, text) { | |
return { style: 'font-family:' + toTypefaces(names) + ';', text:text } | |
} | |
function monospace(text) { | |
return { style: 'font-family:monospace;', text:text } | |
} | |
function italic(text) { | |
return { style: 'font-style:italic;', text:text } | |
} | |
function bold(text) { | |
return { style: 'font-weight:bold;', text:text } | |
} | |
function link(href, text) { | |
return { href: toText(href), text:text }; | |
} | |
function line(line, text) { | |
return { style: 'text-decoration:' + toLine(line) + ';', text:text }; | |
} | |
function color(color, text) { | |
return { style: 'color:' + toCss(color) + ';', text:text }; | |
} | |
function block(align) { | |
return function(text) { | |
var raw = { | |
ctor :'RawHtml', | |
html : Utils.makeText(text), | |
align: align, | |
guid : null, | |
args : [] | |
}; | |
var pos = A2(Utils.htmlHeight, 0, raw); | |
return A3(Element.newElement, pos._0, pos._1, raw); | |
} | |
} | |
function markdown(text, guid) { | |
var raw = { | |
ctor:'RawHtml', | |
html: text, | |
align: null, | |
guid: guid, | |
args: [] | |
}; | |
var pos = A2(Utils.htmlHeight, 0, raw); | |
return A3(Element.newElement, pos._0, pos._1, raw); | |
} | |
return elm.Native.Text.values = { | |
toText: toText, | |
height : F2(height), | |
italic : italic, | |
bold : bold, | |
line : F2(line), | |
monospace : monospace, | |
typeface : F2(typeface), | |
color : F2(color), | |
link : F2(link), | |
style : F2(style), | |
leftAligned : block('left'), | |
rightAligned : block('right'), | |
centered : block('center'), | |
justified : block('justify'), | |
markdown : markdown, | |
toTypefaces:toTypefaces, | |
toLine:toLine | |
}; | |
}; | |
Elm.Native.Bitwise = {}; | |
Elm.Native.Bitwise.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Bitwise = elm.Native.Bitwise || {}; | |
if (elm.Native.Bitwise.values) return elm.Native.Bitwise.values; | |
function and(a,b) { return a & b; } | |
function or (a,b) { return a | b; } | |
function xor(a,b) { return a ^ b; } | |
function not(a) { return ~a; } | |
function sll(a,offset) { return a << offset; } | |
function sra(a,offset) { return a >> offset; } | |
function srl(a,offset) { return a >>> offset; } | |
return elm.Native.Bitwise.values = { | |
and: F2(and), | |
or : F2(or ), | |
xor: F2(xor), | |
complement: not, | |
shiftLeft : F2(sll), | |
shiftRightArithmatic: F2(sra), | |
shiftRightLogical : F2(srl) | |
}; | |
}; | |
Elm.Native.Date = {}; | |
Elm.Native.Date.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Date = elm.Native.Date || {}; | |
if (elm.Native.Date.values) return elm.Native.Date.values; | |
var Maybe = Elm.Maybe.make(elm); | |
function dateNow() { return new window.Date; } | |
function readDate(str) { | |
var d = new window.Date(str); | |
if (isNaN(d.getTime())) return Maybe.Nothing; | |
return Maybe.Just(d); | |
} | |
var dayTable = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]; | |
var monthTable = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", | |
"Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]; | |
return elm.Native.Date.values = { | |
read : readDate, | |
year : function(d) { return d.getFullYear(); }, | |
month : function(d) { return { ctor:monthTable[d.getMonth()] }; }, | |
day : function(d) { return d.getDate(); }, | |
hour : function(d) { return d.getHours(); }, | |
minute : function(d) { return d.getMinutes(); }, | |
second : function(d) { return d.getSeconds(); }, | |
toTime : function(d) { return d.getTime(); }, | |
fromTime: function(t) { return new window.Date(t); }, | |
dayOfWeek : function(d) { return { ctor:dayTable[d.getDay()] }; } | |
}; | |
}; | |
Elm.Native.Show = {}; | |
Elm.Native.Show.make = function(elm) { | |
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 Array = Elm.Array.make(elm); | |
var List = Elm.List.make(elm); | |
var Dict = Elm.Dict.make(elm); | |
var Tuple2 = Elm.Native.Utils.make(elm).Tuple2; | |
var toString = function(v) { | |
var type = typeof v; | |
if (type === "function") { | |
var name = v.func ? v.func.name : v.name; | |
return '<function' + (name === '' ? '' : ': ') + name + '>'; | |
} else if (type === "boolean") { | |
return v ? "True" : "False"; | |
} else if (type === "number") { | |
return v+""; | |
} else if ((v instanceof String) && v.isChar) { | |
return "'" + addSlashes(v) + "'"; | |
} else if (type === "string") { | |
return '"' + addSlashes(v) + '"'; | |
} else if (type === "object" && '_' in v && probablyPublic(v)) { | |
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(", ") + " }"; | |
} else if (type === "object" && 'ctor' in v) { | |
if (v.ctor.substring(0,6) === "_Tuple") { | |
var output = []; | |
for (var k in v) { | |
if (k === 'ctor') continue; | |
output.push(toString(v[k])); | |
} | |
return "(" + output.join(",") + ")"; | |
} else if (v.ctor === "_Array") { | |
var list = Array.toList(v); | |
return "Array.fromList " + toString(list); | |
} else if (v.ctor === "::") { | |
var output = '[' + toString(v._0); | |
v = v._1; | |
while (v.ctor === "::") { | |
output += "," + toString(v._0); | |
v = v._1; | |
} | |
return output + ']'; | |
} else if (v.ctor === "[]") { | |
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") { | |
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; | |
output += ' ' + (parenless ? str : '(' + str + ')'); | |
} | |
return v.ctor + output; | |
} | |
} | |
if (type === 'object' && 'recv' in v) return '<signal>'; | |
return "<internal structure>"; | |
}; | |
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, '\\"'); | |
} | |
function probablyPublic(v) { | |
var keys = Object.keys(v); | |
var len = keys.length; | |
if (len === 3 | |
&& 'props' in v | |
&& 'element' in v) return false; | |
if (len === 5 | |
&& 'horizontal' in v | |
&& 'vertical' in v | |
&& 'x' in v | |
&& 'y' in v) return false; | |
if (len === 7 | |
&& 'theta' in v | |
&& 'scale' in v | |
&& 'x' in v | |
&& 'y' in v | |
&& 'alpha' in v | |
&& 'form' in v) return false; | |
return true; | |
} | |
return elm.Native.Show.values = { show:toString }; | |
}; | |
Elm.Native.Transform2D = {}; | |
Elm.Native.Transform2D.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Transform2D = elm.Native.Transform2D || {}; | |
if (elm.Native.Transform2D.values) return elm.Native.Transform2D.values; | |
var A; | |
if (typeof Float32Array === 'undefined') { | |
A = function(arr) { | |
this.length = arr.length; | |
this[0] = arr[0]; | |
this[1] = arr[1]; | |
this[2] = arr[2]; | |
this[3] = arr[3]; | |
this[4] = arr[4]; | |
this[5] = arr[5]; | |
}; | |
} else { | |
A = Float32Array; | |
} | |
// layout of matrix in an array is | |
// | |
// | m11 m12 dx | | |
// | m21 m22 dy | | |
// | 0 0 1 | | |
// | |
// new A([ m11, m12, dx, m21, m22, dy ]) | |
var identity = new A([1,0,0,0,1,0]); | |
function matrix(m11, m12, m21, m22, dx, dy) { | |
return new A([m11, m12, dx, m21, m22, dy]); | |
} | |
function rotation(t) { | |
var c = Math.cos(t); | |
var s = Math.sin(t); | |
return new A([c, -s, 0, s, c, 0]); | |
} | |
function rotate(t,m) { | |
var c = Math.cos(t); | |
var s = Math.sin(t); | |
var m11 = m[0], m12 = m[1], m21 = m[3], m22 = m[4]; | |
return new A([m11*c + m12*s, -m11*s + m12*c, m[2], | |
m21*c + m22*s, -m21*s + m22*c, m[5]]); | |
} | |
/* | |
function move(xy,m) { | |
var x = xy._0; | |
var y = xy._1; | |
var m11 = m[0], m12 = m[1], m21 = m[3], m22 = m[4]; | |
return new A([m11, m12, m11*x + m12*y + m[2], | |
m21, m22, m21*x + m22*y + m[5]]); | |
} | |
function scale(s,m) { return new A([m[0]*s, m[1]*s, m[2], m[3]*s, m[4]*s, m[5]]); } | |
function scaleX(x,m) { return new A([m[0]*x, m[1], m[2], m[3]*x, m[4], m[5]]); } | |
function scaleY(y,m) { return new A([m[0], m[1]*y, m[2], m[3], m[4]*y, m[5]]); } | |
function reflectX(m) { return new A([-m[0], m[1], m[2], -m[3], m[4], m[5]]); } | |
function reflectY(m) { return new A([m[0], -m[1], m[2], m[3], -m[4], m[5]]); } | |
function transform(m11, m21, m12, m22, mdx, mdy, n) { | |
var n11 = n[0], n12 = n[1], n21 = n[3], n22 = n[4], ndx = n[2], ndy = n[5]; | |
return new A([m11*n11 + m12*n21, | |
m11*n12 + m12*n22, | |
m11*ndx + m12*ndy + mdx, | |
m21*n11 + m22*n21, | |
m21*n12 + m22*n22, | |
m21*ndx + m22*ndy + mdy]); | |
} | |
*/ | |
function multiply(m, n) { | |
var m11 = m[0], m12 = m[1], m21 = m[3], m22 = m[4], mdx = m[2], mdy = m[5]; | |
var n11 = n[0], n12 = n[1], n21 = n[3], n22 = n[4], ndx = n[2], ndy = n[5]; | |
return new A([m11*n11 + m12*n21, | |
m11*n12 + m12*n22, | |
m11*ndx + m12*ndy + mdx, | |
m21*n11 + m22*n21, | |
m21*n12 + m22*n22, | |
m21*ndx + m22*ndy + mdy]); | |
} | |
return elm.Native.Transform2D.values = { | |
identity:identity, | |
matrix:F6(matrix), | |
rotation:rotation, | |
multiply:F2(multiply) | |
/* | |
transform:F7(transform), | |
rotate:F2(rotate), | |
move:F2(move), | |
scale:F2(scale), | |
scaleX:F2(scaleX), | |
scaleY:F2(scaleY), | |
reflectX:reflectX, | |
reflectY:reflectY | |
*/ | |
}; | |
}; | |
Elm.Native.String = {}; | |
Elm.Native.String.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.String = elm.Native.String || {}; | |
if (elm.Native.String.values) return elm.Native.String.values; | |
if ('values' in Elm.Native.String) | |
return elm.Native.String.values = Elm.Native.String.values; | |
var Char = Elm.Char.make(elm); | |
var Maybe = Elm.Maybe.make(elm); | |
var List = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function isEmpty(str) { | |
return str.length === 0; | |
} | |
function cons(chr,str) { | |
return chr + str; | |
} | |
function uncons(str) { | |
var hd; | |
return (hd = str[0]) ? Maybe.Just(Utils.Tuple2(Utils.chr(hd), str.slice(1))) | |
: Maybe.Nothing; | |
} | |
function append(a,b) { | |
return a + b; | |
} | |
function concat(strs) { | |
return List.toArray(strs).join(''); | |
} | |
function length(str) { | |
return str.length; | |
} | |
function map(f,str) { | |
var out = str.split(''); | |
for (var i = out.length; i--; ) { | |
out[i] = f(Utils.chr(out[i])); | |
} | |
return out.join(''); | |
} | |
function filter(pred,str) { | |
return str.split('').map(Utils.chr).filter(pred).join(''); | |
} | |
function reverse(str) { | |
return str.split('').reverse().join(''); | |
} | |
function foldl(f,b,str) { | |
var len = str.length; | |
for (var i = 0; i < len; ++i) { | |
b = A2(f, Utils.chr(str[i]), b); | |
} | |
return b; | |
} | |
function foldr(f,b,str) { | |
for (var i = str.length; i--; ) { | |
b = A2(f, Utils.chr(str[i]), b); | |
} | |
return b; | |
} | |
function split(sep, str) { | |
return List.fromArray(str.split(sep)); | |
} | |
function join(sep, strs) { | |
return List.toArray(strs).join(sep); | |
} | |
function repeat(n, str) { | |
var result = ''; | |
while (n > 0) { | |
if (n & 1) result += str; | |
n >>= 1, str += str; | |
} | |
return result; | |
} | |
function slice(start, end, str) { | |
return str.slice(start,end); | |
} | |
function left(n, str) { | |
return n < 1 ? "" : str.slice(0,n); | |
} | |
function right(n, str) { | |
return n < 1 ? "" : str.slice(-n); | |
} | |
function dropLeft(n, str) { | |
return n < 1 ? str : str.slice(n); | |
} | |
function dropRight(n, str) { | |
return n < 1 ? str : str.slice(0,-n); | |
} | |
function pad(n,chr,str) { | |
var half = (n - str.length) / 2; | |
return repeat(Math.ceil(half),chr) + str + repeat(half|0,chr); | |
} | |
function padRight(n,chr,str) { | |
return str + repeat(n - str.length, chr); | |
} | |
function padLeft(n,chr,str) { | |
return repeat(n - str.length, chr) + str; | |
} | |
function trim(str) { | |
return str.trim(); | |
} | |
function trimLeft(str) { | |
return str.trimLeft(); | |
} | |
function trimRight(str) { | |
return str.trimRight(); | |
} | |
function words(str) { | |
return List.fromArray(str.trim().split(/\s+/g)); | |
} | |
function lines(str) { | |
return List.fromArray(str.split(/\r\n|\r|\n/g)); | |
} | |
function toUpper(str) { | |
return str.toUpperCase(); | |
} | |
function toLower(str) { | |
return str.toLowerCase(); | |
} | |
function any(pred, str) { | |
for (var i = str.length; i--; ) { | |
if (pred(Utils.chr(str[i]))) return true; | |
} | |
return false; | |
} | |
function all(pred, str) { | |
for (var i = str.length; i--; ) { | |
if (!pred(Utils.chr(str[i]))) return false; | |
} | |
return true; | |
} | |
function contains(sub, str) { | |
return str.indexOf(sub) > -1; | |
} | |
function startsWith(sub, str) { | |
return str.indexOf(sub) === 0; | |
} | |
function endsWith(sub, str) { | |
return str.length >= sub.length && | |
str.lastIndexOf(sub) === str.length - sub.length; | |
} | |
function indexes(sub, str) { | |
var subLen = sub.length; | |
var i = 0; | |
var is = []; | |
while ((i = str.indexOf(sub, i)) > -1) { | |
is.push(i); | |
i = i + subLen; | |
} | |
return List.fromArray(is); | |
} | |
function toInt(s) { | |
var len = s.length; | |
if (len === 0) { return Maybe.Nothing; } | |
var start = 0; | |
if (s[0] == '-') { | |
if (len === 1) { return Maybe.Nothing; } | |
start = 1; | |
} | |
for (var i = start; i < len; ++i) { | |
if (!Char.isDigit(s[i])) { return Maybe.Nothing; } | |
} | |
return Maybe.Just(parseInt(s, 10)); | |
} | |
function toFloat(s) { | |
var len = s.length; | |
if (len === 0) { return Maybe.Nothing; } | |
var start = 0; | |
if (s[0] == '-') { | |
if (len === 1) { return Maybe.Nothing; } | |
start = 1; | |
} | |
var dotCount = 0; | |
for (var i = start; i < len; ++i) { | |
if (Char.isDigit(s[i])) { continue; } | |
if (s[i] === '.') { | |
dotCount += 1; | |
if (dotCount <= 1) { continue; } | |
} | |
return Maybe.Nothing; | |
} | |
return Maybe.Just(parseFloat(s)); | |
} | |
function toList(str) { | |
return List.fromArray(str.split('').map(Utils.chr)); | |
} | |
function fromList(chars) { | |
return List.toArray(chars).join(''); | |
} | |
return Elm.Native.String.values = { | |
isEmpty: isEmpty, | |
cons: F2(cons), | |
uncons: uncons, | |
append: F2(append), | |
concat: concat, | |
length: length, | |
map: F2(map), | |
filter: F2(filter), | |
reverse: reverse, | |
foldl: F3(foldl), | |
foldr: F3(foldr), | |
split: F2(split), | |
join: F2(join), | |
repeat: F2(repeat), | |
slice: F3(slice), | |
left: F2(left), | |
right: F2(right), | |
dropLeft: F2(dropLeft), | |
dropRight: F2(dropRight), | |
pad: F3(pad), | |
padLeft: F3(padLeft), | |
padRight: F3(padRight), | |
trim: trim, | |
trimLeft: trimLeft, | |
trimRight: trimRight, | |
words: words, | |
lines: lines, | |
toUpper: toUpper, | |
toLower: toLower, | |
any: F2(any), | |
all: F2(all), | |
contains: F2(contains), | |
startsWith: F2(startsWith), | |
endsWith: F2(endsWith), | |
indexes: F2(indexes), | |
toInt: toInt, | |
toFloat: toFloat, | |
toList: toList, | |
fromList: fromList | |
}; | |
}; | |
Elm.Native.Graphics.Input = {}; | |
Elm.Native.Graphics.Input.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Graphics = elm.Native.Graphics || {}; | |
elm.Native.Graphics.Input = elm.Native.Graphics.Input || {}; | |
if (elm.Native.Graphics.Input.values) return elm.Native.Graphics.Input.values; | |
var Render = ElmRuntime.use(ElmRuntime.Render.Element); | |
var newNode = ElmRuntime.use(ElmRuntime.Render.Utils).newElement; | |
var toCss = Elm.Native.Color.make(elm).toCss; | |
var Text = Elm.Native.Text.make(elm); | |
var Signal = Elm.Signal.make(elm); | |
var newElement = Elm.Graphics.Element.make(elm).newElement; | |
var List = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
var Tuple2 = Utils.Tuple2; | |
function input(initialValue) { | |
var signal = Signal.constant(initialValue); | |
return { _:{}, signal:signal, handle:signal }; | |
} | |
function renderDropDown(signal, values) { | |
return function(_) { | |
var entries = List.toArray(values); | |
var drop = newNode('select'); | |
drop.style.border = '0 solid'; | |
drop.style.pointerEvents = 'auto'; | |
for (var i = 0; i < entries.length; ++i) { | |
var option = newNode('option'); | |
var name = entries[i]._0; | |
option.value = name; | |
option.innerHTML = name; | |
drop.appendChild(option); | |
} | |
drop.addEventListener('change', function() { | |
elm.notify(signal.id, entries[drop.selectedIndex]._1); | |
}); | |
var t = drop.cloneNode(true); | |
t.style.visibility = "hidden"; | |
elm.node.appendChild(t); | |
var style = window.getComputedStyle(t, null); | |
var w = Math.ceil(style.getPropertyValue("width").slice(0,-2) - 0); | |
var h = Math.ceil(style.getPropertyValue("height").slice(0,-2) - 0); | |
elm.node.removeChild(t); | |
return drop; | |
}; | |
} | |
function updateDropDown(node, oldModel, newModel) { | |
} | |
function dropDown(signal, values) { | |
return A3(newElement, 100, 24, { | |
ctor: 'Custom', | |
type: 'DropDown', | |
render: renderDropDown(signal,values), | |
update: updateDropDown, | |
model: {} | |
}); | |
} | |
function renderButton(model) { | |
var node = newNode('button'); | |
node.style.display = 'block'; | |
node.style.pointerEvents = 'auto'; | |
node.elm_signal = model.signal; | |
node.elm_value = model.value; | |
function click() { | |
elm.notify(node.elm_signal.id, node.elm_value); | |
} | |
node.addEventListener('click', click); | |
node.innerHTML = model.text; | |
return node; | |
} | |
function updateButton(node, oldModel, newModel) { | |
node.elm_signal = newModel.signal; | |
node.elm_value = newModel.value; | |
var txt = newModel.text; | |
if (oldModel.text !== txt) node.innerHTML = txt; | |
} | |
function button(signal, value, text) { | |
return A3(newElement, 100, 40, { | |
ctor: 'Custom', | |
type: 'Button', | |
render: renderButton, | |
update: updateButton, | |
model: { signal:signal, value:value, text:text } | |
}); | |
} | |
function renderCustomButton(model) { | |
var btn = newNode('div'); | |
btn.style.pointerEvents = 'auto'; | |
btn.elm_signal = model.signal; | |
btn.elm_value = model.value; | |
btn.elm_up = Render.render(model.up); | |
btn.elm_hover = Render.render(model.hover); | |
btn.elm_down = Render.render(model.down); | |
function replace(node) { | |
if (node !== btn.firstChild) { | |
btn.replaceChild(node, btn.firstChild); | |
} | |
} | |
var overCount = 0; | |
function over(e) { | |
if (overCount++ > 0) return; | |
replace(btn.elm_hover); | |
} | |
function out(e) { | |
if (btn.contains(e.toElement || e.relatedTarget)) return; | |
overCount = 0; | |
replace(btn.elm_up); | |
} | |
function up() { | |
replace(btn.elm_hover); | |
elm.notify(btn.elm_signal.id, btn.elm_value); | |
} | |
function down() { | |
replace(btn.elm_down); | |
} | |
btn.addEventListener('mouseover', over); | |
btn.addEventListener('mouseout' , out); | |
btn.addEventListener('mousedown', down); | |
btn.addEventListener('mouseup' , up); | |
btn.appendChild(btn.elm_up); | |
return btn; | |
} | |
function updateCustomButton(node, oldModel, newModel) { | |
var signal = newModel.signal; | |
node.elm_up.elm_signal = signal; | |
node.elm_hover.elm_signal = signal; | |
node.elm_down.elm_signal = signal; | |
var value = newModel.value; | |
node.elm_up.elm_value = value; | |
node.elm_hover.elm_value = value; | |
node.elm_down.elm_value = value; | |
Render.update(node.elm_up, oldModel.up, newModel.up) | |
Render.update(node.elm_hover, oldModel.hover, newModel.hover) | |
Render.update(node.elm_down, oldModel.down, newModel.down) | |
} | |
function max3(a,b,c) { | |
var ab = a > b ? a : b; | |
return ab > c ? ab : c; | |
} | |
function customButton(signal, value, up, hover, down) { | |
return A3(newElement, | |
max3(up.props.width, hover.props.width, down.props.width), | |
max3(up.props.height, hover.props.height, down.props.height), | |
{ ctor: 'Custom', | |
type: 'CustomButton', | |
render: renderCustomButton, | |
update: updateCustomButton, | |
model: { signal:signal, value:value, up:up, hover:hover, down:down } | |
}); | |
} | |
function renderCheckbox(model) { | |
var node = newNode('input'); | |
node.type = 'checkbox'; | |
node.checked = model.checked; | |
node.style.display = 'block'; | |
node.style.pointerEvents = 'auto'; | |
node.elm_signal = model.signal; | |
node.elm_handler = model.handler; | |
function change() { | |
elm.notify(node.elm_signal.id, node.elm_handler(node.checked)); | |
} | |
node.addEventListener('change', change); | |
return node; | |
} | |
function updateCheckbox(node, oldModel, newModel) { | |
node.elm_signal = newModel.signal; | |
node.elm_handler = newModel.handler; | |
node.checked = newModel.checked; | |
return true; | |
} | |
function checkbox(signal, handler, checked) { | |
return A3(newElement, 13, 13, { | |
ctor: 'Custom', | |
type: 'CheckBox', | |
render: renderCheckbox, | |
update: updateCheckbox, | |
model: { signal:signal, handler:handler, checked:checked } | |
}); | |
} | |
function setRange(node, start, end, dir) { | |
if (node.parentNode) { | |
node.setSelectionRange(start, end, dir); | |
} else { | |
setTimeout(function(){node.setSelectionRange(start, end, dir);}, 0); | |
} | |
} | |
function updateIfNeeded(css, attribute, latestAttribute) { | |
if (css[attribute] !== latestAttribute) { | |
css[attribute] = latestAttribute; | |
} | |
} | |
function cssDimensions(dimensions) { | |
return dimensions.top + 'px ' + | |
dimensions.right + 'px ' + | |
dimensions.bottom + 'px ' + | |
dimensions.left + 'px'; | |
} | |
function updateFieldStyle(css, style) { | |
updateIfNeeded(css, 'padding', cssDimensions(style.padding)); | |
var outline = style.outline; | |
updateIfNeeded(css, 'border-width', cssDimensions(outline.width)); | |
updateIfNeeded(css, 'border-color', toCss(outline.color)); | |
updateIfNeeded(css, 'border-radius', outline.radius + 'px'); | |
var highlight = style.highlight; | |
if (highlight.width === 0) { | |
css.outline = 'none'; | |
} else { | |
updateIfNeeded(css, 'outline-width', highlight.width + 'px'); | |
updateIfNeeded(css, 'outline-color', toCss(highlight.color)); | |
} | |
var textStyle = style.style; | |
updateIfNeeded(css, 'color', toCss(textStyle.color)); | |
if (textStyle.typeface.ctor !== '[]') { | |
updateIfNeeded(css, 'font-family', Text.toTypefaces(textStyle.typeface)); | |
} | |
if (textStyle.height.ctor !== "Nothing") { | |
updateIfNeeded(css, 'font-size', textStyle.height._0 + 'px'); | |
} | |
updateIfNeeded(css, 'font-weight', textStyle.bold ? 'bold' : 'normal'); | |
updateIfNeeded(css, 'font-style', textStyle.italic ? 'italic' : 'normal'); | |
if (textStyle.line.ctor !== 'Nothing') { | |
updateIfNeeded(css, 'text-decoration', Text.toLine(textStyle.line._0)); | |
} | |
} | |
function renderField(model) { | |
var field = newNode('input'); | |
updateFieldStyle(field.style, model.style); | |
field.style.borderStyle = 'solid'; | |
field.style.pointerEvents = 'auto'; | |
field.type = model.type; | |
field.placeholder = model.placeHolder; | |
field.value = model.content.string; | |
field.elm_signal = model.signal; | |
field.elm_handler = model.handler; | |
field.elm_old_value = field.value; | |
function inputUpdate(event) { | |
var curr = field.elm_old_value; | |
var next = field.value; | |
if (curr === next) { | |
return; | |
} | |
var direction = field.selectionDirection === 'forward' ? 'Forward' : 'Backward'; | |
var start = field.selectionStart; | |
var end = field.selectionEnd; | |
field.value = field.elm_old_value; | |
elm.notify(field.elm_signal.id, field.elm_handler({ | |
_:{}, | |
string: next, | |
selection: { | |
_:{}, | |
start: start, | |
end: end, | |
direction: { ctor: direction } | |
} | |
})); | |
} | |
field.addEventListener('input', inputUpdate); | |
field.addEventListener('focus', function() { | |
field.elm_hasFocus = true; | |
}); | |
field.addEventListener('blur', function() { | |
field.elm_hasFocus = false; | |
}); | |
return field; | |
} | |
function updateField(field, oldModel, newModel) { | |
if (oldModel.style !== newModel.style) { | |
updateFieldStyle(field.style, newModel.style); | |
} | |
field.elm_signal = newModel.signal; | |
field.elm_handler = newModel.handler; | |
field.type = newModel.type; | |
field.placeholder = newModel.placeHolder; | |
var value = newModel.content.string; | |
field.value = value; | |
field.elm_old_value = value; | |
if (field.elm_hasFocus) { | |
var selection = newModel.content.selection; | |
var direction = selection.direction.ctor === 'Forward' ? 'forward' : 'backward'; | |
setRange(field, selection.start, selection.end, direction); | |
} | |
} | |
function mkField(type) { | |
function field(style, signal, handler, placeHolder, content) { | |
var padding = style.padding; | |
var outline = style.outline.width; | |
var adjustWidth = padding.left + padding.right + outline.left + outline.right; | |
var adjustHeight = padding.top + padding.bottom + outline.top + outline.bottom; | |
return A3(newElement, 200, 30, { | |
ctor: 'Custom', | |
type: type + 'Field', | |
adjustWidth: adjustWidth, | |
adjustHeight: adjustHeight, | |
render: renderField, | |
update: updateField, | |
model: { | |
signal:signal, | |
handler:handler, | |
placeHolder:placeHolder, | |
content:content, | |
style:style, | |
type:type | |
} | |
}); | |
} | |
return F5(field); | |
} | |
function hoverable(signal, handler, elem) { | |
function onHover(bool) { | |
elm.notify(signal.id, handler(bool)); | |
} | |
var props = Utils.replace([['hover',onHover]], elem.props); | |
return { props:props, element:elem.element }; | |
} | |
function clickable(signal, value, elem) { | |
function onClick(bool) { | |
elm.notify(signal.id, value); | |
} | |
var props = Utils.replace([['click',onClick]], elem.props); | |
return { props:props, element:elem.element }; | |
} | |
return elm.Native.Graphics.Input.values = { | |
input:input, | |
button:F3(button), | |
customButton:F5(customButton), | |
checkbox:F3(checkbox), | |
dropDown:F2(dropDown), | |
field:mkField('text'), | |
email:mkField('email'), | |
password:mkField('password'), | |
hoverable:F3(hoverable), | |
clickable:F3(clickable) | |
}; | |
}; | |
Elm.Native.Graphics.Collage = {}; | |
Elm.Native.Graphics.Collage.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Graphics = elm.Native.Graphics || {}; | |
elm.Native.Graphics.Collage = elm.Native.Graphics.Collage || {}; | |
if (elm.Native.Graphics.Collage.values) return elm.Native.Graphics.Collage.values; | |
var newElement = Elm.Graphics.Element.make(elm).newElement; | |
var C = ElmRuntime.use(ElmRuntime.Render.Collage); | |
function collage(w,h,forms) { | |
return A3(newElement, w, h, { | |
ctor: 'Custom', | |
type: 'Collage', | |
render: C.render, | |
update: C.update, | |
model: {w:w, h:h, forms:forms} | |
}); | |
} | |
return elm.Native.Graphics.Collage.values = { collage:F3(collage) }; | |
};Elm.Native.Time = {}; | |
Elm.Native.Time.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Time = elm.Native.Time || {}; | |
if (elm.Native.Time.values) return elm.Native.Time.values; | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
var Maybe = Elm.Maybe.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function fpsWhen(desiredFPS, isOn) { | |
var msPerFrame = 1000 / desiredFPS; | |
var prev = Date.now(), curr = prev, diff = 0, wasOn = true; | |
var ticker = Signal.constant(diff); | |
function tick(zero) { return function() { | |
curr = Date.now(); | |
diff = zero ? 0 : curr - prev; | |
prev = curr; | |
elm.notify(ticker.id, diff); | |
}; | |
} | |
var timeoutID = 0; | |
function f(isOn, t) { | |
if (isOn) { | |
timeoutID = setTimeout(tick(!wasOn && isOn), msPerFrame); | |
} else if (wasOn) { | |
clearTimeout(timeoutID); | |
} | |
wasOn = isOn; | |
return t; | |
} | |
return A3( NS.liftImpure2, F2(f), isOn, ticker ); | |
} | |
function every(t) { | |
var clock = Signal.constant(Date.now()); | |
setInterval(function() { | |
elm.notify(clock.id, Date.now()); | |
}, t); | |
return clock; | |
} | |
function since(t, s) { | |
function cmp(a,b) { return !Utils.eq(a,b); } | |
var dcount = Signal.count(A2(NS.delay, t, s)); | |
return A3( Signal.lift2, F2(cmp), Signal.count(s), dcount ); | |
} | |
function read(s) { | |
var t = Date.parse(s); | |
return isNaN(t) ? Maybe.Nothing : Maybe.Just(t); | |
} | |
return elm.Native.Time.values = { | |
fpsWhen : F2(fpsWhen), | |
fps : function(t) { return fpsWhen(t, Signal.constant(true)); }, | |
every : every, | |
delay : NS.delay, | |
timestamp : NS.timestamp, | |
since : F2(since), | |
toDate : function(t) { return new window.Date(t); }, | |
read : read | |
}; | |
}; | |
Elm.Native.Random = {}; | |
Elm.Native.Random.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Random = elm.Native.Random || {}; | |
if (elm.Native.Random.values) return elm.Native.Random.values; | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
var List = Elm.Native.List.make(elm); | |
function range(min, max, signal) { | |
function f(x) { return Math.floor(Math.random() * (max-min+1)) + min; } | |
return A2( NS.liftImpure, f, signal ); | |
} | |
function float_(signal) { | |
function f(x) { return Math.random(); } | |
return A2( NS.liftImpure, f, signal ); | |
} | |
function floatList(signal) { | |
function f(n) { | |
if (n < 0) return List.Nil; | |
var arr = new Array(n); | |
for (var i = n; i--; ) { | |
arr[i] = Math.random(); | |
} | |
return List.fromArray(arr); | |
} | |
return A2( NS.liftImpure, f, signal ); | |
} | |
return elm.Native.Random.values = { | |
range: F3(range), | |
float_: float_, | |
floatList: floatList | |
}; | |
}; | |
Elm.Native.Window = {}; | |
Elm.Native.Window.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Window = elm.Native.Window || {}; | |
if (elm.Native.Window.values) return elm.Native.Window.values; | |
var Signal = Elm.Signal.make(elm); | |
var Tuple2 = Elm.Native.Utils.make(elm).Tuple2; | |
function getWidth() { return elm.node.clientWidth; } | |
function getHeight() { | |
if (elm.display === ElmRuntime.Display.FULLSCREEN) { | |
return window.innerHeight; | |
} | |
return elm.node.clientHeight; | |
} | |
var dimensions = Signal.constant(Tuple2(getWidth(), getHeight())); | |
dimensions.defaultNumberOfKids = 2; | |
// Do not move width and height into Elm. By setting the default number of kids, | |
// the resize listener can be detached. | |
var width = A2(Signal.lift, function(p){return p._0;}, dimensions); | |
width.defaultNumberOfKids = 0; | |
var height = A2(Signal.lift, function(p){return p._1;}, dimensions); | |
height.defaultNumberOfKids = 0; | |
function resizeIfNeeded() { | |
// Do not trigger event if the dimensions have not changed. | |
// This should be most of the time. | |
var w = getWidth(); | |
var h = getHeight(); | |
if (dimensions.value._0 === w && dimensions.value._1 === h) return; | |
setTimeout(function () { | |
// Check again to see if the dimensions have changed. | |
// It is conceivable that the dimensions have changed | |
// again while some other event was being processed. | |
var w = getWidth(); | |
var h = getHeight(); | |
if (dimensions.value._0 === w && dimensions.value._1 === h) return; | |
elm.notify(dimensions.id, Tuple2(w,h)); | |
}, 0); | |
} | |
elm.addListener([dimensions.id], window, 'resize', resizeIfNeeded); | |
return elm.Native.Window.values = { | |
dimensions:dimensions, | |
width:width, | |
height:height, | |
resizeIfNeeded:resizeIfNeeded | |
}; | |
}; | |
Elm.Native.Http = {}; | |
Elm.Native.Http.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Http = elm.Native.Http || {}; | |
if (elm.Native.Http.values) return elm.Native.Http.values; | |
var List = Elm.List.make(elm); | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
function registerReq(queue,responses) { | |
return function(req) { | |
if (req.url.length > 0) { | |
sendReq(queue,responses,req); | |
} | |
}; | |
} | |
function updateQueue(queue,responses) { | |
if (queue.length > 0) { | |
elm.notify(responses.id, queue[0].value); | |
if (queue[0].value.ctor !== 'Waiting') { | |
queue.shift(); | |
setTimeout(function() { updateQueue(queue,responses); }, 0); | |
} | |
} | |
} | |
function sendReq(queue,responses,req) { | |
var response = { value: { ctor:'Waiting' } }; | |
queue.push(response); | |
var request = (window.ActiveXObject | |
? new ActiveXObject("Microsoft.XMLHTTP") | |
: new XMLHttpRequest()); | |
request.onreadystatechange = function(e) { | |
if (request.readyState === 4) { | |
response.value = (request.status >= 200 && request.status < 300 ? | |
{ ctor:'Success', _0:request.responseText } : | |
{ ctor:'Failure', _0:request.status, _1:request.statusText }); | |
setTimeout(function() { updateQueue(queue,responses); }, 0); | |
} | |
}; | |
request.open(req.verb, req.url, true); | |
function setHeader(pair) { | |
request.setRequestHeader( pair._0, pair._1 ); | |
} | |
A2( List.map, setHeader, req.headers ); | |
request.send(req.body); | |
} | |
function send(requests) { | |
var responses = Signal.constant(elm.Http.values.Waiting); | |
var sender = A2( NS.liftImpure, registerReq([],responses), requests ); | |
function f(x) { return function(y) { return x; } } | |
return A3( Signal.lift2, f, responses, sender ); | |
} | |
return elm.Native.Http.values = { | |
send:send | |
}; | |
}; | |
Elm.Native.Keyboard = {}; | |
Elm.Native.Keyboard.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Keyboard = elm.Native.Keyboard || {}; | |
if (elm.Native.Keyboard.values) return elm.Native.Keyboard.values; | |
// Duplicated from Native.Signal | |
function send(node, timestep, updated, duplicate) { | |
var kids = node.kids; | |
for (var i = kids.length; i--; ) { | |
kids[i].recv(timestep, updated, duplicate, node.id); | |
} | |
} | |
var Signal = Elm.Signal.make(elm); | |
var NList = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
var downEvents = Signal.constant(0); | |
var upEvents = Signal.constant(0); | |
var blurEvents = Signal.constant(0); | |
elm.addListener([downEvents.id], document, 'keydown', function down(e) { | |
elm.notify(downEvents.id, e.keyCode); | |
}); | |
elm.addListener([upEvents.id], document, 'keyup', function up(e) { | |
elm.notify(upEvents.id, e.keyCode); | |
}); | |
elm.addListener([blurEvents.id], document, 'blur', function blur(e) { | |
elm.notify(blurEvents.id, NList.Nil); | |
}); | |
function KeyMerge(down, up, blur) { | |
var args = [down,up,blur]; | |
this.id = Utils.guid(); | |
// Ignore starting values here | |
this.value = NList.Nil | |
this.kids = []; | |
var n = args.length; | |
var count = 0; | |
var oneUpdated = false; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
++count; | |
if (updated) { | |
// We know this a change must only be one of the following cases | |
if (parentID === down.id && !(NList.member(down.value)(this.value))) { | |
oneUpdated = true; | |
this.value = NList.Cons(down.value, this.value); | |
} | |
if (parentID === up.id) { | |
oneUpdated = true; | |
var notEq = function(kc) { return kc !== up.value }; | |
this.value = NList.filter(notEq)(this.value); | |
} | |
if (parentID === blur.id) { | |
oneUpdated = true; | |
this.value = NList.Nil; | |
} | |
} | |
if (count == n) { | |
send(this, timestep, oneUpdated, !oneUpdated); | |
oneUpdated = false; | |
count = 0; | |
} | |
}; | |
for (var i = n; i--; ) { args[i].kids.push(this); } | |
} | |
var keysDown = Signal.dropRepeats(new KeyMerge(downEvents,upEvents,blurEvents)); | |
function keySignal(f) { | |
var signal = A2(Signal.lift, f, keysDown); | |
// must set the default number of kids to make it possible to filter | |
// these signals if they are not actually used. | |
keysDown.defaultNumberOfKids += 1; | |
signal.defaultNumberOfKids = 1; | |
var filtered = Signal.dropRepeats(signal) | |
filtered.defaultNumberOfKids = 0; | |
return filtered; | |
} | |
function dir(up, down, left, right) { | |
function f(ks) { | |
var x = 0, y = 0; | |
while (ks.ctor === "::") { | |
switch (ks._0) { | |
case left : --x; break; | |
case right: ++x; break; | |
case up : ++y; break; | |
case down : --y; break; | |
} | |
ks = ks._1; | |
} | |
return { _:{}, x:x, y:y }; | |
} | |
return keySignal(f); | |
} | |
function is(key) { return keySignal(NList.member(key)); } | |
var lastPressed = downEvents; | |
return elm.Native.Keyboard.values = { | |
isDown:is, | |
directions:F4(dir), | |
keysDown:keysDown, | |
lastPressed:lastPressed | |
}; | |
}; | |
Elm.Native.Touch = {}; | |
Elm.Native.Touch.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Touch = elm.Native.Touch || {}; | |
if (elm.Native.Touch.values) return elm.Native.Touch.values; | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
var List = Elm.Native.List.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
function Dict() { | |
this.keys = []; | |
this.values = []; | |
this.insert = function(key,value) { | |
this.keys.push(key); | |
this.values.push(value); | |
}; | |
this.lookup = function(key) { | |
var i = this.keys.indexOf(key) | |
return i >= 0 ? this.values[i] : {x:0,y:0,t:0}; | |
}; | |
this.remove = function(key) { | |
var i = this.keys.indexOf(key); | |
if (i < 0) return; | |
var t = this.values[i]; | |
this.keys.splice(i,1); | |
this.values.splice(i,1); | |
return t; | |
}; | |
this.clear = function() { | |
this.keys = []; | |
this.values = []; | |
}; | |
} | |
var root = Signal.constant([]), | |
tapTime = 500, | |
hasTap = false, | |
tap = {_:{},x:0,y:0}, | |
dict = new Dict(); | |
function touch(t) { | |
var r = dict.lookup(t.identifier); | |
var point = Utils.getXY(t); | |
return {_ : {}, | |
id: t.identifier, | |
x : point._0, | |
y : point._1, | |
x0: r.x, | |
y0: r.y, | |
t0: r.t | |
}; | |
} | |
var node = elm.display === ElmRuntime.Display.FULLSCREEN ? document : elm.node; | |
function start(e) { | |
var point = Utils.getXY(e); | |
dict.insert(e.identifier, | |
{x: point._0, | |
y: point._1, | |
t: Date.now()}); | |
} | |
function end(e) { | |
var t = dict.remove(e.identifier); | |
if (Date.now() - t.t < tapTime) { | |
hasTap = true; | |
tap = {_:{}, x:t.x, y:t.y}; | |
} | |
} | |
function listen(name, f) { | |
function update(e) { | |
for (var i = e.changedTouches.length; i--; ) { f(e.changedTouches[i]); } | |
var ts = new Array(e.touches.length); | |
for (var i = e.touches.length; i--; ) { ts[i] = touch(e.touches[i]); } | |
elm.notify(root.id, ts); | |
e.preventDefault(); | |
} | |
elm.addListener([root.id], node, name, update); | |
} | |
listen("touchstart", start); | |
listen("touchmove", function(_){}); | |
listen("touchend", end); | |
listen("touchcancel", end); | |
listen("touchleave", end); | |
var mouseID = -1; | |
function move(e) { | |
var point = Utils.getXY(e); | |
for (var i = root.value.length; i--; ) { | |
if (root.value[i].id === mouseID) { | |
root.value[i].x = point._0; | |
root.value[i].y = point._1; | |
elm.notify(root.id, root.value); | |
break; | |
} | |
} | |
} | |
elm.addListener([root.id], node, "mousedown", function down(e) { | |
node.addEventListener("mousemove", move); | |
e.identifier = mouseID; | |
start(e); | |
root.value.push(touch(e)); | |
elm.notify(root.id, root.value); | |
}); | |
elm.addListener([root.id], node, "mouseup", function up(e) { | |
node.removeEventListener("mousemove", move); | |
e.identifier = mouseID; | |
end(e); | |
for (var i = root.value.length; i--; ) { | |
if (root.value[i].id === mouseID) { | |
root.value.splice(i, 1); | |
--mouseID; | |
break; | |
} | |
} | |
elm.notify(root.id, root.value); | |
}); | |
elm.addListener([root.id], node, "blur", function blur(e) { | |
node.removeEventListener("mousemove", move); | |
if (root.value.length > 0) { | |
elm.notify(root.id, []); | |
--mouseID; | |
} | |
dict.clear(); | |
}); | |
function dependency(f) { | |
var sig = A2( NS.liftImpure, f, root ); | |
root.defaultNumberOfKids += 1; | |
sig.defaultNumberOfKids = 0; | |
return sig; | |
} | |
var touches = dependency(List.fromArray); | |
var taps = function() { | |
var sig = dependency(function(_) { return tap; }); | |
sig.defaultNumberOfKids = 1; | |
function pred(_) { var b = hasTap; hasTap = false; return b; } | |
var sig2 = A3( Signal.keepIf, pred, {_:{},x:0,y:0}, sig); | |
sig2.defaultNumberOfKids = 0; | |
return sig2; | |
}(); | |
return elm.Native.Touch.values = { touches: touches, taps: taps }; | |
}; | |
Elm.Native.Mouse = {}; | |
Elm.Native.Mouse.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Mouse = elm.Native.Mouse || {}; | |
if (elm.Native.Mouse.values) return elm.Native.Mouse.values; | |
var Signal = Elm.Signal.make(elm); | |
var Utils = Elm.Native.Utils.make(elm); | |
var position = Signal.constant(Utils.Tuple2(0,0)); | |
position.defaultNumberOfKids = 2; | |
// do not move x and y into Elm. By setting their default number | |
// of kids, it is possible to detatch the mouse listeners if | |
// they are not needed. | |
var x = A2( Signal.lift, function(p){return p._0}, position); | |
x.defaultNumberOfKids = 0; | |
var y = A2( Signal.lift, function(p){return p._1}, position); | |
y.defaultNumberOfKids = 0; | |
var isDown = Signal.constant(false); | |
var clicks = Signal.constant(Utils.Tuple0); | |
var node = elm.display === ElmRuntime.Display.FULLSCREEN ? document : elm.node; | |
elm.addListener([clicks.id], node, 'click', function click() { | |
elm.notify(clicks.id, Utils.Tuple0); | |
}); | |
elm.addListener([isDown.id], node, 'mousedown', function down() { | |
elm.notify(isDown.id, true); | |
}); | |
elm.addListener([isDown.id], node, 'mouseup', function up() { | |
elm.notify(isDown.id, false); | |
}); | |
elm.addListener([position.id], node, 'mousemove', function move(e) { | |
elm.notify(position.id, Utils.getXY(e)); | |
}); | |
return elm.Native.Mouse.values = { | |
position: position, | |
x:x, | |
y:y, | |
isDown: isDown, | |
clicks: clicks | |
}; | |
}; | |
Elm.Native.Signal = {}; | |
Elm.Native.Signal.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.Signal = elm.Native.Signal || {}; | |
if (elm.Native.Signal.values) return elm.Native.Signal.values; | |
var Utils = Elm.Native.Utils.make(elm); | |
var foldr1 = Elm.List.make(elm).foldr1; | |
function send(node, timestep, updated, duplicate) { | |
var kids = node.kids; | |
for (var i = kids.length; i--; ) { | |
kids[i].recv(timestep, updated, duplicate, node.id); | |
} | |
} | |
function Input(base) { | |
this.id = Utils.guid(); | |
this.value = base; | |
this.kids = []; | |
this.defaultNumberOfKids = 0; | |
this.recv = function(timestep, eid, v) { | |
var updated = eid === this.id; | |
if (updated) { this.value = v; } | |
// TODO: consider changing this to an actual duplicate check | |
var duplicate = !updated; | |
send(this, timestep, updated, duplicate); | |
return updated; | |
}; | |
elm.inputs.push(this); | |
} | |
function LiftN(pure, update, args) { | |
this.id = Utils.guid(); | |
this.value = update(); | |
this.kids = []; | |
var n = args.length; | |
var count = 0; | |
var oneUpdated = false; | |
var allDuplicate = true; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
++count; | |
if (updated) { oneUpdated = true; } | |
if (!duplicate) { allDuplicate = false; } | |
if (count === n) { | |
if (!(pure && allDuplicate)) { this.value = update(); } | |
send(this, timestep, oneUpdated, pure && allDuplicate); | |
oneUpdated = false; | |
allDuplicate = true; | |
count = 0; | |
} | |
}; | |
for (var i = n; i--; ) { args[i].kids.push(this); } | |
} | |
function lift(func, a) { | |
function update() { return func(a.value); } | |
return new LiftN(true, update, [a]); | |
} | |
function lift2(func, a, b) { | |
function update() { return A2( func, a.value, b.value ); } | |
return new LiftN(true, update, [a,b]); | |
} | |
function lift3(func, a, b, c) { | |
function update() { return A3( func, a.value, b.value, c.value ); } | |
return new LiftN(true, update, [a,b,c]); | |
} | |
function lift4(func, a, b, c, d) { | |
function update() { return A4( func, a.value, b.value, c.value, d.value ); } | |
return new LiftN(true, update, [a,b,c,d]); | |
} | |
function lift5(func, a, b, c, d, e) { | |
function update() { return A5( func, a.value, b.value, c.value, d.value, e.value ); } | |
return new LiftN(true, update, [a,b,c,d,e]); | |
} | |
function lift6(func, a, b, c, d, e, f) { | |
function update() { return A6( func, a.value, b.value, c.value, d.value, e.value, f.value ); } | |
return new LiftN(true, update, [a,b,c,d,e,f]); | |
} | |
function lift7(func, a, b, c, d, e, f, g) { | |
function update() { return A7( func, a.value, b.value, c.value, d.value, e.value, f.value, g.value ); } | |
return new LiftN(true, update, [a,b,c,d,e,f,g]); | |
} | |
function lift8(func, a, b, c, d, e, f, g, h) { | |
function update() { return A8( func, a.value, b.value, c.value, d.value, e.value, f.value, g.value, h.value ); } | |
return new LiftN(true, update, [a,b,c,d,e,f,g,h]); | |
} | |
function liftImpure(func, a) { | |
function update() { return func(a.value); } | |
return new LiftN(false, update, [a]); | |
} | |
function liftImpure2(func, a, b) { | |
function update() { return A2( func, a.value, b.value ); } | |
return new LiftN(false, update, [a,b]); | |
} | |
//For lifting side-effecting functions | |
function RawLift(func, recvF, s) { | |
this.id = Utils.guid(); | |
this.value = func(s.value); | |
this.kids = []; | |
this.recv = recvF(this); | |
s.kids.push(this); | |
} | |
function rawLift(f, r, a) { | |
return new RawLift(f,r,a); | |
} | |
function Foldp(step, state, input) { | |
this.id = Utils.guid(); | |
this.value = state; | |
this.kids = []; | |
this.recv = function(timestep, updated, _, parentID) { | |
if (updated) { | |
this.value = A2( step, input.value, this.value ); | |
} | |
var duplicate = !updated; | |
send(this, timestep, updated, duplicate); | |
}; | |
input.kids.push(this); | |
} | |
function foldp(step, state, input) { | |
return new Foldp(step, state, input); | |
} | |
function DropIf(pred,base,input) { | |
this.id = Utils.guid(); | |
var shouldDrop = pred(input.value); | |
this.value = shouldDrop ? base : input.value; | |
this.kids = []; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
if (duplicate) { | |
// runtime sanity check | |
// can be commented out when reasonably certain this doesn't occur. | |
if (!Utils.eq(this.value, input.value)) { | |
throw new Error( | |
'Runtime check of duplicate tracking went wrong!\n' + | |
'A changed value was called a duplicate.\n' + | |
'Definitely report this to <https://github.com/elm-lang/Elm/issues>\n'); | |
} | |
} | |
if (duplicate && shouldDrop) { // Duplicate, pred | |
updated = false; // -> NoUpdate | |
} | |
if (!duplicate) { // MaybeChanged | |
shouldDrop = pred(input.value); // -> update pred | |
if (shouldDrop) { // MaybeChanged, pred | |
updated = false; // -> NoUpdate | |
duplicate = true; // -> Duplicate | |
} else { // MaybeChanged, !pred | |
this.value = input.value; // -> update value | |
} | |
} | |
send(this, timestep, updated, duplicate); | |
}; | |
input.kids.push(this); | |
} | |
function DropRepeats(input) { | |
this.id = Utils.guid(); | |
this.value = input.value; | |
this.kids = []; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
if (duplicate || Utils.eq(this.value,input.value)) { // Duplicate || MaybeChanged but found to be a duplicate | |
duplicate = true; // -> Duplicate | |
updated = false; // -> NoUpdate | |
} else { // really changed value | |
this.value = input.value; // -> update value | |
} | |
send(this, timestep, updated, duplicate); | |
}; | |
input.kids.push(this); | |
} | |
function timestamp(a) { | |
function update() { return Utils.Tuple2(Date.now(), a.value); } | |
return new LiftN(update, [a]); | |
} | |
function SampleOn(s1,s2) { | |
this.id = Utils.guid(); | |
this.value = s2.value; | |
this.kids = []; | |
var count = 0; | |
var s1Updated = false; | |
var s2Updated = false; | |
var s2Duplicate = false; | |
var skip = false; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
if (parentID === s1.id) { s1Updated = updated; } | |
if (parentID === s2.id) { | |
s2Updated = updated; | |
s2Duplicate = duplicate; | |
} | |
++count; | |
if (count === 2) { | |
if (s1Updated) { | |
if (s2Duplicate && skip) { // if an update from s2 was skipped | |
s2Duplicate = false; // then this event could change the output | |
} | |
this.value = s2.value; | |
skip = false; | |
} else if (!s2Duplicate) { | |
skip = true; | |
} | |
send(this, timestep, s1Updated, s2Duplicate); | |
count = 0; | |
s1Updated = false; | |
s2Updated = false; | |
s2Duplicate = false; | |
} | |
}; | |
s1.kids.push(this); | |
s2.kids.push(this); | |
} | |
function sampleOn(s1,s2) { return new SampleOn(s1,s2); } | |
function delay(t,s) { | |
var delayed = new Input(s.value); | |
var firstEvent = true; | |
function update(rawLiftNode) { | |
return function(timestep, updated, duplicate, parentID) { | |
if(updated) { | |
setTimeout(function() { elm.notify(delayed.id, s.value); }, t); | |
} | |
} | |
} | |
A3(rawLift, function(_){}, update, s); | |
function first(a,b) { return a; } | |
// TODO find out why you would even do this whole | |
// `sampleOn delayed (uncurry fst <~ delayed ~ s)` | |
return new SampleOn(delayed, lift2(F2(first), delayed, s)); | |
} | |
function Merge(s1,s2) { | |
this.id = Utils.guid(); | |
var count = 0; | |
var current = { s : s1 | |
, updated : true | |
, duplicate : false }; | |
var next = null; | |
this.value = current.value; | |
this.kids = []; | |
this.recv = function(timestep, updated, duplicate, parentID) { | |
++count; | |
if (parentID === s2.id && next === null) { | |
next = { s : s2 | |
, updated : updated | |
, duplicate : duplicate }; | |
} else if (parentID === s1.id) { | |
next = { s : s1 | |
, updated : updated | |
, duplicate : duplicate }; | |
} | |
if (count === 2) { | |
if (current.s !== next.s) { | |
next.duplicate = false; | |
} | |
current = next; | |
this.value = current.s.value; | |
send(this, timestep, current.updated, current.duplicate); | |
next = null; | |
count = 0; | |
} | |
}; | |
s1.kids.push(this); | |
s2.kids.push(this); | |
} | |
function merge(s1,s2) { return new Merge(s1,s2); } | |
function merges(ss) { return A2(foldr1, F2(merge), ss); } | |
return elm.Native.Signal.values = { | |
constant : function(v) { return new Input(v); }, | |
lift : F2(lift ), | |
lift2 : F3(lift2), | |
lift3 : F4(lift3), | |
lift4 : F5(lift4), | |
lift5 : F6(lift5), | |
lift6 : F7(lift6), | |
lift7 : F8(lift7), | |
lift8 : F9(lift8), | |
liftImpure : F2(liftImpure ), | |
liftImpure2 : F3(liftImpure2), | |
rawLift : F3(rawLift), | |
foldp : F3(foldp), | |
delay : F2(delay), | |
merge : F2(merge), | |
merges : merges, | |
count : function(s) { return foldp(F2(function(_,c) { return c+1; }), 0, s); }, | |
countIf : F2(function(pred,s) { | |
return foldp(F2(function(x,c){ | |
return pred(x) ? c+1 : c; }), 0, s)}), | |
keepIf : F3(function(pred,base,sig) { | |
return new DropIf(function(x) {return !pred(x);},base,sig); }), | |
dropIf : F3(function(pred,base,sig) { return new DropIf(pred,base,sig); }), | |
dropRepeats : function(s) { return new DropRepeats(s);}, | |
sampleOn : F2(sampleOn), | |
timestamp : timestamp | |
}; | |
}; | |
Elm.Native.WebSocket = {}; | |
Elm.Native.WebSocket.make = function(elm) { | |
elm.Native = elm.Native || {}; | |
elm.Native.WebSocket = elm.Native.WebSocket || {}; | |
if (elm.Native.WebSocket.values) return elm.Native.WebSocket.values; | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
var List = Elm.Native.List.make(elm); | |
function open(url, outgoing) { | |
var incoming = Signal.constant(List.Nil); | |
var ws = new WebSocket(url); | |
var pending = []; | |
var ready = false; | |
ws.onopen = function(e) { | |
var len = pending.length; | |
for (var i = 0; i < len; ++i) { ws.send(pending[i]); } | |
ready = true; | |
}; | |
ws.onmessage = function(event) { | |
elm.notify(incoming.id, event.data); | |
}; | |
function send(msg) { | |
ready ? ws.send(msg) : pending.push(msg); | |
} | |
function take1(x,y) { return x } | |
return A3(Signal.lift2, F2(take1), incoming, A2(NS.liftImpure, send, outgoing)); | |
} | |
return elm.Native.WebSocket.values = { connect: F2(open) }; | |
}; | |
Elm.Trampoline = Elm.Trampoline || {}; | |
Elm.Trampoline.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Trampoline = _elm.Trampoline || {}; | |
if (_elm.Trampoline.values) | |
return _elm.Trampoline.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Trampoline"; | |
var Native = Native || {}; | |
Native.Trampoline = Elm.Native.Trampoline.make(_elm); | |
var _op = {}; | |
var trampoline = Native.Trampoline.trampoline; | |
var Continue = function (a) | |
{ | |
return {ctor: "Continue", _0: a}; | |
}; | |
var Done = function (a) | |
{ | |
return {ctor: "Done", _0: a}; | |
}; | |
_elm.Trampoline.values = {_op: _op, trampoline: trampoline, Done: Done, Continue: Continue}; | |
return _elm.Trampoline.values; | |
};Elm.Time = Elm.Time || {}; | |
Elm.Time.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Time = _elm.Time || {}; | |
if (_elm.Time.values) | |
return _elm.Time.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Time"; | |
var Basics = Elm.Basics.make(_elm); | |
var Native = Native || {}; | |
Native.Time = Elm.Native.Time.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var delay = Native.Time.delay; | |
var timestamp = Native.Time.timestamp; | |
var since = Native.Time.since; | |
var every = Native.Time.every; | |
var fpsWhen = Native.Time.fpsWhen; | |
var fps = Native.Time.fps; | |
var inMilliseconds = function (t) | |
{ | |
return t; | |
}; | |
var millisecond = 1; | |
var second = 1000 * millisecond; | |
var minute = 60 * second; | |
var hour = 60 * minute; | |
var inHours = function (t) | |
{ | |
return t / hour; | |
}; | |
var inMinutes = function (t) | |
{ | |
return t / minute; | |
}; | |
var inSeconds = function (t) | |
{ | |
return t / second; | |
}; | |
_elm.Time.values = {_op: _op, millisecond: millisecond, second: second, minute: minute, hour: hour, inMilliseconds: inMilliseconds, inSeconds: inSeconds, inMinutes: inMinutes, inHours: inHours, fps: fps, fpsWhen: fpsWhen, every: every, since: since, timestamp: timestamp, delay: delay}; | |
return _elm.Time.values; | |
};Elm.Maybe = Elm.Maybe || {}; | |
Elm.Maybe.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Maybe = _elm.Maybe || {}; | |
if (_elm.Maybe.values) | |
return _elm.Maybe.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Maybe"; | |
var Basics = Elm.Basics.make(_elm); | |
var List = Elm.List.make(_elm); | |
var _op = {}; | |
var Nothing = {ctor: "Nothing"}; | |
var Just = function (a) | |
{ | |
return {ctor: "Just", _0: a}; | |
}; | |
var maybe = F3(function (b,f,m) | |
{ | |
return function () | |
{ | |
switch (m.ctor) | |
{case | |
"Just" : | |
return f(m._0); | |
case | |
"Nothing" : | |
return b;} | |
_E.Case($moduleName,"between lines 35 and 44"); | |
}(); | |
}); | |
var isJust = A2(maybe, | |
false, | |
function (_v2) | |
{ | |
return function () | |
{ | |
return true; | |
}(); | |
}); | |
var isNothing = function ($) | |
{ | |
return Basics.not(isJust($)); | |
}; | |
var cons = F2(function (mx,xs) | |
{ | |
return A3(maybe, | |
xs, | |
function (x) | |
{ | |
return {ctor: "::", _0: x, _1: xs}; | |
}, | |
mx); | |
}); | |
var justs = A2(List.foldr,cons,_L.fromArray([])); | |
_elm.Maybe.values = {_op: _op, maybe: maybe, isJust: isJust, isNothing: isNothing, cons: cons, justs: justs, Just: Just, Nothing: Nothing}; | |
return _elm.Maybe.values; | |
};Elm.Json = Elm.Json || {}; | |
Elm.Json.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Json = _elm.Json || {}; | |
if (_elm.Json.values) | |
return _elm.Json.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Json"; | |
var Dict = Elm.Dict.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Json = Elm.Native.Json.make(_elm); | |
var _op = {}; | |
var fromString = function (str) | |
{ | |
return Native.Json.fromString(str); | |
}; | |
var toString = F2(function (sep,value) | |
{ | |
return A2(Native.Json.toString,sep,value); | |
}); | |
var Object = function (a) | |
{ | |
return {ctor: "Object", _0: a}; | |
}; | |
var Array = function (a) | |
{ | |
return {ctor: "Array", _0: a}; | |
}; | |
var Null = {ctor: "Null"}; | |
var Boolean = function (a) | |
{ | |
return {ctor: "Boolean", _0: a}; | |
}; | |
var Number = function (a) | |
{ | |
return {ctor: "Number", _0: a}; | |
}; | |
var String = function (a) | |
{ | |
return {ctor: "String", _0: a}; | |
}; | |
_elm.Json.values = {_op: _op, toString: toString, fromString: fromString, String: String, Number: Number, Boolean: Boolean, Null: Null, Array: Array, Object: Object}; | |
return _elm.Json.values; | |
};Elm.Set = Elm.Set || {}; | |
Elm.Set.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Set = _elm.Set || {}; | |
if (_elm.Set.values) | |
return _elm.Set.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Set"; | |
var Dict = Elm.Dict.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var _op = {}; | |
var partition = F2(function (p,set) | |
{ | |
return A2(Dict.partition, | |
F2(function (k,_v0) | |
{ | |
return function () | |
{ | |
return p(k); | |
}(); | |
}), | |
set); | |
}); | |
var filter = F2(function (p,set) | |
{ | |
return A2(Dict.filter, | |
F2(function (k,_v2) | |
{ | |
return function () | |
{ | |
return p(k); | |
}(); | |
}), | |
set); | |
}); | |
var foldr = F3(function (f,b,s) | |
{ | |
return A3(Dict.foldr, | |
F3(function (k,_v4,b) | |
{ | |
return function () | |
{ | |
return A2(f,k,b); | |
}(); | |
}), | |
b, | |
s); | |
}); | |
var foldl = F3(function (f,b,s) | |
{ | |
return A3(Dict.foldl, | |
F3(function (k,_v6,b) | |
{ | |
return function () | |
{ | |
return A2(f,k,b); | |
}(); | |
}), | |
b, | |
s); | |
}); | |
var toList = Dict.keys; | |
var diff = Dict.diff; | |
var intersect = Dict.intersect; | |
var union = Dict.union; | |
var member = Dict.member; | |
var remove = Dict.remove; | |
var insert = function (k) | |
{ | |
return A2(Dict.insert,k,{ctor: "_Tuple0"}); | |
}; | |
var singleton = function (k) | |
{ | |
return A2(Dict.singleton,k,{ctor: "_Tuple0"}); | |
}; | |
var empty = Dict.empty; | |
var fromList = function (xs) | |
{ | |
return A3(List.foldl,insert,empty,xs); | |
}; | |
var map = F2(function (f,s) | |
{ | |
return fromList(A2(List.map,f,toList(s))); | |
}); | |
_elm.Set.values = {_op: _op, empty: empty, singleton: singleton, insert: insert, remove: remove, member: member, foldl: foldl, foldr: foldr, map: map, filter: filter, partition: partition, union: union, intersect: intersect, diff: diff, toList: toList, fromList: fromList}; | |
return _elm.Set.values; | |
};Elm.Either = Elm.Either || {}; | |
Elm.Either.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Either = _elm.Either || {}; | |
if (_elm.Either.values) | |
return _elm.Either.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Either"; | |
var List = Elm.List.make(_elm); | |
var _op = {}; | |
var Right = function (a) | |
{ | |
return {ctor: "Right", _0: a}; | |
}; | |
var isRight = function (e) | |
{ | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Right" : | |
return true;} | |
return false; | |
}(); | |
}; | |
var Left = function (a) | |
{ | |
return {ctor: "Left", _0: a}; | |
}; | |
var either = F3(function (f,g,e) | |
{ | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Left" : | |
return f(e._0); | |
case | |
"Right" : | |
return g(e._0);} | |
_E.Case($moduleName,"on line 37, column 16 to 60"); | |
}(); | |
}); | |
var isLeft = function (e) | |
{ | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Left" : | |
return true;} | |
return false; | |
}(); | |
}; | |
var consLeft = F2(function (e,vs) | |
{ | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Left" : | |
return {ctor: "::", _0: e._0, _1: vs}; | |
case | |
"Right" : | |
return vs;} | |
_E.Case($moduleName,"between lines 78 and 80"); | |
}(); | |
}); | |
var lefts = function (es) | |
{ | |
return A3(List.foldr,consLeft,_L.fromArray([]),es); | |
}; | |
var consRight = F2(function (e,vs) | |
{ | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Left" : | |
return vs; | |
case | |
"Right" : | |
return {ctor: "::", _0: e._0, _1: vs};} | |
_E.Case($moduleName,"between lines 83 and 85"); | |
}(); | |
}); | |
var rights = function (es) | |
{ | |
return A3(List.foldr,consRight,_L.fromArray([]),es); | |
}; | |
var consEither = F2(function (e,_v13) | |
{ | |
return function () | |
{ | |
switch (_v13.ctor) | |
{case | |
"_Tuple2" : | |
return function () | |
{ | |
switch (e.ctor) | |
{case | |
"Left" : | |
return {ctor: "_Tuple2", _0: {ctor: "::", _0: e._0, _1: _v13._0}, _1: _v13._1}; | |
case | |
"Right" : | |
return {ctor: "_Tuple2", _0: _v13._0, _1: {ctor: "::", _0: e._0, _1: _v13._1}};} | |
_E.Case($moduleName, | |
"between lines 88 and 90"); | |
}();} | |
_E.Case($moduleName,"between lines 88 and 90"); | |
}(); | |
}); | |
var partition = function (es) | |
{ | |
return A3(List.foldr, | |
consEither, | |
{ctor: "_Tuple2", _0: _L.fromArray([]), _1: _L.fromArray([])}, | |
es); | |
}; | |
_elm.Either.values = {_op: _op, either: either, isLeft: isLeft, isRight: isRight, lefts: lefts, rights: rights, partition: partition, consLeft: consLeft, consRight: consRight, consEither: consEither, Left: Left, Right: Right}; | |
return _elm.Either.values; | |
};Elm.Basics = Elm.Basics || {}; | |
Elm.Basics.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Basics = _elm.Basics || {}; | |
if (_elm.Basics.values) | |
return _elm.Basics.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Basics"; | |
var Native = Native || {}; | |
Native.Basics = Elm.Native.Basics.make(_elm); | |
var _op = {}; | |
var uncurry = F2(function (f,_v0) | |
{ | |
return function () | |
{ | |
switch (_v0.ctor) | |
{case | |
"_Tuple2" : | |
return A2(f,_v0._0,_v0._1);} | |
_E.Case($moduleName,"on line 381, column 19 to 24"); | |
}(); | |
}); | |
var curry = F3(function (f,a,b) | |
{ | |
return f({ctor: "_Tuple2", _0: a, _1: b}); | |
}); | |
var flip = F3(function (f,b,a) | |
{ | |
return A2(f,a,b); | |
}); | |
var snd = function (_v4) | |
{ | |
return function () | |
{ | |
switch (_v4.ctor) | |
{case | |
"_Tuple2" : | |
return _v4._1;} | |
_E.Case($moduleName,"on line 365, column 13 to 14"); | |
}(); | |
}; | |
var fst = function (_v8) | |
{ | |
return function () | |
{ | |
switch (_v8.ctor) | |
{case | |
"_Tuple2" : | |
return _v8._0;} | |
_E.Case($moduleName,"on line 361, column 13 to 14"); | |
}(); | |
}; | |
var always = F2(function (a,_v12) | |
{ | |
return function () | |
{ | |
return a; | |
}(); | |
}); | |
var id = function (x) | |
{ | |
return x; | |
}; | |
_op["<|"] = F2(function (f,x) | |
{ | |
return f(x); | |
}); | |
_op["|>"] = F2(function (x,f) | |
{ | |
return f(x); | |
}); | |
_op["."] = F3(function (f,g,x) | |
{ | |
return f(g(x)); | |
}); | |
var isInfinite = Native.Basics.isInfinite; | |
var isNaN = Native.Basics.isNaN; | |
var toFloat = Native.Basics.toFloat; | |
var ceiling = Native.Basics.ceiling; | |
var floor = Native.Basics.floor; | |
var truncate = Native.Basics.truncate; | |
var round = Native.Basics.round; | |
var otherwise = true; | |
var not = Native.Basics.not; | |
var xor = Native.Basics.xor; | |
_op["||"] = Native.Basics.or; | |
_op["&&"] = Native.Basics.and; | |
var max = Native.Basics.max; | |
var min = Native.Basics.min; | |
var GT = {ctor: "GT"}; | |
var EQ = {ctor: "EQ"}; | |
var LT = {ctor: "LT"}; | |
var compare = Native.Basics.compare; | |
_op[">="] = Native.Basics.ge; | |
_op["<="] = Native.Basics.le; | |
_op[">"] = Native.Basics.gt; | |
_op["<"] = Native.Basics.lt; | |
_op["/="] = Native.Basics.neq; | |
_op["=="] = Native.Basics.eq; | |
var e = Native.Basics.e; | |
var pi = Native.Basics.pi; | |
var clamp = Native.Basics.clamp; | |
var logBase = Native.Basics.logBase; | |
var abs = Native.Basics.abs; | |
var sqrt = Native.Basics.sqrt; | |
var atan2 = Native.Basics.atan2; | |
var atan = Native.Basics.atan; | |
var asin = Native.Basics.asin; | |
var acos = Native.Basics.acos; | |
var tan = Native.Basics.tan; | |
var sin = Native.Basics.sin; | |
var cos = Native.Basics.cos; | |
_op["^"] = Native.Basics.exp; | |
var mod = Native.Basics.mod; | |
var rem = Native.Basics.rem; | |
var div = Native.Basics.div; | |
_op["/"] = Native.Basics.floatDiv; | |
_op["*"] = Native.Basics.mul; | |
_op["-"] = Native.Basics.sub; | |
_op["+"] = Native.Basics.add; | |
var toPolar = function (_v14) | |
{ | |
return function () | |
{ | |
switch (_v14.ctor) | |
{case | |
"_Tuple2" : | |
return {ctor: "_Tuple2", _0: Native.Basics.sqrt(Math.pow(_v14._0, | |
2) + Math.pow(_v14._1, | |
2)), _1: A2(Native.Basics.atan2, | |
_v14._1, | |
_v14._0)};} | |
_E.Case($moduleName,"on line 79, column 18 to 73"); | |
}(); | |
}; | |
var fromPolar = function (_v18) | |
{ | |
return function () | |
{ | |
switch (_v18.ctor) | |
{case | |
"_Tuple2" : | |
return {ctor: "_Tuple2", _0: _v18._0 * Native.Basics.cos(_v18._1), _1: _v18._0 * Native.Basics.sin(_v18._1)};} | |
_E.Case($moduleName,"on line 73, column 20 to 68"); | |
}(); | |
}; | |
var turns = function (r) | |
{ | |
return 2 * Native.Basics.pi * r; | |
}; | |
var degrees = function (d) | |
{ | |
return d * Native.Basics.pi / 180; | |
}; | |
var radians = function (t) | |
{ | |
return t; | |
}; | |
_elm.Basics.values = {_op: _op, radians: radians, degrees: degrees, turns: turns, fromPolar: fromPolar, toPolar: toPolar, div: div, rem: rem, mod: mod, cos: cos, sin: sin, tan: tan, acos: acos, asin: asin, atan: atan, atan2: atan2, sqrt: sqrt, abs: abs, logBase: logBase, clamp: clamp, pi: pi, e: e, compare: compare, min: min, max: max, xor: xor, not: not, otherwise: otherwise, round: round, truncate: truncate, floor: floor, ceiling: ceiling, toFloat: toFloat, isNaN: isNaN, isInfinite: isInfinite, id: id, always: always, fst: fst, snd: snd, flip: flip, curry: curry, uncurry: uncurry, LT: LT, EQ: EQ, GT: GT}; | |
return _elm.Basics.values; | |
};Elm.Color = Elm.Color || {}; | |
Elm.Color.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Color = _elm.Color || {}; | |
if (_elm.Color.values) | |
return _elm.Color.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Color"; | |
var Basics = Elm.Basics.make(_elm); | |
var _op = {}; | |
var Radial = F5(function (a,b,c,d,e) | |
{ | |
return {ctor: "Radial", _0: a, _1: b, _2: c, _3: d, _4: e}; | |
}); | |
var radial = Radial; | |
var Linear = F3(function (a,b,c) | |
{ | |
return {ctor: "Linear", _0: a, _1: b, _2: c}; | |
}); | |
var linear = Linear; | |
var fmod = F2(function (f,n) | |
{ | |
return function () | |
{ | |
var integer = Basics.floor(f); | |
return Basics.toFloat(A2(Basics.mod, | |
integer, | |
n)) + f - Basics.toFloat(integer); | |
}(); | |
}); | |
var rgbToHsl = F3(function (red,green,blue) | |
{ | |
return function () | |
{ | |
var b = Basics.toFloat(blue) / 255; | |
var g = Basics.toFloat(green) / 255; | |
var r = Basics.toFloat(red) / 255; | |
var cMax = A2(Basics.max,A2(Basics.max,r,g),b); | |
var cMin = A2(Basics.min,A2(Basics.min,r,g),b); | |
var c = cMax - cMin; | |
var lightness = (cMax + cMin) / 2; | |
var saturation = _U.eq(lightness, | |
0) ? 0 : c / (1 - Basics.abs(2 * lightness - 1)); | |
var hue = Basics.degrees(60) * (_U.eq(cMax, | |
r) ? A2(fmod, | |
(g - b) / c, | |
6) : _U.eq(cMax, | |
g) ? (b - r) / c + 2 : _U.eq(cMax, | |
b) ? (r - g) / c + 4 : _E.If($moduleName, | |
"between lines 140 and 142")); | |
return {ctor: "_Tuple3", _0: hue, _1: saturation, _2: lightness}; | |
}(); | |
}); | |
var hslToRgb = F3(function (hue,saturation,lightness) | |
{ | |
return function () | |
{ | |
var hue$ = hue / Basics.degrees(60); | |
var chroma = (1 - Basics.abs(2 * lightness - 1)) * saturation; | |
var x = chroma * (1 - Basics.abs(A2(fmod, | |
hue$, | |
2) - 1)); | |
var $ = _U.cmp(hue$, | |
0) < 0 ? {ctor: "_Tuple3", _0: 0, _1: 0, _2: 0} : _U.cmp(hue$, | |
1) < 0 ? {ctor: "_Tuple3", _0: chroma, _1: x, _2: 0} : _U.cmp(hue$, | |
2) < 0 ? {ctor: "_Tuple3", _0: x, _1: chroma, _2: 0} : _U.cmp(hue$, | |
3) < 0 ? {ctor: "_Tuple3", _0: 0, _1: chroma, _2: x} : _U.cmp(hue$, | |
4) < 0 ? {ctor: "_Tuple3", _0: 0, _1: x, _2: chroma} : _U.cmp(hue$, | |
5) < 0 ? {ctor: "_Tuple3", _0: x, _1: 0, _2: chroma} : _U.cmp(hue$, | |
6) < 0 ? {ctor: "_Tuple3", _0: chroma, _1: 0, _2: x} : {ctor: "_Tuple3", _0: 0, _1: 0, _2: 0}, | |
r = $._0, | |
g = $._1, | |
b = $._2; | |
var m = lightness - chroma / 2; | |
return {ctor: "_Tuple3", _0: r + m, _1: g + m, _2: b + m}; | |
}(); | |
}); | |
var HSLA = F4(function (a,b,c,d) | |
{ | |
return {ctor: "HSLA", _0: a, _1: b, _2: c, _3: d}; | |
}); | |
var hsla = F4(function (hue,saturation,lightness,alpha) | |
{ | |
return A4(HSLA, | |
hue - Basics.toFloat(Basics.floor(hue / (2 * Basics.pi))), | |
saturation, | |
lightness, | |
alpha); | |
}); | |
var hsl = F3(function (hue,saturation,lightness) | |
{ | |
return A4(hsla,hue,saturation,lightness,1); | |
}); | |
var grayscale = function (p) | |
{ | |
return A4(HSLA,0,0,1 - p,1); | |
}; | |
var greyscale = function (p) | |
{ | |
return A4(HSLA,0,0,1 - p,1); | |
}; | |
var RGBA = F4(function (a,b,c,d) | |
{ | |
return {ctor: "RGBA", _0: a, _1: b, _2: c, _3: d}; | |
}); | |
var rgba = RGBA; | |
var rgb = F3(function (r,g,b) | |
{ | |
return A4(RGBA,r,g,b,1); | |
}); | |
var complement = function (color) | |
{ | |
return function () | |
{ | |
switch (color.ctor) | |
{case | |
"HSLA" : | |
return A4(hsla, | |
color._0 + Basics.degrees(180), | |
color._1, | |
color._2, | |
color._3); | |
case | |
"RGBA" : | |
return function () | |
{ | |
var $ = A3(rgbToHsl, | |
color._0, | |
color._1, | |
color._2), | |
h = $._0, | |
s = $._1, | |
l = $._2; | |
return A4(hsla, | |
h + Basics.degrees(180), | |
s, | |
l, | |
color._3); | |
}();} | |
_E.Case($moduleName,"between lines 95 and 101"); | |
}(); | |
}; | |
var toHsl = function (color) | |
{ | |
return function () | |
{ | |
switch (color.ctor) | |
{case | |
"HSLA" : | |
return {_: {}, alpha: color._3, hue: color._0, lightness: color._2, saturation: color._1}; | |
case | |
"RGBA" : | |
return function () | |
{ | |
var $ = A3(rgbToHsl, | |
color._0, | |
color._1, | |
color._2), | |
h = $._0, | |
s = $._1, | |
l = $._2; | |
return {_: {}, alpha: color._3, hue: h, lightness: l, saturation: s}; | |
}();} | |
_E.Case($moduleName,"between lines 104 and 111"); | |
}(); | |
}; | |
var toRgb = function (color) | |
{ | |
return function () | |
{ | |
switch (color.ctor) | |
{case | |
"HSLA" : | |
return function () | |
{ | |
var $ = A3(hslToRgb, | |
color._0, | |
color._1, | |
color._2), | |
r = $._0, | |
g = $._1, | |
b = $._2; | |
return {_: {}, alpha: color._3, blue: Basics.round(255 * b), green: Basics.round(255 * g), red: Basics.round(255 * r)}; | |
}(); | |
case | |
"RGBA" : | |
return {_: {}, alpha: color._3, blue: color._2, green: color._1, red: color._0};} | |
_E.Case($moduleName,"between lines 114 and 122"); | |
}(); | |
}; | |
var lightRed = A4(RGBA,239,41,41,1); | |
var red = A4(RGBA,204,0,0,1); | |
var darkRed = A4(RGBA,164,0,0,1); | |
var lightOrange = A4(RGBA,252,175,62,1); | |
var orange = A4(RGBA,245,121,0,1); | |
var darkOrange = A4(RGBA,206,92,0,1); | |
var lightYellow = A4(RGBA,255,233,79,1); | |
var yellow = A4(RGBA,237,212,0,1); | |
var darkYellow = A4(RGBA,196,160,0,1); | |
var lightGreen = A4(RGBA,138,226,52,1); | |
var green = A4(RGBA,115,210,22,1); | |
var darkGreen = A4(RGBA,78,154,6,1); | |
var lightBlue = A4(RGBA,114,159,207,1); | |
var blue = A4(RGBA,52,101,164,1); | |
var darkBlue = A4(RGBA,32,74,135,1); | |
var lightPurple = A4(RGBA,173,127,168,1); | |
var purple = A4(RGBA,117,80,123,1); | |
var darkPurple = A4(RGBA,92,53,102,1); | |
var lightBrown = A4(RGBA,233,185,110,1); | |
var brown = A4(RGBA,193,125,17,1); | |
var darkBrown = A4(RGBA,143,89,2,1); | |
var black = A4(RGBA,0,0,0,1); | |
var white = A4(RGBA,255,255,255,1); | |
var lightGrey = A4(RGBA,238,238,236,1); | |
var grey = A4(RGBA,211,215,207,1); | |
var darkGrey = A4(RGBA,186,189,182,1); | |
var lightGray = A4(RGBA,238,238,236,1); | |
var gray = A4(RGBA,211,215,207,1); | |
var darkGray = A4(RGBA,186,189,182,1); | |
var lightCharcoal = A4(RGBA,136,138,133,1); | |
var charcoal = A4(RGBA,85,87,83,1); | |
var darkCharcoal = A4(RGBA,46,52,54,1); | |
_elm.Color.values = {_op: _op, rgba: rgba, rgb: rgb, hsla: hsla, hsl: hsl, grayscale: grayscale, greyscale: greyscale, complement: complement, toHsl: toHsl, toRgb: toRgb, fmod: fmod, rgbToHsl: rgbToHsl, hslToRgb: hslToRgb, linear: linear, radial: radial, lightRed: lightRed, red: red, darkRed: darkRed, lightOrange: lightOrange, orange: orange, darkOrange: darkOrange, lightYellow: lightYellow, yellow: yellow, darkYellow: darkYellow, lightGreen: lightGreen, green: green, darkGreen: darkGreen, lightBlue: lightBlue, blue: blue, darkBlue: darkBlue, lightPurple: lightPurple, purple: purple, darkPurple: darkPurple, lightBrown: lightBrown, brown: brown, darkBrown: darkBrown, black: black, white: white, lightGrey: lightGrey, grey: grey, darkGrey: darkGrey, lightGray: lightGray, gray: gray, darkGray: darkGray, lightCharcoal: lightCharcoal, charcoal: charcoal, darkCharcoal: darkCharcoal, RGBA: RGBA, HSLA: HSLA, Linear: Linear, Radial: Radial}; | |
return _elm.Color.values; | |
};Elm.Window = Elm.Window || {}; | |
Elm.Window.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Window = _elm.Window || {}; | |
if (_elm.Window.values) | |
return _elm.Window.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Window"; | |
var Native = Native || {}; | |
Native.Window = Elm.Native.Window.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var height = Native.Window.height; | |
var width = Native.Window.width; | |
var dimensions = Native.Window.dimensions; | |
_elm.Window.values = {_op: _op, dimensions: dimensions, width: width, height: height}; | |
return _elm.Window.values; | |
};Elm.Keyboard = Elm.Keyboard || {}; | |
Elm.Keyboard.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Keyboard = _elm.Keyboard || {}; | |
if (_elm.Keyboard.values) | |
return _elm.Keyboard.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Keyboard"; | |
var Native = Native || {}; | |
Native.Keyboard = Elm.Native.Keyboard.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var lastPressed = Native.Keyboard.lastPressed; | |
var keysDown = Native.Keyboard.keysDown; | |
var isDown = Native.Keyboard.isDown; | |
var shift = isDown(16); | |
var ctrl = isDown(17); | |
var space = isDown(32); | |
var enter = isDown(13); | |
var directions = Native.Keyboard.directions; | |
var arrows = A4(directions,38,40,37,39); | |
var wasd = A4(directions,87,83,65,68); | |
_elm.Keyboard.values = {_op: _op, directions: directions, arrows: arrows, wasd: wasd, isDown: isDown, shift: shift, ctrl: ctrl, space: space, enter: enter, keysDown: keysDown, lastPressed: lastPressed}; | |
return _elm.Keyboard.values; | |
};Elm.Text = Elm.Text || {}; | |
Elm.Text.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Text = _elm.Text || {}; | |
if (_elm.Text.values) | |
return _elm.Text.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Text"; | |
var Basics = Elm.Basics.make(_elm); | |
var Color = Elm.Color.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Element = Elm.Graphics.Element.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Show = Elm.Native.Show.make(_elm); | |
var Native = Native || {}; | |
Native.Text = Elm.Native.Text.make(_elm); | |
var String = Elm.String.make(_elm); | |
var _op = {}; | |
var markdown = Native.Text.markdown; | |
var justified = Native.Text.justified; | |
var centered = Native.Text.centered; | |
var rightAligned = Native.Text.rightAligned; | |
var leftAligned = Native.Text.leftAligned; | |
var line = Native.Text.line; | |
var italic = Native.Text.italic; | |
var bold = Native.Text.bold; | |
var color = Native.Text.color; | |
var height = Native.Text.height; | |
var link = Native.Text.link; | |
var monospace = Native.Text.monospace; | |
var typeface = Native.Text.typeface; | |
var style = Native.Text.style; | |
var toText = Native.Text.toText; | |
var plainText = function (str) | |
{ | |
return leftAligned(toText(str)); | |
}; | |
var asText = function (value) | |
{ | |
return leftAligned(monospace(toText(Native.Show.show(value)))); | |
}; | |
var defaultStyle = {_: {}, bold: false, color: Color.black, height: Maybe.Nothing, italic: false, line: Maybe.Nothing, typeface: _L.fromArray([])}; | |
var Style = F6(function (a,b,c,d,e,f) | |
{ | |
return {_: {}, bold: d, color: c, height: b, italic: e, line: f, typeface: a}; | |
}); | |
var Through = {ctor: "Through"}; | |
var Over = {ctor: "Over"}; | |
var Under = {ctor: "Under"}; | |
var Text = {ctor: "Text"}; | |
_elm.Text.values = {_op: _op, defaultStyle: defaultStyle, toText: toText, style: style, typeface: typeface, monospace: monospace, link: link, height: height, color: color, bold: bold, italic: italic, line: line, leftAligned: leftAligned, rightAligned: rightAligned, centered: centered, justified: justified, plainText: plainText, markdown: markdown, asText: asText, Text: Text, Under: Under, Over: Over, Through: Through, Style: Style}; | |
return _elm.Text.values; | |
};Elm.Touch = Elm.Touch || {}; | |
Elm.Touch.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Touch = _elm.Touch || {}; | |
if (_elm.Touch.values) | |
return _elm.Touch.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Touch"; | |
var Native = Native || {}; | |
Native.Touch = Elm.Native.Touch.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var Time = Elm.Time.make(_elm); | |
var _op = {}; | |
var taps = Native.Touch.taps; | |
var touches = Native.Touch.touches; | |
var Touch = F6(function (a,b,c,d,e,f) | |
{ | |
return {_: {}, id: c, t0: f, x: a, x0: d, y: b, y0: e}; | |
}); | |
_elm.Touch.values = {_op: _op, touches: touches, taps: taps, Touch: Touch}; | |
return _elm.Touch.values; | |
};Elm.Bitwise = Elm.Bitwise || {}; | |
Elm.Bitwise.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Bitwise = _elm.Bitwise || {}; | |
if (_elm.Bitwise.values) | |
return _elm.Bitwise.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Bitwise"; | |
var Native = Native || {}; | |
Native.Bitwise = Elm.Native.Bitwise.make(_elm); | |
var _op = {}; | |
var shiftRightLogical = Native.Bitwise.shiftRightLogical; | |
var shiftRight = Native.Bitwise.shiftRightArithmatic; | |
var shiftLeft = Native.Bitwise.shiftLeft; | |
var complement = Native.Bitwise.complement; | |
var xor = Native.Bitwise.xor; | |
var or = Native.Bitwise.or; | |
var and = Native.Bitwise.and; | |
_elm.Bitwise.values = {_op: _op, and: and, or: or, xor: xor, complement: complement, shiftLeft: shiftLeft, shiftRight: shiftRight, shiftRightLogical: shiftRightLogical}; | |
return _elm.Bitwise.values; | |
};Elm.Array = Elm.Array || {}; | |
Elm.Array.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Array = _elm.Array || {}; | |
if (_elm.Array.values) | |
return _elm.Array.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Array"; | |
var Basics = Elm.Basics.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Array = Elm.Native.Array.make(_elm); | |
var _op = {}; | |
var append = Native.Array.append; | |
var length = Native.Array.length; | |
var slice = Native.Array.slice; | |
var set = Native.Array.set; | |
var getOrElse = F3(function ($default,i,array) | |
{ | |
return _U.cmp(0,i) < 1 && _U.cmp(i, | |
Native.Array.length(array)) < 0 ? A2(Native.Array.get, | |
i, | |
array) : $default; | |
}); | |
var get = F2(function (i,array) | |
{ | |
return _U.cmp(0,i) < 1 && _U.cmp(i, | |
Native.Array.length(array)) < 0 ? Maybe.Just(A2(Native.Array.get, | |
i, | |
array)) : Maybe.Nothing; | |
}); | |
var getOrFail = Native.Array.get; | |
var push = Native.Array.push; | |
var empty = Native.Array.empty; | |
var filter = F2(function (isOkay,arr) | |
{ | |
return function () | |
{ | |
var update = F2(function (x,xs) | |
{ | |
return isOkay(x) ? A2(Native.Array.push, | |
x, | |
xs) : xs; | |
}); | |
return A3(Native.Array.foldl, | |
update, | |
Native.Array.empty, | |
arr); | |
}(); | |
}); | |
var foldr = Native.Array.foldr; | |
var foldl = Native.Array.foldl; | |
var indexedMap = Native.Array.indexedMap; | |
var map = Native.Array.map; | |
var toIndexedList = function (array) | |
{ | |
return A2(List.zip, | |
_L.range(0,Native.Array.length(array) - 1), | |
Native.Array.toList(array)); | |
}; | |
var toList = Native.Array.toList; | |
var fromList = Native.Array.fromList; | |
var initialize = Native.Array.initialize; | |
var repeat = F2(function (n,e) | |
{ | |
return A2(initialize,n,Basics.always(e)); | |
}); | |
var Array = {ctor: "Array"}; | |
_elm.Array.values = {_op: _op, initialize: initialize, repeat: repeat, fromList: fromList, toList: toList, toIndexedList: toIndexedList, map: map, indexedMap: indexedMap, foldl: foldl, foldr: foldr, filter: filter, empty: empty, push: push, getOrFail: getOrFail, get: get, getOrElse: getOrElse, set: set, slice: slice, length: length, append: append, Array: Array}; | |
return _elm.Array.values; | |
};Elm.Char = Elm.Char || {}; | |
Elm.Char.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Char = _elm.Char || {}; | |
if (_elm.Char.values) | |
return _elm.Char.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Char"; | |
var Native = Native || {}; | |
Native.Char = Elm.Native.Char.make(_elm); | |
var _op = {}; | |
var fromCode = Native.Char.fromCode; | |
var toCode = Native.Char.toCode; | |
var toLocaleLower = Native.Char.toLocaleLower; | |
var toLocaleUpper = Native.Char.toLocaleUpper; | |
var toLower = Native.Char.toLower; | |
var toUpper = Native.Char.toUpper; | |
var isHexDigit = Native.Char.isHexDigit; | |
var isOctDigit = Native.Char.isOctDigit; | |
var isDigit = Native.Char.isDigit; | |
var isLower = Native.Char.isLower; | |
var isUpper = Native.Char.isUpper; | |
_elm.Char.values = {_op: _op, isUpper: isUpper, isLower: isLower, isDigit: isDigit, isOctDigit: isOctDigit, isHexDigit: isHexDigit, toUpper: toUpper, toLower: toLower, toLocaleUpper: toLocaleUpper, toLocaleLower: toLocaleLower, toCode: toCode, fromCode: fromCode}; | |
return _elm.Char.values; | |
};Elm.Dict = Elm.Dict || {}; | |
Elm.Dict.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Dict = _elm.Dict || {}; | |
if (_elm.Dict.values) | |
return _elm.Dict.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Dict"; | |
var Basics = Elm.Basics.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Error = Elm.Native.Error.make(_elm); | |
var Native = Native || {}; | |
Native.Utils = Elm.Native.Utils.make(_elm); | |
var _op = {}; | |
var Same = {ctor: "Same"}; | |
var Remove = {ctor: "Remove"}; | |
var Insert = {ctor: "Insert"}; | |
var showFlag = function (f) | |
{ | |
return function () | |
{ | |
switch (f.ctor) | |
{case | |
"Insert" : | |
return "Insert"; | |
case | |
"Remove" : | |
return "Remove"; | |
case | |
"Same" : | |
return "Same";} | |
_E.Case($moduleName,"between lines 179 and 184"); | |
}(); | |
}; | |
var RBEmpty = function (a) | |
{ | |
return {ctor: "RBEmpty", _0: a}; | |
}; | |
var RBNode = F5(function (a,b,c,d,e) | |
{ | |
return {ctor: "RBNode", _0: a, _1: b, _2: c, _3: d, _4: e}; | |
}); | |
var max = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
return Native.Error.raise("(max Empty) is not defined"); | |
case | |
"RBNode" : | |
switch (t._4.ctor) | |
{case | |
"RBEmpty" : | |
return {ctor: "_Tuple2", _0: t._1, _1: t._2};} | |
return max(t._4);} | |
_E.Case($moduleName,"between lines 84 and 101"); | |
}(); | |
}; | |
var LBBlack = {ctor: "LBBlack"}; | |
var LBlack = {ctor: "LBlack"}; | |
var showLColor = function (c) | |
{ | |
return function () | |
{ | |
switch (c.ctor) | |
{case | |
"LBBlack" : | |
return "LBBlack"; | |
case | |
"LBlack" : | |
return "LBlack";} | |
_E.Case($moduleName,"between lines 64 and 66"); | |
}(); | |
}; | |
var empty = RBEmpty(LBlack); | |
var min = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return Native.Error.raise("(min Empty) is not defined");} | |
break; | |
case | |
"RBNode" : | |
switch (t._3.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._3._0.ctor) | |
{case | |
"LBlack" : | |
return {ctor: "_Tuple2", _0: t._1, _1: t._2};} | |
break;} | |
return min(t._3);} | |
_E.Case($moduleName,"between lines 77 and 80"); | |
}(); | |
}; | |
var get = F2(function (k,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return Maybe.Nothing;} | |
break; | |
case | |
"RBNode" : | |
return function () | |
{ | |
var _v25 = A2(Native.Utils.compare,k,t._1); | |
switch (_v25.ctor) | |
{case | |
"EQ" : | |
return Maybe.Just(t._2); | |
case | |
"GT" : | |
return A2(get,k,t._4); | |
case | |
"LT" : | |
return A2(get,k,t._3);} | |
_E.Case($moduleName, | |
"between lines 107 and 120"); | |
}();} | |
_E.Case($moduleName,"between lines 104 and 120"); | |
}(); | |
}); | |
var member = F2(function (k,t) | |
{ | |
return Maybe.isJust(A2(get,k,t)); | |
}); | |
var getOrElse = F3(function (base,k,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return base;} | |
break; | |
case | |
"RBNode" : | |
return function () | |
{ | |
var _v33 = A2(Native.Utils.compare, | |
k, | |
t._1); | |
switch (_v33.ctor) | |
{case | |
"EQ" : | |
return t._2; | |
case | |
"GT" : | |
return A3(getOrElse,base,k,t._4); | |
case | |
"LT" : | |
return A3(getOrElse,base,k,t._3);} | |
_E.Case($moduleName, | |
"between lines 126 and 142"); | |
}();} | |
_E.Case($moduleName,"between lines 123 and 142"); | |
}(); | |
}); | |
var getOrFail = F2(function (k,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return Native.Error.raise("key not found when using \'getOrFail\'");} | |
break; | |
case | |
"RBNode" : | |
return function () | |
{ | |
var _v41 = A2(Native.Utils.compare, | |
k, | |
t._1); | |
switch (_v41.ctor) | |
{case | |
"EQ" : | |
return t._2; | |
case | |
"GT" : | |
return A2(getOrFail,k,t._4); | |
case | |
"LT" : | |
return A2(getOrFail,k,t._3);} | |
_E.Case($moduleName, | |
"between lines 148 and 153"); | |
}();} | |
_E.Case($moduleName,"between lines 145 and 153"); | |
}(); | |
}); | |
var map = F2(function (f,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return RBEmpty(LBlack);} | |
break; | |
case | |
"RBNode" : | |
return A5(RBNode, | |
t._0, | |
t._1, | |
f(t._2), | |
A2(map,f,t._3), | |
A2(map,f,t._4));} | |
_E.Case($moduleName,"between lines 345 and 350"); | |
}(); | |
}); | |
var foldl = F3(function (f,acc,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return acc;} | |
break; | |
case | |
"RBNode" : | |
return A3(foldl, | |
f, | |
A3(f,t._1,t._2,A3(foldl,f,acc,t._3)), | |
t._4);} | |
_E.Case($moduleName,"between lines 353 and 358"); | |
}(); | |
}); | |
var foldr = F3(function (f,acc,t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return acc;} | |
break; | |
case | |
"RBNode" : | |
return A3(foldr, | |
f, | |
A3(f,t._1,t._2,A3(foldr,f,acc,t._4)), | |
t._3);} | |
_E.Case($moduleName,"between lines 361 and 366"); | |
}(); | |
}); | |
var keys = function (t) | |
{ | |
return A3(foldr, | |
F3(function (k,v,acc) | |
{ | |
return {ctor: "::", _0: k, _1: acc}; | |
}), | |
_L.fromArray([]), | |
t); | |
}; | |
var values = function (t) | |
{ | |
return A3(foldr, | |
F3(function (k,v,acc) | |
{ | |
return {ctor: "::", _0: v, _1: acc}; | |
}), | |
_L.fromArray([]), | |
t); | |
}; | |
var toList = function (t) | |
{ | |
return A3(foldr, | |
F3(function (k,v,acc) | |
{ | |
return {ctor: "::", _0: {ctor: "_Tuple2", _0: k, _1: v}, _1: acc}; | |
}), | |
_L.fromArray([]), | |
t); | |
}; | |
var NBlack = {ctor: "NBlack"}; | |
var BBlack = {ctor: "BBlack"}; | |
var isBBlack = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBBlack" : | |
return true;} | |
break; | |
case | |
"RBNode" : | |
switch (t._0.ctor) | |
{case | |
"BBlack" : | |
return true;} | |
break;} | |
return false; | |
}(); | |
}; | |
var Black = {ctor: "Black"}; | |
var blackish = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
return true; | |
case | |
"RBNode" : | |
return _U.eq(t._0,Black) || _U.eq(t._0,BBlack);} | |
_E.Case($moduleName,"between lines 296 and 298"); | |
}(); | |
}; | |
var blacken = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
return RBEmpty(LBlack); | |
case | |
"RBNode" : | |
return A5(RBNode,Black,t._1,t._2,t._3,t._4);} | |
_E.Case($moduleName,"between lines 332 and 334"); | |
}(); | |
}; | |
var Red = {ctor: "Red"}; | |
var showNColor = function (c) | |
{ | |
return function () | |
{ | |
switch (c.ctor) | |
{case | |
"BBlack" : | |
return "BBlack"; | |
case | |
"Black" : | |
return "Black"; | |
case | |
"NBlack" : | |
return "NBlack"; | |
case | |
"Red" : | |
return "Red";} | |
_E.Case($moduleName,"between lines 53 and 57"); | |
}(); | |
}; | |
var reportRemBug = F4(function (msg,c,lgot,rgot) | |
{ | |
return Native.Error.raise(List.concat(_L.fromArray(["Internal red-black tree invariant violated, expected ", | |
msg, | |
"and got", | |
showNColor(c), | |
" ", | |
lgot, | |
" ", | |
rgot, | |
"\nPlease report this bug to https://github.com/elm-lang/Elm/issues"]))); | |
}); | |
var ensureBlackRoot = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return t;} | |
break; | |
case | |
"RBNode" : | |
switch (t._0.ctor) | |
{case | |
"Black" : | |
return t; | |
case | |
"Red" : | |
return A5(RBNode, | |
Black, | |
t._1, | |
t._2, | |
t._3, | |
t._4);} | |
break;} | |
_E.Case($moduleName,"between lines 160 and 166"); | |
}(); | |
}; | |
var moreBlack = function (c) | |
{ | |
return function () | |
{ | |
switch (c.ctor) | |
{case | |
"BBlack" : | |
return Native.Error.raise("Can\'t make a double black node more black!"); | |
case | |
"Black" : | |
return BBlack; | |
case | |
"NBlack" : | |
return Red; | |
case | |
"Red" : | |
return Black;} | |
_E.Case($moduleName,"between lines 222 and 226"); | |
}(); | |
}; | |
var lessBlack = function (c) | |
{ | |
return function () | |
{ | |
switch (c.ctor) | |
{case | |
"BBlack" : | |
return Black; | |
case | |
"Black" : | |
return Red; | |
case | |
"NBlack" : | |
return Native.Error.raise("Can\'t make a negative black node less black!"); | |
case | |
"Red" : | |
return NBlack;} | |
_E.Case($moduleName,"between lines 229 and 233"); | |
}(); | |
}; | |
var lessBlackTree = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBBlack" : | |
return RBEmpty(LBlack);} | |
break; | |
case | |
"RBNode" : | |
return A5(RBNode, | |
lessBlack(t._0), | |
t._1, | |
t._2, | |
t._3, | |
t._4);} | |
_E.Case($moduleName,"between lines 236 and 238"); | |
}(); | |
}; | |
var redden = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
return Native.Error.raise("can\'t make a Leaf red"); | |
case | |
"RBNode" : | |
return A5(RBNode,Red,t._1,t._2,t._3,t._4);} | |
_E.Case($moduleName,"between lines 338 and 342"); | |
}(); | |
}; | |
var balance_node = function (t) | |
{ | |
return function () | |
{ | |
var assemble = function (col) | |
{ | |
return function (xk) | |
{ | |
return function (xv) | |
{ | |
return function (yk) | |
{ | |
return function (yv) | |
{ | |
return function (zk) | |
{ | |
return function (zv) | |
{ | |
return function (a) | |
{ | |
return function (b) | |
{ | |
return function (c) | |
{ | |
return function (d) | |
{ | |
return A5(RBNode, | |
lessBlack(col), | |
yk, | |
yv, | |
A5(RBNode, | |
Black, | |
xk, | |
xv, | |
a, | |
b), | |
A5(RBNode, | |
Black, | |
zk, | |
zv, | |
c, | |
d)); | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
}; | |
return blackish(t) ? function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBNode" : | |
switch (t._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._0.ctor) | |
{case | |
"Red" : | |
switch (t._3._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._3._0.ctor) | |
{case | |
"Red" : | |
return assemble(t._0)(t._3._3._1)(t._3._3._2)(t._3._1)(t._3._2)(t._1)(t._2)(t._3._3._3)(t._3._3._4)(t._3._4)(t._4);} | |
break;} | |
switch (t._3._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._4._0.ctor) | |
{case | |
"Red" : | |
return assemble(t._0)(t._3._1)(t._3._2)(t._3._4._1)(t._3._4._2)(t._1)(t._2)(t._3._3)(t._3._4._3)(t._3._4._4)(t._4);} | |
break;} | |
break;} | |
break;} | |
switch (t._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._0.ctor) | |
{case | |
"Red" : | |
switch (t._4._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._3._0.ctor) | |
{case | |
"Red" : | |
return assemble(t._0)(t._1)(t._2)(t._4._3._1)(t._4._3._2)(t._4._1)(t._4._2)(t._3)(t._4._3._3)(t._4._3._4)(t._4._4);} | |
break;} | |
switch (t._4._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._4._0.ctor) | |
{case | |
"Red" : | |
return assemble(t._0)(t._1)(t._2)(t._4._1)(t._4._2)(t._4._4._1)(t._4._4._2)(t._3)(t._4._3)(t._4._4._3)(t._4._4._4);} | |
break;} | |
break;} | |
break;} | |
switch (t._0.ctor) | |
{case | |
"BBlack" : | |
switch (t._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._0.ctor) | |
{case | |
"NBlack" : | |
switch (t._4._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._3._0.ctor) | |
{case | |
"Black" : | |
return function () | |
{ | |
switch (t._4._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._4._4._0.ctor) | |
{case | |
"Black" : | |
return A5(RBNode, | |
Black, | |
t._4._3._1, | |
t._4._3._2, | |
A5(RBNode, | |
Black, | |
t._1, | |
t._2, | |
t._3, | |
t._4._3._3), | |
A5(balance, | |
Black, | |
t._4._1, | |
t._4._2, | |
t._4._3._4, | |
redden(t._4._4)));} | |
break;} | |
return t; | |
}();} | |
break;} | |
break;} | |
break;} | |
switch (t._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._0.ctor) | |
{case | |
"NBlack" : | |
switch (t._3._4.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._4._0.ctor) | |
{case | |
"Black" : | |
return function () | |
{ | |
switch (t._3._3.ctor) | |
{case | |
"RBNode" : | |
switch (t._3._3._0.ctor) | |
{case | |
"Black" : | |
return A5(RBNode, | |
Black, | |
t._3._4._1, | |
t._3._4._2, | |
A5(balance, | |
Black, | |
t._3._1, | |
t._3._2, | |
redden(t._3._3), | |
t._3._4._3), | |
A5(RBNode, | |
Black, | |
t._1, | |
t._2, | |
t._3._4._4, | |
t._4));} | |
break;} | |
return t; | |
}();} | |
break;} | |
break;} | |
break;} | |
break;} | |
break;} | |
return t; | |
}() : t; | |
}(); | |
}; | |
var balance = F5(function (c,k,v,l,r) | |
{ | |
return balance_node(A5(RBNode,c,k,v,l,r)); | |
}); | |
var bubble = F5(function (c,k,v,l,r) | |
{ | |
return isBBlack(l) || isBBlack(r) ? A5(balance, | |
moreBlack(c), | |
k, | |
v, | |
lessBlackTree(l), | |
lessBlackTree(r)) : A5(RBNode, | |
c, | |
k, | |
v, | |
l, | |
r); | |
}); | |
var remove_max = F5(function (c,k,v,l,r) | |
{ | |
return function () | |
{ | |
switch (r.ctor) | |
{case | |
"RBEmpty" : | |
return A3(rem,c,l,r); | |
case | |
"RBNode" : | |
return A5(bubble, | |
c, | |
k, | |
v, | |
l, | |
A5(remove_max, | |
r._0, | |
r._1, | |
r._2, | |
r._3, | |
r._4));} | |
_E.Case($moduleName,"between lines 284 and 287"); | |
}(); | |
}); | |
var rem = F3(function (c,l,r) | |
{ | |
return function () | |
{ | |
var _v183 = {ctor: "_Tuple2", _0: l, _1: r}; | |
switch (_v183.ctor) | |
{case | |
"_Tuple2" : | |
switch (_v183._0.ctor) | |
{case | |
"RBEmpty" : | |
switch (_v183._1.ctor) | |
{case | |
"RBEmpty" : | |
return function () | |
{ | |
switch (c.ctor) | |
{case | |
"Black" : | |
return RBEmpty(LBBlack); | |
case | |
"Red" : | |
return RBEmpty(LBlack);} | |
_E.Case($moduleName, | |
"between lines 257 and 260"); | |
}(); | |
case | |
"RBNode" : | |
return function () | |
{ | |
var _v205 = {ctor: "_Tuple3", _0: c, _1: _v183._0._0, _2: _v183._1._0}; | |
switch (_v205.ctor) | |
{case | |
"_Tuple3" : | |
switch (_v205._0.ctor) | |
{case | |
"Black" : | |
switch (_v205._1.ctor) | |
{case | |
"LBlack" : | |
switch (_v205._2.ctor) | |
{case | |
"Red" : | |
return A5(RBNode, | |
Black, | |
_v183._1._1, | |
_v183._1._2, | |
_v183._1._3, | |
_v183._1._4);} | |
break;} | |
break;} | |
break;} | |
return A4(reportRemBug, | |
"Black, LBlack, Red", | |
c, | |
showLColor(_v183._0._0), | |
showNColor(_v183._1._0)); | |
}();} | |
break; | |
case | |
"RBNode" : | |
switch (_v183._1.ctor) | |
{case | |
"RBEmpty" : | |
return function () | |
{ | |
var _v209 = {ctor: "_Tuple3", _0: c, _1: _v183._0._0, _2: _v183._1._0}; | |
switch (_v209.ctor) | |
{case | |
"_Tuple3" : | |
switch (_v209._0.ctor) | |
{case | |
"Black" : | |
switch (_v209._1.ctor) | |
{case | |
"Red" : | |
switch (_v209._2.ctor) | |
{case | |
"LBlack" : | |
return A5(RBNode, | |
Black, | |
_v183._0._1, | |
_v183._0._2, | |
_v183._0._3, | |
_v183._0._4);} | |
break;} | |
break;} | |
break;} | |
return A4(reportRemBug, | |
"Black, Red, LBlack", | |
c, | |
showNColor(_v183._0._0), | |
showLColor(_v183._1._0)); | |
}(); | |
case | |
"RBNode" : | |
return function () | |
{ | |
var l$ = A5(remove_max, | |
_v183._0._0, | |
_v183._0._1, | |
_v183._0._2, | |
_v183._0._3, | |
_v183._0._4); | |
var r = A5(RBNode, | |
_v183._1._0, | |
_v183._1._1, | |
_v183._1._2, | |
_v183._1._3, | |
_v183._1._4); | |
var l = A5(RBNode, | |
_v183._0._0, | |
_v183._0._1, | |
_v183._0._2, | |
_v183._0._3, | |
_v183._0._4); | |
var $ = max(l),k = $._0,v = $._1; | |
return A5(bubble,c,k,v,l$,r); | |
}();} | |
break;} | |
break;} | |
_E.Case($moduleName,"between lines 256 and 274"); | |
}(); | |
}); | |
var update = F3(function (k,u,t) | |
{ | |
return function () | |
{ | |
var up = function (t) | |
{ | |
return function () | |
{ | |
switch (t.ctor) | |
{case | |
"RBEmpty" : | |
switch (t._0.ctor) | |
{case | |
"LBlack" : | |
return function () | |
{ | |
var _v220 = u(Maybe.Nothing); | |
switch (_v220.ctor) | |
{case | |
"Just" : | |
return {ctor: "_Tuple2", _0: Insert, _1: A5(RBNode, | |
Red, | |
k, | |
_v220._0, | |
empty, | |
empty)}; | |
case | |
"Nothing" : | |
return {ctor: "_Tuple2", _0: Same, _1: empty};} | |
_E.Case($moduleName, | |
"between lines 188 and 191"); | |
}();} | |
break; | |
case | |
"RBNode" : | |
return function () | |
{ | |
var _v222 = A2(Native.Utils.compare, | |
k, | |
t._1); | |
switch (_v222.ctor) | |
{case | |
"EQ" : | |
return function () | |
{ | |
var _v223 = u(Maybe.Just(t._2)); | |
switch (_v223.ctor) | |
{case | |
"Just" : | |
return {ctor: "_Tuple2", _0: Same, _1: A5(RBNode, | |
t._0, | |
t._1, | |
_v223._0, | |
t._3, | |
t._4)}; | |
case | |
"Nothing" : | |
return {ctor: "_Tuple2", _0: Remove, _1: A3(rem, | |
t._0, | |
t._3, | |
t._4)};} | |
_E.Case($moduleName, | |
"between lines 192 and 195"); | |
}(); | |
case | |
"GT" : | |
return function () | |
{ | |
var $ = up(t._4), | |
fl = $._0, | |
r$ = $._1; | |
return function () | |
{ | |
switch (fl.ctor) | |
{case | |
"Insert" : | |
return {ctor: "_Tuple2", _0: Insert, _1: A5(balance, | |
t._0, | |
t._1, | |
t._2, | |
t._3, | |
r$)}; | |
case | |
"Remove" : | |
return {ctor: "_Tuple2", _0: Remove, _1: A5(bubble, | |
t._0, | |
t._1, | |
t._2, | |
t._3, | |
r$)}; | |
case | |
"Same" : | |
return {ctor: "_Tuple2", _0: Same, _1: A5(RBNode, | |
t._0, | |
t._1, | |
t._2, | |
t._3, | |
r$)};} | |
_E.Case($moduleName, | |
"between lines 201 and 205"); | |
}(); | |
}(); | |
case | |
"LT" : | |
return function () | |
{ | |
var $ = up(t._3), | |
fl = $._0, | |
l$ = $._1; | |
return function () | |
{ | |
switch (fl.ctor) | |
{case | |
"Insert" : | |
return {ctor: "_Tuple2", _0: Insert, _1: A5(balance, | |
t._0, | |
t._1, | |
t._2, | |
l$, | |
t._4)}; | |
case | |
"Remove" : | |
return {ctor: "_Tuple2", _0: Remove, _1: A5(bubble, | |
t._0, | |
t._1, | |
t._2, | |
l$, | |
t._4)}; | |
case | |
"Same" : | |
return {ctor: "_Tuple2", _0: Same, _1: A5(RBNode, | |
t._0, | |
t._1, | |
t._2, | |
l$, | |
t._4)};} | |
_E.Case($moduleName, | |
"between lines 196 and 200"); | |
}(); | |
}();} | |
_E.Case($moduleName, | |
"between lines 191 and 205"); | |
}();} | |
_E.Case($moduleName, | |
"between lines 187 and 205"); | |
}(); | |
}; | |
var $ = up(t),fl = $._0,t$ = $._1; | |
return function () | |
{ | |
switch (fl.ctor) | |
{case | |
"Insert" : | |
return ensureBlackRoot(t$); | |
case | |
"Remove" : | |
return blacken(t$); | |
case | |
"Same" : | |
return t$;} | |
_E.Case($moduleName, | |
"between lines 206 and 211"); | |
}(); | |
}(); | |
}); | |
var insert = F3(function (k,v,t) | |
{ | |
return function () | |
{ | |
var u = function (_v228) | |
{ | |
return function () | |
{ | |
return Maybe.Just(v); | |
}(); | |
}; | |
return A3(update,k,u,t); | |
}(); | |
}); | |
var singleton = F2(function (k,v) | |
{ | |
return A3(insert,k,v,RBEmpty(LBlack)); | |
}); | |
var union = F2(function (t1,t2) | |
{ | |
return A3(foldl,insert,t2,t1); | |
}); | |
var fromList = function (assocs) | |
{ | |
return A3(List.foldl, | |
F2(function (_v230,d) | |
{ | |
return function () | |
{ | |
switch (_v230.ctor) | |
{case | |
"_Tuple2" : | |
return A3(insert, | |
_v230._0, | |
_v230._1, | |
d);} | |
_E.Case($moduleName, | |
"on line 394, column 43 to 55"); | |
}(); | |
}), | |
empty, | |
assocs); | |
}; | |
var filter = F2(function (p,dict) | |
{ | |
return function () | |
{ | |
var add = F3(function (k,v,t) | |
{ | |
return A2(p,k,v) ? A3(insert,k,v,t) : t; | |
}); | |
return A3(foldl,add,empty,dict); | |
}(); | |
}); | |
var intersect = F2(function (t1,t2) | |
{ | |
return A2(filter, | |
F2(function (k,_v234) | |
{ | |
return function () | |
{ | |
return A2(member,k,t2); | |
}(); | |
}), | |
t1); | |
}); | |
var partition = F2(function (p,dict) | |
{ | |
return function () | |
{ | |
var add = F3(function (k,v,_v236) | |
{ | |
return function () | |
{ | |
switch (_v236.ctor) | |
{case | |
"_Tuple2" : | |
return A2(p, | |
k, | |
v) ? {ctor: "_Tuple2", _0: A3(insert, | |
k, | |
v, | |
_v236._0), _1: _v236._1} : {ctor: "_Tuple2", _0: _v236._0, _1: A3(insert, | |
k, | |
v, | |
_v236._1)};} | |
_E.Case($moduleName, | |
"between lines 408 and 410"); | |
}(); | |
}); | |
return A3(foldl, | |
add, | |
{ctor: "_Tuple2", _0: empty, _1: empty}, | |
dict); | |
}(); | |
}); | |
var remove = F2(function (k,t) | |
{ | |
return function () | |
{ | |
var u = function (_v240) | |
{ | |
return function () | |
{ | |
return Maybe.Nothing; | |
}(); | |
}; | |
return A3(update,k,u,t); | |
}(); | |
}); | |
var diff = F2(function (t1,t2) | |
{ | |
return A3(foldl, | |
F3(function (k,v,t) | |
{ | |
return A2(remove,k,t); | |
}), | |
t1, | |
t2); | |
}); | |
_elm.Dict.values = {_op: _op, empty: empty, singleton: singleton, insert: insert, update: update, get: get, getOrElse: getOrElse, getOrFail: getOrFail, remove: remove, member: member, filter: filter, partition: partition, foldl: foldl, foldr: foldr, map: map, union: union, intersect: intersect, diff: diff, keys: keys, values: values, toList: toList, fromList: fromList}; | |
return _elm.Dict.values; | |
};Elm.Transform2D = Elm.Transform2D || {}; | |
Elm.Transform2D.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Transform2D = _elm.Transform2D || {}; | |
if (_elm.Transform2D.values) | |
return _elm.Transform2D.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Transform2D"; | |
var Native = Native || {}; | |
Native.Transform2D = Elm.Native.Transform2D.make(_elm); | |
var _op = {}; | |
var multiply = Native.Transform2D.multiply; | |
var rotation = Native.Transform2D.rotation; | |
var matrix = Native.Transform2D.matrix; | |
var translation = F2(function (x,y) | |
{ | |
return A6(matrix,1,0,0,1,x,y); | |
}); | |
var scale = function (s) | |
{ | |
return A6(matrix,s,0,0,s,0,0); | |
}; | |
var scaleX = function (x) | |
{ | |
return A6(matrix,x,0,0,1,0,0); | |
}; | |
var scaleY = function (y) | |
{ | |
return A6(matrix,1,0,0,y,0,0); | |
}; | |
var identity = Native.Transform2D.identity; | |
var Transform2D = {ctor: "Transform2D"}; | |
_elm.Transform2D.values = {_op: _op, identity: identity, matrix: matrix, rotation: rotation, translation: translation, scale: scale, scaleX: scaleX, scaleY: scaleY, multiply: multiply, Transform2D: Transform2D}; | |
return _elm.Transform2D.values; | |
};Elm.Signal = Elm.Signal || {}; | |
Elm.Signal.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Signal = _elm.Signal || {}; | |
if (_elm.Signal.values) | |
return _elm.Signal.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Signal"; | |
var Basics = Elm.Basics.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Native = Native || {}; | |
Native.Signal = Elm.Native.Signal.make(_elm); | |
var _op = {}; | |
_op["~"] = F2(function (sf,s) | |
{ | |
return A3(Native.Signal.lift2, | |
F2(function (f,x) | |
{ | |
return f(x); | |
}), | |
sf, | |
s); | |
}); | |
_op["<~"] = F2(function (f,s) | |
{ | |
return A2(Native.Signal.lift,f,s); | |
}); | |
var sampleOn = Native.Signal.sampleOn; | |
var dropRepeats = Native.Signal.dropRepeats; | |
var dropIf = Native.Signal.dropIf; | |
var keepIf = Native.Signal.keepIf; | |
var keepWhen = F3(function (bs,def,sig) | |
{ | |
return A2(_op["<~"], | |
Basics.snd, | |
A3(keepIf, | |
Basics.fst, | |
{ctor: "_Tuple2", _0: false, _1: def}, | |
A2(_op["~"], | |
A2(_op["<~"], | |
F2(function (v0,v1) | |
{ | |
return {ctor: "_Tuple2", _0: v0, _1: v1}; | |
}), | |
A2(sampleOn,sig,bs)), | |
sig))); | |
}); | |
var dropWhen = function (bs) | |
{ | |
return keepWhen(A2(_op["<~"],Basics.not,bs)); | |
}; | |
var countIf = Native.Signal.countIf; | |
var count = Native.Signal.count; | |
var combine = A2(List.foldr, | |
Native.Signal.lift2(F2(function (x,y) | |
{ | |
return {ctor: "::", _0: x, _1: y}; | |
})), | |
Native.Signal.constant(_L.fromArray([]))); | |
var merges = Native.Signal.merges; | |
var merge = Native.Signal.merge; | |
var foldp = Native.Signal.foldp; | |
var lift8 = Native.Signal.lift8; | |
var lift7 = Native.Signal.lift7; | |
var lift6 = Native.Signal.lift6; | |
var lift5 = Native.Signal.lift5; | |
var lift4 = Native.Signal.lift4; | |
var lift3 = Native.Signal.lift3; | |
var lift2 = Native.Signal.lift2; | |
var lift = Native.Signal.lift; | |
var constant = Native.Signal.constant; | |
var Signal = {ctor: "Signal"}; | |
_elm.Signal.values = {_op: _op, constant: constant, lift: lift, lift2: lift2, lift3: lift3, lift4: lift4, lift5: lift5, lift6: lift6, lift7: lift7, lift8: lift8, foldp: foldp, merge: merge, merges: merges, combine: combine, count: count, countIf: countIf, keepIf: keepIf, dropIf: dropIf, keepWhen: keepWhen, dropWhen: dropWhen, dropRepeats: dropRepeats, sampleOn: sampleOn, Signal: Signal}; | |
return _elm.Signal.values; | |
};Elm.String = Elm.String || {}; | |
Elm.String.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.String = _elm.String || {}; | |
if (_elm.String.values) | |
return _elm.String.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "String"; | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Show = Elm.Native.Show.make(_elm); | |
var Native = Native || {}; | |
Native.String = Elm.Native.String.make(_elm); | |
var _op = {}; | |
var fromList = Native.String.fromList; | |
var toList = Native.String.toList; | |
var toFloat = Native.String.toFloat; | |
var toInt = Native.String.toInt; | |
var show = Native.Show.show; | |
var indices = Native.String.indexes; | |
var indexes = Native.String.indexes; | |
var endsWith = Native.String.endsWith; | |
var startsWith = Native.String.startsWith; | |
var contains = Native.String.contains; | |
var all = Native.String.all; | |
var any = Native.String.any; | |
var toLower = Native.String.toLower; | |
var toUpper = Native.String.toUpper; | |
var lines = Native.String.lines; | |
var words = Native.String.words; | |
var trimRight = Native.String.trimRight; | |
var trimLeft = Native.String.trimLeft; | |
var trim = Native.String.trim; | |
var padRight = Native.String.padRight; | |
var padLeft = Native.String.padLeft; | |
var pad = Native.String.pad; | |
var dropRight = Native.String.dropRight; | |
var dropLeft = Native.String.dropLeft; | |
var right = Native.String.right; | |
var left = Native.String.left; | |
var slice = Native.String.slice; | |
var repeat = Native.String.repeat; | |
var join = Native.String.join; | |
var split = Native.String.split; | |
var foldr = Native.String.foldr; | |
var foldl = Native.String.foldl; | |
var reverse = Native.String.reverse; | |
var filter = Native.String.filter; | |
var map = Native.String.map; | |
var length = Native.String.length; | |
var concat = Native.String.concat; | |
var append = Native.String.append; | |
var uncons = Native.String.uncons; | |
var cons = Native.String.cons; | |
var isEmpty = Native.String.isEmpty; | |
_elm.String.values = {_op: _op, isEmpty: isEmpty, cons: cons, uncons: uncons, append: append, concat: concat, length: length, map: map, filter: filter, reverse: reverse, foldl: foldl, foldr: foldr, split: split, join: join, repeat: repeat, slice: slice, left: left, right: right, dropLeft: dropLeft, dropRight: dropRight, pad: pad, padLeft: padLeft, padRight: padRight, trim: trim, trimLeft: trimLeft, trimRight: trimRight, words: words, lines: lines, toUpper: toUpper, toLower: toLower, any: any, all: all, contains: contains, startsWith: startsWith, endsWith: endsWith, indexes: indexes, indices: indices, show: show, toInt: toInt, toFloat: toFloat, toList: toList, fromList: fromList}; | |
return _elm.String.values; | |
};Elm.Regex = Elm.Regex || {}; | |
Elm.Regex.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Regex = _elm.Regex || {}; | |
if (_elm.Regex.values) | |
return _elm.Regex.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Regex"; | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Regex = Elm.Native.Regex.make(_elm); | |
var _op = {}; | |
var split = Native.Regex.split; | |
var replace = Native.Regex.replace; | |
var find = Native.Regex.find; | |
var AtMost = function (a) | |
{ | |
return {ctor: "AtMost", _0: a}; | |
}; | |
var All = {ctor: "All"}; | |
var Match = F4(function (a,b,c,d) | |
{ | |
return {_: {}, index: c, match: a, number: d, submatches: b}; | |
}); | |
var contains = Native.Regex.contains; | |
var caseInsensitive = Native.Regex.caseInsensitive; | |
var regex = Native.Regex.regex; | |
var escape = Native.Regex.escape; | |
var Regex = {ctor: "Regex"}; | |
_elm.Regex.values = {_op: _op, escape: escape, regex: regex, caseInsensitive: caseInsensitive, contains: contains, find: find, replace: replace, split: split, Regex: Regex, All: All, AtMost: AtMost, Match: Match}; | |
return _elm.Regex.values; | |
};Elm.WebSocket = Elm.WebSocket || {}; | |
Elm.WebSocket.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.WebSocket = _elm.WebSocket || {}; | |
if (_elm.WebSocket.values) | |
return _elm.WebSocket.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "WebSocket"; | |
var Basics = Elm.Basics.make(_elm); | |
var Native = Native || {}; | |
Native.WebSocket = Elm.Native.WebSocket.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var connect = Native.WebSocket.connect; | |
_elm.WebSocket.values = {_op: _op, connect: connect}; | |
return _elm.WebSocket.values; | |
};Elm.Debug = Elm.Debug || {}; | |
Elm.Debug.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Debug = _elm.Debug || {}; | |
if (_elm.Debug.values) | |
return _elm.Debug.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Debug"; | |
var Native = Native || {}; | |
Native.Debug = Elm.Native.Debug.make(_elm); | |
var _op = {}; | |
var log = Native.Debug.log; | |
_elm.Debug.values = {_op: _op, log: log}; | |
return _elm.Debug.values; | |
};Elm.Mouse = Elm.Mouse || {}; | |
Elm.Mouse.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Mouse = _elm.Mouse || {}; | |
if (_elm.Mouse.values) | |
return _elm.Mouse.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Mouse"; | |
var Native = Native || {}; | |
Native.Mouse = Elm.Native.Mouse.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var clicks = Native.Mouse.clicks; | |
var isDown = Native.Mouse.isDown; | |
var y = Native.Mouse.y; | |
var x = Native.Mouse.x; | |
var position = Native.Mouse.position; | |
_elm.Mouse.values = {_op: _op, position: position, x: x, y: y, isDown: isDown, clicks: clicks}; | |
return _elm.Mouse.values; | |
};Elm.Http = Elm.Http || {}; | |
Elm.Http.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Http = _elm.Http || {}; | |
if (_elm.Http.values) | |
return _elm.Http.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Http"; | |
var Native = Native || {}; | |
Native.Http = Elm.Native.Http.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var send = Native.Http.send; | |
var Request = F4(function (a,b,c,d) | |
{ | |
return {_: {}, body: c, headers: d, url: b, verb: a}; | |
}); | |
var request = Request; | |
var get = function (url) | |
{ | |
return A4(Request,"GET",url,"",_L.fromArray([])); | |
}; | |
var sendGet = function (reqs) | |
{ | |
return send(A2(Signal.lift,get,reqs)); | |
}; | |
var post = F2(function (url,body) | |
{ | |
return A4(Request,"POST",url,body,_L.fromArray([])); | |
}); | |
var Failure = F2(function (a,b) | |
{ | |
return {ctor: "Failure", _0: a, _1: b}; | |
}); | |
var Waiting = {ctor: "Waiting"}; | |
var Success = function (a) | |
{ | |
return {ctor: "Success", _0: a}; | |
}; | |
_elm.Http.values = {_op: _op, request: request, get: get, post: post, send: send, sendGet: sendGet, Success: Success, Waiting: Waiting, Failure: Failure, Request: Request}; | |
return _elm.Http.values; | |
};Elm.Random = Elm.Random || {}; | |
Elm.Random.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Random = _elm.Random || {}; | |
if (_elm.Random.values) | |
return _elm.Random.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Random"; | |
var Native = Native || {}; | |
Native.Random = Elm.Native.Random.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var floatList = Native.Random.floatList; | |
var $float = Native.Random.float_; | |
var range = Native.Random.range; | |
_elm.Random.values = {_op: _op, range: range, $float: $float, floatList: floatList}; | |
return _elm.Random.values; | |
};Elm.Date = Elm.Date || {}; | |
Elm.Date.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Date = _elm.Date || {}; | |
if (_elm.Date.values) | |
return _elm.Date.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Date"; | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Date = Elm.Native.Date.make(_elm); | |
var Time = Elm.Time.make(_elm); | |
var _op = {}; | |
var second = Native.Date.second; | |
var minute = Native.Date.minute; | |
var hour = Native.Date.hour; | |
var dayOfWeek = Native.Date.dayOfWeek; | |
var day = Native.Date.day; | |
var month = Native.Date.month; | |
var year = Native.Date.year; | |
var fromTime = Native.Date.fromTime; | |
var toTime = Native.Date.toTime; | |
var read = Native.Date.read; | |
var Dec = {ctor: "Dec"}; | |
var Nov = {ctor: "Nov"}; | |
var Oct = {ctor: "Oct"}; | |
var Sep = {ctor: "Sep"}; | |
var Aug = {ctor: "Aug"}; | |
var Jul = {ctor: "Jul"}; | |
var Jun = {ctor: "Jun"}; | |
var May = {ctor: "May"}; | |
var Apr = {ctor: "Apr"}; | |
var Mar = {ctor: "Mar"}; | |
var Feb = {ctor: "Feb"}; | |
var Jan = {ctor: "Jan"}; | |
var Sun = {ctor: "Sun"}; | |
var Sat = {ctor: "Sat"}; | |
var Fri = {ctor: "Fri"}; | |
var Thu = {ctor: "Thu"}; | |
var Wed = {ctor: "Wed"}; | |
var Tue = {ctor: "Tue"}; | |
var Mon = {ctor: "Mon"}; | |
var Date = {ctor: "Date"}; | |
_elm.Date.values = {_op: _op, read: read, toTime: toTime, fromTime: fromTime, year: year, month: month, day: day, dayOfWeek: dayOfWeek, hour: hour, minute: minute, second: second, Date: Date, Mon: Mon, Tue: Tue, Wed: Wed, Thu: Thu, Fri: Fri, Sat: Sat, Sun: Sun, Jan: Jan, Feb: Feb, Mar: Mar, Apr: Apr, May: May, Jun: Jun, Jul: Jul, Aug: Aug, Sep: Sep, Oct: Oct, Nov: Nov, Dec: Dec}; | |
return _elm.Date.values; | |
};Elm.List = Elm.List || {}; | |
Elm.List.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.List = _elm.List || {}; | |
if (_elm.List.values) | |
return _elm.List.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "List"; | |
var Basics = Elm.Basics.make(_elm); | |
var Native = Native || {}; | |
Native.List = Elm.Native.List.make(_elm); | |
var _op = {}; | |
var sortWith = Native.List.sortWith; | |
var sortBy = Native.List.sortBy; | |
var sort = Native.List.sort; | |
var repeat = Native.List.repeat; | |
var drop = Native.List.drop; | |
var take = Native.List.take; | |
var join = Native.List.join; | |
var zipWith5 = Native.List.zipWith5; | |
var zipWith4 = Native.List.zipWith4; | |
var zipWith3 = Native.List.zipWith3; | |
var zipWith = Native.List.zipWith; | |
var zip5 = Native.List.zipWith5(F5(function (v0,v1,v2,v3,v4) | |
{ | |
return {ctor: "_Tuple5", _0: v0, _1: v1, _2: v2, _3: v3, _4: v4}; | |
})); | |
var zip4 = Native.List.zipWith4(F4(function (v0,v1,v2,v3) | |
{ | |
return {ctor: "_Tuple4", _0: v0, _1: v1, _2: v2, _3: v3}; | |
})); | |
var zip3 = Native.List.zipWith3(F3(function (v0,v1,v2) | |
{ | |
return {ctor: "_Tuple3", _0: v0, _1: v1, _2: v2}; | |
})); | |
var zip = Native.List.zip; | |
var concat = Native.List.concat; | |
var any = Native.List.any; | |
var all = Native.List.all; | |
var reverse = Native.List.reverse; | |
var length = Native.List.length; | |
var filter = Native.List.filter; | |
var scanl1 = Native.List.scanl1; | |
var scanl = Native.List.scanl; | |
var foldr1 = Native.List.foldr1; | |
var foldl1 = Native.List.foldl1; | |
var maximum = foldl1(Basics.max); | |
var minimum = foldl1(Basics.min); | |
var foldr = Native.List.foldr; | |
var foldl = Native.List.foldl; | |
var and = A2(foldl, | |
F2(function (x,y) | |
{ | |
return x && y; | |
}), | |
true); | |
var or = A2(foldl, | |
F2(function (x,y) | |
{ | |
return x || y; | |
}), | |
false); | |
var sum = A2(foldl, | |
F2(function (x,y) | |
{ | |
return x + y; | |
}), | |
0); | |
var product = A2(foldl, | |
F2(function (x,y) | |
{ | |
return x * y; | |
}), | |
1); | |
var map = Native.List.map; | |
var concatMap = F2(function (f,list) | |
{ | |
return concat(A2(map,f,list)); | |
}); | |
var isEmpty = function (xs) | |
{ | |
return function () | |
{ | |
switch (xs.ctor) | |
{case | |
"[]" : | |
return true;} | |
return false; | |
}(); | |
}; | |
var last = Native.List.last; | |
var tail = Native.List.tail; | |
var head = Native.List.head; | |
_op["++"] = Native.List.append; | |
_op["::"] = Native.List.cons; | |
var partition = function (pred) | |
{ | |
return function () | |
{ | |
var step = F2(function (x,_v1) | |
{ | |
return function () | |
{ | |
switch (_v1.ctor) | |
{case | |
"_Tuple2" : | |
return pred(x) ? {ctor: "_Tuple2", _0: {ctor: "::", _0: x, _1: _v1._0}, _1: _v1._1} : {ctor: "_Tuple2", _0: _v1._0, _1: {ctor: "::", _0: x, _1: _v1._1}};} | |
_E.Case($moduleName, | |
"between lines 184 and 186"); | |
}(); | |
}); | |
return A2(foldr, | |
step, | |
{ctor: "_Tuple2", _0: _L.fromArray([]), _1: _L.fromArray([])}); | |
}(); | |
}; | |
var unzip = function () | |
{ | |
var step = F2(function (_v5,_v6) | |
{ | |
return function () | |
{ | |
switch (_v6.ctor) | |
{case | |
"_Tuple2" : | |
return function () | |
{ | |
switch (_v5.ctor) | |
{case | |
"_Tuple2" : | |
return {ctor: "_Tuple2", _0: {ctor: "::", _0: _v5._0, _1: _v6._0}, _1: {ctor: "::", _0: _v5._1, _1: _v6._1}};} | |
_E.Case($moduleName, | |
"on line 230, column 32 to 44"); | |
}();} | |
_E.Case($moduleName, | |
"on line 230, column 32 to 44"); | |
}(); | |
}); | |
return A2(foldr, | |
step, | |
{ctor: "_Tuple2", _0: _L.fromArray([]), _1: _L.fromArray([])}); | |
}(); | |
var intersperse = F2(function (sep,xs) | |
{ | |
return function () | |
{ | |
switch (xs.ctor) | |
{case | |
"::" : | |
return function () | |
{ | |
var step = F2(function (x,rest) | |
{ | |
return {ctor: "::", _0: sep, _1: {ctor: "::", _0: x, _1: rest}}; | |
}); | |
var spersed = A3(foldr, | |
step, | |
_L.fromArray([]), | |
xs._1); | |
return {ctor: "::", _0: xs._0, _1: spersed}; | |
}(); | |
case | |
"[]" : | |
return _L.fromArray([]);} | |
_E.Case($moduleName,"between lines 247 and 254"); | |
}(); | |
}); | |
_elm.List.values = {_op: _op, head: head, tail: tail, last: last, isEmpty: isEmpty, map: map, foldl: foldl, foldr: foldr, foldl1: foldl1, foldr1: foldr1, scanl: scanl, scanl1: scanl1, filter: filter, length: length, reverse: reverse, all: all, any: any, and: and, or: or, concat: concat, concatMap: concatMap, sum: sum, product: product, maximum: maximum, minimum: minimum, partition: partition, zip: zip, zip3: zip3, zip4: zip4, zip5: zip5, zipWith: zipWith, zipWith3: zipWith3, zipWith4: zipWith4, zipWith5: zipWith5, unzip: unzip, join: join, intersperse: intersperse, take: take, drop: drop, repeat: repeat, sort: sort, sortBy: sortBy, sortWith: sortWith}; | |
return _elm.List.values; | |
};Elm.JavaScript = Elm.JavaScript || {}; | |
Elm.JavaScript.Experimental = Elm.JavaScript.Experimental || {}; | |
Elm.JavaScript.Experimental.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.JavaScript = _elm.JavaScript || {}; | |
_elm.JavaScript.Experimental = _elm.JavaScript.Experimental || {}; | |
if (_elm.JavaScript.Experimental.values) | |
return _elm.JavaScript.Experimental.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "JavaScript.Experimental"; | |
var Json = Elm.Json.make(_elm); | |
var Native = Native || {}; | |
Native.JavaScript = Elm.Native.JavaScript.make(_elm); | |
var Native = Native || {}; | |
Native.Json = Elm.Native.Json.make(_elm); | |
var _op = {}; | |
var fromJson = Native.Json.toJS; | |
var toJson = Native.Json.fromJS; | |
var fromRecord = Native.JavaScript.fromRecord; | |
var toRecord = Native.JavaScript.toRecord; | |
var RawObject = {ctor: "RawObject"}; | |
_elm.JavaScript.Experimental.values = {_op: _op, toRecord: toRecord, fromRecord: fromRecord, toJson: toJson, fromJson: fromJson, RawObject: RawObject}; | |
return _elm.JavaScript.Experimental.values; | |
};Elm.Graphics = Elm.Graphics || {}; | |
Elm.Graphics.Input = Elm.Graphics.Input || {}; | |
Elm.Graphics.Input.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Graphics = _elm.Graphics || {}; | |
_elm.Graphics.Input = _elm.Graphics.Input || {}; | |
if (_elm.Graphics.Input.values) | |
return _elm.Graphics.Input.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Graphics.Input"; | |
var Graphics = Graphics || {}; | |
Graphics.Element = Elm.Graphics.Element.make(_elm); | |
var Native = Native || {}; | |
Native.Graphics = Native.Graphics || {}; | |
Native.Graphics.Input = Elm.Native.Graphics.Input.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var _op = {}; | |
var clickable = Native.Graphics.Input.clickable; | |
var hoverable = Native.Graphics.Input.hoverable; | |
var dropDown = Native.Graphics.Input.dropDown; | |
var checkbox = Native.Graphics.Input.checkbox; | |
var customButton = Native.Graphics.Input.customButton; | |
var button = Native.Graphics.Input.button; | |
var input = Native.Graphics.Input.input; | |
var Handle = {ctor: "Handle"}; | |
var Input = F2(function (a,b) | |
{ | |
return {_: {}, handle: b, signal: a}; | |
}); | |
_elm.Graphics.Input.values = {_op: _op, input: input, button: button, customButton: customButton, checkbox: checkbox, dropDown: dropDown, hoverable: hoverable, clickable: clickable, Handle: Handle, Input: Input}; | |
return _elm.Graphics.Input.values; | |
};Elm.Graphics = Elm.Graphics || {}; | |
Elm.Graphics.Element = Elm.Graphics.Element || {}; | |
Elm.Graphics.Element.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Graphics = _elm.Graphics || {}; | |
_elm.Graphics.Element = _elm.Graphics.Element || {}; | |
if (_elm.Graphics.Element.values) | |
return _elm.Graphics.Element.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Graphics.Element"; | |
var Basics = Elm.Basics.make(_elm); | |
var Color = Elm.Color.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Utils = Elm.Native.Utils.make(_elm); | |
var _op = {}; | |
var DOut = {ctor: "DOut"}; | |
var outward = DOut; | |
var DIn = {ctor: "DIn"}; | |
var inward = DIn; | |
var DRight = {ctor: "DRight"}; | |
var right = DRight; | |
var DLeft = {ctor: "DLeft"}; | |
var left = DLeft; | |
var DDown = {ctor: "DDown"}; | |
var down = DDown; | |
var DUp = {ctor: "DUp"}; | |
var up = DUp; | |
var Position = F4(function (a,b,c,d) | |
{ | |
return {_: {}, horizontal: a, vertical: b, x: c, y: d}; | |
}); | |
var Relative = function (a) | |
{ | |
return {ctor: "Relative", _0: a}; | |
}; | |
var relative = Relative; | |
var Absolute = function (a) | |
{ | |
return {ctor: "Absolute", _0: a}; | |
}; | |
var absolute = Absolute; | |
var N = {ctor: "N"}; | |
var bottomLeftAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: N, vertical: N, x: x, y: y}; | |
}); | |
var Z = {ctor: "Z"}; | |
var middle = {_: {}, horizontal: Z, vertical: Z, x: Relative(0.5), y: Relative(0.5)}; | |
var midLeft = _U.replace([["horizontal",N],["x",Absolute(0)]], | |
middle); | |
var middleAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: Z, vertical: Z, x: x, y: y}; | |
}); | |
var midLeftAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: N, vertical: Z, x: x, y: y}; | |
}); | |
var midBottomAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: Z, vertical: N, x: x, y: y}; | |
}); | |
var P = {ctor: "P"}; | |
var topLeft = {_: {}, horizontal: N, vertical: P, x: Absolute(0), y: Absolute(0)}; | |
var bottomLeft = _U.replace([["vertical",N]],topLeft); | |
var topRight = _U.replace([["horizontal",P]],topLeft); | |
var bottomRight = _U.replace([["horizontal",P]],bottomLeft); | |
var midRight = _U.replace([["horizontal",P]],midLeft); | |
var midTop = _U.replace([["vertical",P],["y",Absolute(0)]],middle); | |
var midBottom = _U.replace([["vertical",N]],midTop); | |
var topLeftAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: N, vertical: P, x: x, y: y}; | |
}); | |
var topRightAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: P, vertical: P, x: x, y: y}; | |
}); | |
var bottomRightAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: P, vertical: N, x: x, y: y}; | |
}); | |
var midRightAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: P, vertical: Z, x: x, y: y}; | |
}); | |
var midTopAt = F2(function (x,y) | |
{ | |
return {_: {}, horizontal: Z, vertical: P, x: x, y: y}; | |
}); | |
var Tiled = {ctor: "Tiled"}; | |
var Cropped = function (a) | |
{ | |
return {ctor: "Cropped", _0: a}; | |
}; | |
var Fitted = {ctor: "Fitted"}; | |
var Plain = {ctor: "Plain"}; | |
var Custom = {ctor: "Custom"}; | |
var RawHtml = {ctor: "RawHtml"}; | |
var Spacer = {ctor: "Spacer"}; | |
var Flow = F2(function (a,b) | |
{ | |
return {ctor: "Flow", _0: a, _1: b}; | |
}); | |
var Container = F2(function (a,b) | |
{ | |
return {ctor: "Container", _0: a, _1: b}; | |
}); | |
var Image = F4(function (a,b,c,d) | |
{ | |
return {ctor: "Image", _0: a, _1: b, _2: c, _3: d}; | |
}); | |
var link = F2(function (href,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
return {_: {}, element: e.element, props: _U.replace([["href", | |
href]], | |
p)}; | |
}(); | |
}); | |
var tag = F2(function (name,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
return {_: {}, element: e.element, props: _U.replace([["tag", | |
name]], | |
p)}; | |
}(); | |
}); | |
var color = F2(function (c,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
return {_: {}, element: e.element, props: _U.replace([["color", | |
Maybe.Just(c)]], | |
p)}; | |
}(); | |
}); | |
var opacity = F2(function (o,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
return {_: {}, element: e.element, props: _U.replace([["opacity", | |
o]], | |
p)}; | |
}(); | |
}); | |
var height = F2(function (nh,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
var props = function () | |
{ | |
var _v0 = e.element; | |
switch (_v0.ctor) | |
{case | |
"Image" : | |
return _U.replace([["width", | |
Basics.round(Basics.toFloat(_v0._1) / Basics.toFloat(_v0._2) * Basics.toFloat(nh))]], | |
p);} | |
return p; | |
}(); | |
return {_: {}, element: e.element, props: _U.replace([["height", | |
nh]], | |
p)}; | |
}(); | |
}); | |
var width = F2(function (nw,e) | |
{ | |
return function () | |
{ | |
var p = e.props; | |
var props = function () | |
{ | |
var _v5 = e.element; | |
switch (_v5.ctor) | |
{case | |
"Image" : | |
return _U.replace([["height", | |
Basics.round(Basics.toFloat(_v5._2) / Basics.toFloat(_v5._1) * Basics.toFloat(nw))]], | |
p); | |
case | |
"RawHtml" : | |
return _U.replace([["height", | |
Basics.snd(A2(Native.Utils.htmlHeight, | |
nw, | |
e.element))]], | |
p);} | |
return p; | |
}(); | |
return {_: {}, element: e.element, props: _U.replace([["width", | |
nw]], | |
props)}; | |
}(); | |
}); | |
var size = F3(function (w,h,e) | |
{ | |
return A2(height,h,A2(width,w,e)); | |
}); | |
var sizeOf = function (e) | |
{ | |
return {ctor: "_Tuple2", _0: e.props.width, _1: e.props.height}; | |
}; | |
var heightOf = function (e) | |
{ | |
return e.props.height; | |
}; | |
var widthOf = function (e) | |
{ | |
return e.props.width; | |
}; | |
var Element = F2(function (a,b) | |
{ | |
return {_: {}, element: b, props: a}; | |
}); | |
var Properties = F9(function (a,b,c,d,e,f,g,h,i) | |
{ | |
return {_: {}, click: i, color: e, height: c, hover: h, href: f, id: a, opacity: d, tag: g, width: b}; | |
}); | |
var newElement = F3(function (w,h,e) | |
{ | |
return {_: {}, element: e, props: A9(Properties, | |
Native.Utils.guid({ctor: "_Tuple0"}), | |
w, | |
h, | |
1, | |
Maybe.Nothing, | |
"", | |
"", | |
{ctor: "_Tuple0"}, | |
{ctor: "_Tuple0"})}; | |
}); | |
var image = F3(function (w,h,src) | |
{ | |
return A3(newElement,w,h,A4(Image,Plain,w,h,src)); | |
}); | |
var fittedImage = F3(function (w,h,src) | |
{ | |
return A3(newElement, | |
w, | |
h, | |
A4(Image,Fitted,w,h,src)); | |
}); | |
var croppedImage = F4(function (pos,w,h,src) | |
{ | |
return A3(newElement, | |
w, | |
h, | |
A4(Image,Cropped(pos),w,h,src)); | |
}); | |
var tiledImage = F3(function (w,h,src) | |
{ | |
return A3(newElement, | |
w, | |
h, | |
A4(Image,Tiled,w,h,src)); | |
}); | |
var container = F4(function (w,h,pos,e) | |
{ | |
return A3(newElement,w,h,A2(Container,pos,e)); | |
}); | |
var spacer = F2(function (w,h) | |
{ | |
return A3(newElement,w,h,Spacer); | |
}); | |
var empty = A2(spacer,0,0); | |
var flow = F2(function (dir,es) | |
{ | |
return function () | |
{ | |
var newFlow = F2(function (w,h) | |
{ | |
return A3(newElement, | |
w, | |
h, | |
A2(Flow, | |
dir, | |
es)); | |
}); | |
var hs = A2(List.map,heightOf,es); | |
var ws = A2(List.map,widthOf,es); | |
return _U.eq(es, | |
_L.fromArray([])) ? empty : function () | |
{ | |
switch (dir.ctor) | |
{case | |
"DDown" : | |
return A2(newFlow, | |
List.maximum(ws), | |
List.sum(hs)); | |
case | |
"DIn" : | |
return A2(newFlow, | |
List.maximum(ws), | |
List.maximum(hs)); | |
case | |
"DLeft" : | |
return A2(newFlow, | |
List.sum(ws), | |
List.maximum(hs)); | |
case | |
"DOut" : | |
return A2(newFlow, | |
List.maximum(ws), | |
List.maximum(hs)); | |
case | |
"DRight" : | |
return A2(newFlow, | |
List.sum(ws), | |
List.maximum(hs)); | |
case | |
"DUp" : | |
return A2(newFlow, | |
List.maximum(ws), | |
List.sum(hs));} | |
_E.Case($moduleName, | |
"between lines 206 and 216"); | |
}(); | |
}(); | |
}); | |
var above = F2(function (hi,lo) | |
{ | |
return A3(newElement, | |
A2(Basics.max,widthOf(hi),widthOf(lo)), | |
heightOf(hi) + heightOf(lo), | |
A2(Flow,DDown,_L.fromArray([hi,lo]))); | |
}); | |
var below = F2(function (lo,hi) | |
{ | |
return A3(newElement, | |
A2(Basics.max,widthOf(hi),widthOf(lo)), | |
heightOf(hi) + heightOf(lo), | |
A2(Flow,DDown,_L.fromArray([hi,lo]))); | |
}); | |
var beside = F2(function (lft,rht) | |
{ | |
return A3(newElement, | |
widthOf(lft) + widthOf(rht), | |
A2(Basics.max, | |
heightOf(lft), | |
heightOf(rht)), | |
A2(Flow,right,_L.fromArray([lft,rht]))); | |
}); | |
var layers = function (es) | |
{ | |
return function () | |
{ | |
var hs = A2(List.map,heightOf,es); | |
var ws = A2(List.map,widthOf,es); | |
return A3(newElement, | |
List.maximum(ws), | |
List.maximum(hs), | |
A2(Flow,DOut,es)); | |
}(); | |
}; | |
_elm.Graphics.Element.values = {_op: _op, empty: empty, widthOf: widthOf, heightOf: heightOf, sizeOf: sizeOf, width: width, height: height, size: size, opacity: opacity, color: color, tag: tag, link: link, newElement: newElement, image: image, fittedImage: fittedImage, croppedImage: croppedImage, tiledImage: tiledImage, container: container, spacer: spacer, flow: flow, above: above, below: below, beside: beside, layers: layers, absolute: absolute, relative: relative, middle: middle, topLeft: topLeft, topRight: topRight, bottomLeft: bottomLeft, bottomRight: bottomRight, midLeft: midLeft, midRight: midRight, midTop: midTop, midBottom: midBottom, middleAt: middleAt, topLeftAt: topLeftAt, topRightAt: topRightAt, bottomLeftAt: bottomLeftAt, bottomRightAt: bottomRightAt, midLeftAt: midLeftAt, midRightAt: midRightAt, midTopAt: midTopAt, midBottomAt: midBottomAt, up: up, down: down, left: left, right: right, inward: inward, outward: outward, Image: Image, Container: Container, Flow: Flow, Spacer: Spacer, RawHtml: RawHtml, Custom: Custom, Plain: Plain, Fitted: Fitted, Cropped: Cropped, Tiled: Tiled, P: P, Z: Z, N: N, Absolute: Absolute, Relative: Relative, DUp: DUp, DDown: DDown, DLeft: DLeft, DRight: DRight, DIn: DIn, DOut: DOut, Properties: Properties, Element: Element, Position: Position}; | |
return _elm.Graphics.Element.values; | |
};Elm.Graphics = Elm.Graphics || {}; | |
Elm.Graphics.Collage = Elm.Graphics.Collage || {}; | |
Elm.Graphics.Collage.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Graphics = _elm.Graphics || {}; | |
_elm.Graphics.Collage = _elm.Graphics.Collage || {}; | |
if (_elm.Graphics.Collage.values) | |
return _elm.Graphics.Collage.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Graphics.Collage"; | |
var Basics = Elm.Basics.make(_elm); | |
var Color = Elm.Color.make(_elm); | |
var Either = Elm.Either.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Element = Elm.Graphics.Element.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Graphics = Native.Graphics || {}; | |
Native.Graphics.Collage = Elm.Native.Graphics.Collage.make(_elm); | |
var Transform2D = Elm.Transform2D.make(_elm); | |
var _op = {}; | |
var ngon = F2(function (n,r) | |
{ | |
return function () | |
{ | |
var m = Basics.toFloat(n); | |
var t = 2 * Basics.pi / m; | |
var f = function (i) | |
{ | |
return {ctor: "_Tuple2", _0: r * Basics.cos(t * i), _1: r * Basics.sin(t * i)}; | |
}; | |
return A2(List.map,f,_L.range(0,m - 1)); | |
}(); | |
}); | |
var oval = F2(function (w,h) | |
{ | |
return function () | |
{ | |
var hh = h / 2; | |
var hw = w / 2; | |
var n = 50; | |
var t = 2 * Basics.pi / n; | |
var f = function (i) | |
{ | |
return {ctor: "_Tuple2", _0: hw * Basics.cos(t * i), _1: hh * Basics.sin(t * i)}; | |
}; | |
return A2(List.map,f,_L.range(0,n - 1)); | |
}(); | |
}); | |
var circle = function (r) | |
{ | |
return A2(oval,2 * r,2 * r); | |
}; | |
var rect = F2(function (w,h) | |
{ | |
return function () | |
{ | |
var hh = h / 2; | |
var hw = w / 2; | |
return _L.fromArray([{ctor: "_Tuple2", _0: 0 - hw, _1: 0 - hh}, | |
{ctor: "_Tuple2", _0: 0 - hw, _1: hh}, | |
{ctor: "_Tuple2", _0: hw, _1: hh}, | |
{ctor: "_Tuple2", _0: hw, _1: 0 - hh}]); | |
}(); | |
}); | |
var square = function (n) | |
{ | |
return A2(rect,n,n); | |
}; | |
var polygon = function (points) | |
{ | |
return points; | |
}; | |
var segment = F2(function (p1,p2) | |
{ | |
return _L.fromArray([p1,p2]); | |
}); | |
var path = function (ps) | |
{ | |
return ps; | |
}; | |
var collage = Native.Graphics.Collage.collage; | |
var alpha = F2(function (a,f) | |
{ | |
return _U.replace([["alpha",a]],f); | |
}); | |
var rotate = F2(function (t,f) | |
{ | |
return _U.replace([["theta",f.theta + t]],f); | |
}); | |
var scale = F2(function (s,f) | |
{ | |
return _U.replace([["scale",f.scale * s]],f); | |
}); | |
var moveY = F2(function (y,f) | |
{ | |
return _U.replace([["y",f.y + y]],f); | |
}); | |
var moveX = F2(function (x,f) | |
{ | |
return _U.replace([["x",f.x + x]],f); | |
}); | |
var move = F2(function (_v0,f) | |
{ | |
return function () | |
{ | |
switch (_v0.ctor) | |
{case | |
"_Tuple2" : | |
return _U.replace([["x",f.x + _v0._0], | |
["y",f.y + _v0._1]], | |
f);} | |
_E.Case($moduleName, | |
"on line 169, column 20 to 48"); | |
}(); | |
}); | |
var form = function (f) | |
{ | |
return {_: {}, alpha: 1, form: f, scale: 1, theta: 0, x: 0, y: 0}; | |
}; | |
var FGroup = F2(function (a,b) | |
{ | |
return {ctor: "FGroup", _0: a, _1: b}; | |
}); | |
var group = function (fs) | |
{ | |
return form(A2(FGroup,Transform2D.identity,fs)); | |
}; | |
var groupTransform = F2(function (matrix,fs) | |
{ | |
return form(A2(FGroup,matrix,fs)); | |
}); | |
var FElement = function (a) | |
{ | |
return {ctor: "FElement", _0: a}; | |
}; | |
var toForm = function (e) | |
{ | |
return form(FElement(e)); | |
}; | |
var FImage = F4(function (a,b,c,d) | |
{ | |
return {ctor: "FImage", _0: a, _1: b, _2: c, _3: d}; | |
}); | |
var sprite = F4(function (w,h,pos,src) | |
{ | |
return form(A4(FImage,w,h,pos,src)); | |
}); | |
var FShape = F2(function (a,b) | |
{ | |
return {ctor: "FShape", _0: a, _1: b}; | |
}); | |
var fill = F2(function (style,shape) | |
{ | |
return form(A2(FShape,Either.Right(style),shape)); | |
}); | |
var outlined = F2(function (style,shape) | |
{ | |
return form(A2(FShape,Either.Left(style),shape)); | |
}); | |
var FPath = F2(function (a,b) | |
{ | |
return {ctor: "FPath", _0: a, _1: b}; | |
}); | |
var traced = F2(function (style,path) | |
{ | |
return form(A2(FPath,style,path)); | |
}); | |
var LineStyle = F6(function (a,b,c,d,e,f) | |
{ | |
return {_: {}, cap: c, color: a, dashOffset: f, dashing: e, join: d, width: b}; | |
}); | |
var Clipped = {ctor: "Clipped"}; | |
var Sharp = function (a) | |
{ | |
return {ctor: "Sharp", _0: a}; | |
}; | |
var Smooth = {ctor: "Smooth"}; | |
var Padded = {ctor: "Padded"}; | |
var Round = {ctor: "Round"}; | |
var Flat = {ctor: "Flat"}; | |
var defaultLine = {_: {}, cap: Flat, color: Color.black, dashOffset: 0, dashing: _L.fromArray([]), join: Sharp(10), width: 1}; | |
var solid = function (clr) | |
{ | |
return _U.replace([["color",clr]],defaultLine); | |
}; | |
var dashed = function (clr) | |
{ | |
return _U.replace([["color",clr], | |
["dashing",_L.fromArray([8,4])]], | |
defaultLine); | |
}; | |
var dotted = function (clr) | |
{ | |
return _U.replace([["color",clr], | |
["dashing",_L.fromArray([3,3])]], | |
defaultLine); | |
}; | |
var Grad = function (a) | |
{ | |
return {ctor: "Grad", _0: a}; | |
}; | |
var gradient = F2(function (grad,shape) | |
{ | |
return A2(fill,Grad(grad),shape); | |
}); | |
var Texture = function (a) | |
{ | |
return {ctor: "Texture", _0: a}; | |
}; | |
var textured = F2(function (src,shape) | |
{ | |
return A2(fill,Texture(src),shape); | |
}); | |
var Solid = function (a) | |
{ | |
return {ctor: "Solid", _0: a}; | |
}; | |
var filled = F2(function (color,shape) | |
{ | |
return A2(fill,Solid(color),shape); | |
}); | |
var Form = F6(function (a,b,c,d,e,f) | |
{ | |
return {_: {}, alpha: e, form: f, scale: b, theta: a, x: c, y: d}; | |
}); | |
_elm.Graphics.Collage.values = {_op: _op, defaultLine: defaultLine, solid: solid, dashed: dashed, dotted: dotted, form: form, fill: fill, filled: filled, textured: textured, gradient: gradient, outlined: outlined, traced: traced, sprite: sprite, toForm: toForm, group: group, groupTransform: groupTransform, move: move, moveX: moveX, moveY: moveY, scale: scale, rotate: rotate, alpha: alpha, collage: collage, path: path, segment: segment, polygon: polygon, rect: rect, square: square, oval: oval, circle: circle, ngon: ngon, Solid: Solid, Texture: Texture, Grad: Grad, Flat: Flat, Round: Round, Padded: Padded, Smooth: Smooth, Sharp: Sharp, Clipped: Clipped, FPath: FPath, FShape: FShape, FImage: FImage, FElement: FElement, FGroup: FGroup, Form: Form, LineStyle: LineStyle}; | |
return _elm.Graphics.Collage.values; | |
};Elm.Graphics = Elm.Graphics || {}; | |
Elm.Graphics.Input = Elm.Graphics.Input || {}; | |
Elm.Graphics.Input.Field = Elm.Graphics.Input.Field || {}; | |
Elm.Graphics.Input.Field.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Graphics = _elm.Graphics || {}; | |
_elm.Graphics.Input = _elm.Graphics.Input || {}; | |
_elm.Graphics.Input.Field = _elm.Graphics.Input.Field || {}; | |
if (_elm.Graphics.Input.Field.values) | |
return _elm.Graphics.Input.Field.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Graphics.Input.Field"; | |
var Color = Elm.Color.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Element = Elm.Graphics.Element.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Input = Elm.Graphics.Input.make(_elm); | |
var Native = Native || {}; | |
Native.Graphics = Native.Graphics || {}; | |
Native.Graphics.Input = Elm.Native.Graphics.Input.make(_elm); | |
var Text = Elm.Text.make(_elm); | |
var _op = {}; | |
var email = Native.Graphics.Input.email; | |
var password = Native.Graphics.Input.password; | |
var field = Native.Graphics.Input.field; | |
var Backward = {ctor: "Backward"}; | |
var Forward = {ctor: "Forward"}; | |
var Selection = F3(function (a,b,c) | |
{ | |
return {_: {}, direction: c, end: b, start: a}; | |
}); | |
var Content = F2(function (a,b) | |
{ | |
return {_: {}, selection: b, string: a}; | |
}); | |
var noContent = A2(Content,"",A3(Selection,0,0,Forward)); | |
var Style = F4(function (a,b,c,d) | |
{ | |
return {_: {}, highlight: c, outline: b, padding: a, style: d}; | |
}); | |
var Highlight = F2(function (a,b) | |
{ | |
return {_: {}, color: a, width: b}; | |
}); | |
var noHighlight = A2(Highlight,Color.blue,0); | |
var Outline = F3(function (a,b,c) | |
{ | |
return {_: {}, color: a, radius: c, width: b}; | |
}); | |
var Dimensions = F4(function (a,b,c,d) | |
{ | |
return {_: {}, bottom: d, left: a, right: b, top: c}; | |
}); | |
var uniformly = function (n) | |
{ | |
return A4(Dimensions,n,n,n,n); | |
}; | |
var noOutline = A3(Outline,Color.grey,uniformly(0),0); | |
var defaultStyle = {_: {}, highlight: A2(Highlight, | |
Color.blue, | |
1), outline: A3(Outline, | |
Color.grey, | |
uniformly(1), | |
2), padding: uniformly(4), style: Text.defaultStyle}; | |
_elm.Graphics.Input.Field.values = {_op: _op, uniformly: uniformly, noOutline: noOutline, noHighlight: noHighlight, defaultStyle: defaultStyle, noContent: noContent, field: field, password: password, email: email, Forward: Forward, Backward: Backward, Dimensions: Dimensions, Outline: Outline, Highlight: Highlight, Style: Style, Content: Content, Selection: Selection}; | |
return _elm.Graphics.Input.Field.values; | |
};(function() { | |
// Returns boolean indicating if the swap was successful. | |
// Requires that the two signal graphs have exactly the same | |
// structure. | |
ElmRuntime.swap = function(from, to) { | |
function similar(nodeOld,nodeNew) { | |
var idOkay = nodeOld.id === nodeNew.id; | |
var lengthOkay = nodeOld.kids.length === nodeNew.kids.length; | |
return idOkay && lengthOkay; | |
} | |
function swap(nodeOld,nodeNew) { | |
nodeNew.value = nodeOld.value; | |
return true; | |
} | |
var canSwap = depthFirstTraversals(similar, from.inputs, to.inputs); | |
if (canSwap) { depthFirstTraversals(swap, from.inputs, to.inputs); } | |
from.node.parentNode.replaceChild(to.node, from.node); | |
return canSwap; | |
} | |
// Returns false if the node operation f ever fails. | |
function depthFirstTraversals(f, queueOld, queueNew) { | |
if (queueOld.length !== queueNew.length) return false; | |
queueOld = queueOld.slice(0); | |
queueNew = queueNew.slice(0); | |
var seen = []; | |
while (queueOld.length > 0 && queueNew.length > 0) { | |
var nodeOld = queueOld.pop(); | |
var nodeNew = queueNew.pop(); | |
if (seen.indexOf(nodeOld.id) < 0) { | |
if (!f(nodeOld, nodeNew)) return false; | |
queueOld = queueOld.concat(nodeOld.kids); | |
queueNew = queueNew.concat(nodeNew.kids); | |
seen.push(nodeOld.id); | |
} | |
} | |
return true; | |
} | |
}()); | |
(function() { | |
'use strict'; | |
ElmRuntime.Display = { FULLSCREEN: 0, COMPONENT: 1, NONE: 2 }; | |
ElmRuntime.counter = 0; | |
ElmRuntime.guid = function() { return ElmRuntime.counter++; } | |
ElmRuntime.use = function(M) { | |
if (typeof M === 'function') M = M(); | |
return M; | |
}; | |
function isAlive(input) { | |
if (!('defaultNumberOfKids' in input)) return true; | |
var len = input.kids.length; | |
if (len === 0) return false; | |
if (len > input.defaultNumberOfKids) return true; | |
var alive = false; | |
for (var i = len; i--; ) { | |
alive = alive || isAlive(input.kids[i]); | |
} | |
return alive; | |
} | |
ElmRuntime.filterDeadInputs = function(inputs) { | |
var temp = []; | |
for (var i = inputs.length; i--; ) { | |
if (isAlive(inputs[i])) temp.push(inputs[i]); | |
} | |
return temp; | |
}; | |
// define the draw function | |
var vendors = ['ms', 'moz', 'webkit', 'o']; | |
var win = typeof window !== 'undefined' ? window : {}; | |
for (var i = 0; i < vendors.length && !win.requestAnimationFrame; ++i) { | |
win.requestAnimationFrame = win[vendors[i]+'RequestAnimationFrame']; | |
win.cancelAnimationFrame = win[vendors[i]+'CancelAnimationFrame'] || | |
win[vendors[i]+'CancelRequestAnimationFrame']; | |
} | |
if (win.requestAnimationFrame && win.cancelAnimationFrame) { | |
var previous = 0; | |
ElmRuntime.draw = function(callback) { | |
win.cancelAnimationFrame(previous); | |
previous = win.requestAnimationFrame(callback); | |
}; | |
} else { | |
ElmRuntime.draw = function(callback) { callback(); }; | |
} | |
}()); | |
(function() { | |
'use strict'; | |
Elm.fullscreen = function(module, ports) { | |
var style = document.createElement('style'); | |
style.type = 'text/css'; | |
style.innerHTML = "html,head,body { padding:0; margin:0; }" + | |
"body { font-family: calibri, helvetica, arial, sans-serif; }"; | |
document.head.appendChild(style); | |
var container = document.createElement('div'); | |
document.body.appendChild(container); | |
return init(ElmRuntime.Display.FULLSCREEN, container, module, ports || {}); | |
}; | |
Elm.embed = function(module, container, ports) { | |
var tag = container.tagName; | |
if (tag !== 'DIV') { | |
throw new Error('Elm.node must be given a DIV, not a ' + tag + '.'); | |
} else if (container.hasChildNodes()) { | |
throw new Error('Elm.node must be given an empty DIV. No children allowed!'); | |
} | |
return init(ElmRuntime.Display.COMPONENT, container, module, ports || {}); | |
}; | |
Elm.worker = function(module, ports) { | |
return init(ElmRuntime.Display.NONE, {}, module, ports || {}); | |
}; | |
function init(display, container, module, ports, moduleToReplace) { | |
// defining state needed for an instance of the Elm RTS | |
var inputs = []; | |
var updateInProgress = false; | |
function notify(id, v) { | |
if (updateInProgress) { | |
throw new Error( | |
'The notify function has been called synchronously!\n' + | |
'This can lead to frames being dropped.\n' + | |
'Definitely report this to <https://github.com/elm-lang/Elm/issues>\n'); | |
} | |
updateInProgress = true; | |
var timestep = Date.now(); | |
for (var i = inputs.length; i--; ) { | |
inputs[i].recv(timestep, id, v); | |
} | |
updateInProgress = false; | |
} | |
var listeners = []; | |
function addListener(relevantInputs, domNode, eventName, func) { | |
domNode.addEventListener(eventName, func); | |
var listener = { | |
relevantInputs: relevantInputs, | |
domNode: domNode, | |
eventName: eventName, | |
func: func | |
}; | |
listeners.push(listener); | |
} | |
var portUses = {} | |
for (var key in ports) { | |
portUses[key] = 0; | |
} | |
// create the actual RTS. Any impure modules will attach themselves to this | |
// object. This permits many Elm programs to be embedded per document. | |
var elm = { | |
notify:notify, | |
node:container, | |
display:display, | |
id:ElmRuntime.guid(), | |
addListener:addListener, | |
inputs:inputs, | |
ports: { incoming:ports, outgoing:{}, uses:portUses } | |
}; | |
function swap(newModule) { | |
removeListeners(listeners); | |
var div = document.createElement('div'); | |
var newElm = init(display, div, newModule, ports, elm); | |
inputs = []; | |
// elm.swap = newElm.swap; | |
return newElm; | |
} | |
var Module = {}; | |
var reportAnyErrors = function() {}; | |
try { | |
Module = module.make(elm); | |
checkPorts(elm); | |
} catch(e) { | |
var directions = "<br/> Open the developer console for more details." | |
Module.main = Elm.Text.make(elm).leftAligned('<code>' + e.message + directions + '</code>'); | |
reportAnyErrors = function() { throw e; } | |
} | |
inputs = ElmRuntime.filterDeadInputs(inputs); | |
filterListeners(inputs, listeners); | |
addReceivers(elm.ports.outgoing); | |
if (display !== ElmRuntime.Display.NONE) { | |
var graphicsNode = initGraphics(elm, Module); | |
} | |
if (typeof moduleToReplace !== 'undefined') { | |
ElmRuntime.swap(moduleToReplace, elm); | |
// rerender scene if graphics are enabled. | |
if (typeof graphicsNode !== 'undefined') { | |
graphicsNode.recv(0, true, false, 0); | |
} | |
} | |
reportAnyErrors(); | |
return { swap:swap, ports:elm.ports.outgoing }; | |
}; | |
function checkPorts(elm) { | |
var portUses = elm.ports.uses; | |
for (var key in portUses) { | |
var uses = portUses[key] | |
if (uses === 0) { | |
throw new Error( | |
"Initialization Error: provided port '" + key + | |
"' to a module that does not take it as in input.\n" + | |
"Remove '" + key + "' from the module initialization code."); | |
} else if (uses > 1) { | |
throw new Error( | |
"Initialization Error: port '" + key + | |
"' has been declared multiple times in the Elm code.\n" + | |
"Remove declarations until there is exactly one."); | |
} | |
} | |
} | |
function filterListeners(inputs, listeners) { | |
loop: | |
for (var i = listeners.length; i--; ) { | |
var listener = listeners[i]; | |
for (var j = inputs.length; j--; ) { | |
if (listener.relevantInputs.indexOf(inputs[j].id) >= 0) { | |
continue loop; | |
} | |
} | |
listener.domNode.removeEventListener(listener.eventName, listener.func); | |
} | |
} | |
function removeListeners(listeners) { | |
for (var i = listeners.length; i--; ) { | |
var listener = listeners[i]; | |
listener.domNode.removeEventListener(listener.eventName, listener.func); | |
} | |
} | |
// add receivers for built-in ports if they are defined | |
function addReceivers(ports) { | |
if ('log' in ports) { | |
ports.log.subscribe(function(v) { console.log(v) }); | |
} | |
if ('stdout' in ports) { | |
var process = process || {}; | |
var handler = process.stdout | |
? function(v) { process.stdout.write(v); } | |
: function(v) { console.log(v); }; | |
ports.stdout.subscribe(handler); | |
} | |
if ('stderr' in ports) { | |
var process = process || {}; | |
var handler = process.stderr | |
? function(v) { process.stderr.write(v); } | |
: function(v) { console.log('Error:' + v); }; | |
ports.stderr.subscribe(handler); | |
} | |
if ('title' in ports) { | |
if (typeof ports.title === 'string') { | |
document.title = ports.title; | |
} else { | |
ports.title.subscribe(function(v) { document.title = v; }); | |
} | |
} | |
if ('redirect' in ports) { | |
ports.redirect.subscribe(function(v) { | |
if (v.length > 0) window.location = v; | |
}); | |
} | |
if ('favicon' in ports) { | |
if (typeof ports.favicon === 'string') { | |
changeFavicon(ports.favicon); | |
} else { | |
ports.favicon.subscribe(changeFavicon); | |
} | |
} | |
function changeFavicon(src) { | |
var link = document.createElement('link'); | |
var oldLink = document.getElementById('elm-favicon'); | |
link.id = 'elm-favicon'; | |
link.rel = 'shortcut icon'; | |
link.href = src; | |
if (oldLink) { | |
document.head.removeChild(oldLink); | |
} | |
document.head.appendChild(link); | |
} | |
} | |
function initGraphics(elm, Module) { | |
if (!('main' in Module)) | |
throw new Error("'main' is missing! What do I display?!"); | |
var signalGraph = Module.main; | |
// make sure the signal graph is actually a signal & extract the visual model | |
var Signal = Elm.Signal.make(elm); | |
var NS = Elm.Native.Signal.make(elm); | |
if (!('recv' in signalGraph)) { | |
signalGraph = Signal.constant(signalGraph); | |
} | |
var currentScene = signalGraph.value; | |
// Add the currentScene to the DOM | |
var Render = ElmRuntime.use(ElmRuntime.Render.Element); | |
elm.node.appendChild(Render.render(currentScene)); | |
// set up updates so that the DOM is adjusted as necessary. | |
var savedScene = currentScene; | |
function domUpdate(newScene) { | |
ElmRuntime.draw(function(_) { | |
Render.update(elm.node.firstChild, savedScene, newScene); | |
if (elm.Native.Window) elm.Native.Window.values.resizeIfNeeded(); | |
savedScene = newScene; | |
}); | |
} | |
function domUpdate2(rawLiftNode) { | |
return function(timestep, updated, duplicate, parentID) { | |
if(updated && !duplicate) { | |
domUpdate(signalGraph.value); | |
} else { | |
console.log("dropped message { " + timestep + ", " + updated + ", " + duplicate + ", " + parentID + " }"); | |
} | |
}; | |
} | |
var renderer = A3(NS.rawLift, domUpdate, domUpdate2, signalGraph); | |
// must check for resize after 'renderer' is created so | |
// that changes show up. | |
if (elm.Native.Window) elm.Native.Window.values.resizeIfNeeded(); | |
return renderer; | |
} | |
}()); | |
ElmRuntime.Render.Element = function() { | |
'use strict'; | |
var Utils = ElmRuntime.use(ElmRuntime.Render.Utils); | |
var newElement = Utils.newElement, colorToCss = Utils.colorToCss, | |
addTransform = Utils.addTransform, removeTransform = Utils.removeTransform, | |
fromList = Utils.fromList, eq = Utils.eq; | |
function setProps(elem, e) { | |
var props = elem.props; | |
var element = elem.element; | |
var width = props.width - (element.adjustWidth || 0); | |
var height = props.height - (element.adjustHeight || 0); | |
e.style.width = (width |0) + 'px'; | |
e.style.height = (height|0) + 'px'; | |
if (props.opacity !== 1) { | |
e.style.opacity = props.opacity; | |
} | |
if (props.color.ctor === 'Just') { | |
e.style.backgroundColor = colorToCss(props.color._0); | |
} | |
if (props.tag !== '') { e.id = props.tag; } | |
if (props.href !== '') { | |
var a = newElement('a'); | |
a.href = props.href; | |
a.style.width = '100%'; | |
a.style.height = '100%'; | |
a.style.top = 0; | |
a.style.left = 0; | |
a.style.display = 'block'; | |
a.style.position = 'absolute'; | |
e.style.position = 'relative'; | |
a.style.pointerEvents = 'auto'; | |
e.appendChild(a); | |
} | |
if (props.hover.ctor !== '_Tuple0') { | |
addHover(e, props.hover); | |
} | |
if (props.click.ctor !== '_Tuple0') { | |
addClick(e, props.click); | |
} | |
return e; | |
} | |
function addClick(e, handler) { | |
e.style.pointerEvents = 'auto'; | |
e.elm_click_handler = handler; | |
function trigger(ev) { | |
e.elm_click_handler(Utils.Tuple0); | |
ev.stopPropagation(); | |
} | |
e.elm_click_trigger = trigger; | |
e.addEventListener('click', trigger); | |
} | |
function removeClick(e, handler) { | |
if (e.elm_click_trigger) { | |
e.removeEventListener('click', e.elm_click_trigger); | |
} | |
} | |
function addHover(e, handler) { | |
e.style.pointerEvents = 'auto'; | |
e.elm_hover_handler = handler; | |
e.elm_hover_count = 0; | |
function over(evt) { | |
if (e.elm_hover_count++ > 0) return; | |
e.elm_hover_handler(true); | |
evt.stopPropagation(); | |
} | |
function out(evt) { | |
if (e.contains(evt.toElement || evt.relatedTarget)) return; | |
e.elm_hover_count = 0; | |
e.elm_hover_handler(false); | |
evt.stopPropagation(); | |
} | |
e.elm_hover_over = over; | |
e.elm_hover_out = out; | |
e.addEventListener('mouseover', over); | |
e.addEventListener('mouseout', out); | |
} | |
function removeHover(e) { | |
if (e.elm_hover_over) { | |
e.removeEventListener('mouseover', e.elm_hover_over); | |
} | |
if (e.elm_hover_out) { | |
e.removeEventListener('mouseout', e.elm_hover_out); | |
} | |
} | |
function image(props, img) { | |
switch (img._0.ctor) { | |
case 'Plain': return plainImage(img._3); | |
case 'Fitted': return fittedImage(props.width, props.height, img._3); | |
case 'Cropped': return croppedImage(img,props.width,props.height,img._3); | |
case 'Tiled': return tiledImage(img._3); | |
} | |
} | |
function plainImage(src) { | |
var img = newElement('img'); | |
img.src = src; | |
img.name = src; | |
img.style.display = "block"; | |
return img; | |
} | |
function tiledImage(src) { | |
var div = newElement('div'); | |
div.style.backgroundImage = 'url(' + src + ')'; | |
return div; | |
} | |
function fittedImage(w, h, src) { | |
var div = newElement('div'); | |
div.style.background = 'url(' + src + ') no-repeat center'; | |
div.style.webkitBackgroundSize = 'cover'; | |
div.style.MozBackgroundSize = 'cover'; | |
div.style.OBackgroundSize = 'cover'; | |
div.style.backgroundSize = 'cover'; | |
return div; | |
} | |
function croppedImage(elem, w, h, src) { | |
var pos = elem._0._0; | |
var e = newElement('div'); | |
e.style.overflow = "hidden"; | |
var img = newElement('img'); | |
img.onload = function() { | |
var sw = w / elem._1, sh = h / elem._2; | |
img.style.width = ((this.width * sw)|0) + 'px'; | |
img.style.height = ((this.height * sh)|0) + 'px'; | |
img.style.marginLeft = ((- pos._0 * sw)|0) + 'px'; | |
img.style.marginTop = ((- pos._1 * sh)|0) + 'px'; | |
}; | |
img.src = src; | |
img.name = src; | |
e.appendChild(img); | |
return e; | |
} | |
function goOut(e) { e.style.position = 'absolute'; return e; } | |
function goDown(e) { return e } | |
function goRight(e) { e.style.styleFloat = e.style.cssFloat = "left"; return e; } | |
var directionTable = { | |
DUp : goDown, | |
DDown : goDown, | |
DLeft : goRight, | |
DRight : goRight, | |
DIn : goOut, | |
DOut : goOut | |
}; | |
function needsReversal(dir) { | |
return dir == 'DUp' || dir == 'DLeft' || dir == 'DIn'; | |
} | |
function flow(dir,elist) { | |
var array = fromList(elist); | |
var container = newElement('div'); | |
var goDir = directionTable[dir]; | |
if (goDir == goOut) { | |
container.style.pointerEvents = 'none'; | |
} | |
if (needsReversal(dir)) { | |
array.reverse(); | |
} | |
var len = array.length; | |
for (var i = 0; i < len; ++i) { | |
container.appendChild(goDir(render(array[i]))); | |
} | |
return container; | |
} | |
function toPos(pos) { | |
switch(pos.ctor) { | |
case "Absolute": return pos._0 + "px"; | |
case "Relative": return (pos._0 * 100) + "%"; | |
} | |
} | |
// must clear right, left, top, bottom, and transform | |
// before calling this function | |
function setPos(pos,elem,e) { | |
var element = elem.element; | |
var props = elem.props; | |
var w = props.width + (element.adjustWidth ? element.adjustWidth : 0); | |
var h = props.height + (element.adjustHeight ? element.adjustHeight : 0); | |
e.style.position = 'absolute'; | |
e.style.margin = 'auto'; | |
var transform = ''; | |
switch(pos.horizontal.ctor) { | |
case 'P': e.style.right = toPos(pos.x); e.style.removeProperty('left'); break; | |
case 'Z': transform = 'translateX(' + ((-w/2)|0) + 'px) '; | |
case 'N': e.style.left = toPos(pos.x); e.style.removeProperty('right'); break; | |
} | |
switch(pos.vertical.ctor) { | |
case 'N': e.style.bottom = toPos(pos.y); e.style.removeProperty('top'); break; | |
case 'Z': transform += 'translateY(' + ((-h/2)|0) + 'px)'; | |
case 'P': e.style.top = toPos(pos.y); e.style.removeProperty('bottom'); break; | |
} | |
if (transform !== '') addTransform(e.style, transform); | |
return e; | |
} | |
function container(pos,elem) { | |
var e = render(elem); | |
setPos(pos, elem, e); | |
var div = newElement('div'); | |
div.style.position = 'relative'; | |
div.style.overflow = 'hidden'; | |
div.appendChild(e); | |
return div; | |
} | |
function rawHtml(elem) { | |
var html = elem.html; | |
var args = elem.args; | |
var guid = elem.guid; | |
var align = elem.align; | |
var div = newElement('div'); | |
div.innerHTML = html; | |
div.style.visibility = "hidden"; | |
if (align) div.style.textAlign = align; | |
document.body.appendChild(div); | |
for (var i = args.length; i--; ) { | |
var arg = args[i]; | |
var span = document.getElementById('md-' + guid + '-' + i); | |
if (arg.isText) { | |
span.innerHTML = arg; | |
} else { | |
span.style.display = 'block'; | |
span.style.width = arg.props.width + 'px'; | |
span.style.height = arg.props.height + 'px'; | |
span.appendChild(render(arg)); | |
} | |
} | |
document.body.removeChild(div); | |
div.style.visibility = 'visible'; | |
div.style.pointerEvents = 'auto'; | |
return div; | |
} | |
function render(elem) { return setProps(elem, makeElement(elem)); } | |
function makeElement(e) { | |
var elem = e.element; | |
switch(elem.ctor) { | |
case 'Image': return image(e.props, elem); | |
case 'Flow': return flow(elem._0.ctor, elem._1); | |
case 'Container': return container(elem._0, elem._1); | |
case 'Spacer': return newElement('div'); | |
case 'RawHtml': return rawHtml(elem); | |
case 'Custom': return elem.render(elem.model); | |
} | |
} | |
function update(node, curr, next) { | |
if (node.tagName === 'A') { node = node.firstChild; } | |
if (curr.props.id === next.props.id) return updateProps(node, curr, next); | |
if (curr.element.ctor !== next.element.ctor) { | |
node.parentNode.replaceChild(render(next),node); | |
return true; | |
} | |
var nextE = next.element, currE = curr.element; | |
switch(nextE.ctor) { | |
case "Spacer": break; | |
case "RawHtml": | |
// only markdown blocks have guids, so this must be a text block | |
if (nextE.guid === null) { | |
if(currE.html.valueOf() !== nextE.html.valueOf()) { | |
node.innerHTML = nextE.html; | |
} | |
break; | |
} | |
if (nextE.guid !== currE.guid) { | |
node.parentNode.replaceChild(render(next),node); | |
return true; | |
} | |
var nargs = nextE.args; | |
var cargs = currE.args; | |
for (var i = nargs.length; i--; ) { | |
var narg = nargs[i]; | |
var carg = cargs[i] | |
if (narg == carg) continue; | |
var span = document.getElementById('md-' + currE.guid + '-' + i); | |
if (narg.isElement) { | |
if (carg.isElement) { | |
update(span, carg, narg); | |
} else { | |
span.style.display = 'block'; | |
var e = render(narg); | |
span.innerHTML = ''; | |
span.appendChild(e); | |
} | |
} else { | |
span.style.display = 'inline'; | |
span.innerHTML = narg; | |
} | |
} | |
break; | |
case "Image": | |
if (nextE._0.ctor === 'Plain') { | |
if (nextE._3 !== currE._3) node.src = nextE._3; | |
} else if (!eq(nextE,currE) || | |
next.props.width !== curr.props.width || | |
next.props.height !== curr.props.height) { | |
node.parentNode.replaceChild(render(next),node); | |
return true; | |
} | |
break; | |
case "Flow": | |
var arr = fromList(nextE._1); | |
for (var i = arr.length; i--; ) { arr[i] = arr[i].element.ctor; } | |
if (nextE._0.ctor !== currE._0.ctor) { | |
node.parentNode.replaceChild(render(next),node); | |
return true; | |
} | |
var nexts = fromList(nextE._1); | |
var kids = node.childNodes; | |
if (nexts.length !== kids.length) { | |
node.parentNode.replaceChild(render(next),node); | |
return true; | |
} | |
var currs = fromList(currE._1); | |
var dir = nextE._0.ctor; | |
var goDir = directionTable[dir]; | |
var toReverse = needsReversal(dir); | |
var len = kids.length; | |
for (var i = len; i-- ;) { | |
update(kids[toReverse ? len - i - 1 : i],currs[i],nexts[i]); | |
goDir(kids[i]); | |
} | |
break; | |
case "Container": | |
update(node.firstChild, currE._1, nextE._1); | |
setPos(nextE._0, nextE._1, node.firstChild); | |
break; | |
case "Custom": | |
if (currE.type === nextE.type) { | |
var done = nextE.update(node, currE.model, nextE.model); | |
if (done) return; | |
} else { | |
return node.parentNode.replaceChild(render(next), node); | |
} | |
} | |
updateProps(node, curr, next); | |
} | |
function updateProps(node, curr, next) { | |
var props = next.props; | |
var currP = curr.props; | |
var e = node; | |
var element = next.element; | |
var width = props.width - (element.adjustWidth || 0); | |
var height = props.height - (element.adjustHeight || 0); | |
if (width !== currP.width) { | |
e.style.width = (width|0) + 'px'; | |
} | |
if (height !== currP.height) { | |
e.style.height = (height|0) + 'px'; | |
} | |
if (props.opacity !== currP.opacity) { | |
e.style.opacity = props.opacity; | |
} | |
var nextColor = (props.color.ctor === 'Just' ? | |
colorToCss(props.color._0) : ''); | |
if (e.style.backgroundColor !== nextColor) { | |
e.style.backgroundColor = (nextColor === '' ? 'transparent' : nextColor); | |
} | |
if (props.tag !== currP.tag) { e.id = props.tag; } | |
if (props.href !== currP.href) { | |
if (currP.href === '') { | |
var a = newElement('a'); | |
a.href = props.href; | |
a.style.width = '100%'; | |
a.style.height = '100%'; | |
a.style.top = 0; | |
a.style.left = 0; | |
a.style.display = 'block'; | |
a.style.position = 'absolute'; | |
e.style.position = 'relative'; | |
a.style.pointerEvents = 'auto'; | |
e.appendChild(a); | |
} else { | |
node.lastNode.href = props.href; | |
} | |
} | |
// update hover handlers | |
if (props.hover.ctor === '_Tuple0') { | |
removeHover(e); | |
} else if (e.elm_hover_handler) { | |
e.elm_hover_handler = props.hover; | |
} else { | |
addHover(e, props.hover); | |
} | |
// update click handlers | |
if (props.click.ctor === '_Tuple0') { | |
removeClick(e); | |
} else if (e.elm_click_handler) { | |
e.elm_click_handler = props.click; | |
} else { | |
addClick(e, props.click); | |
} | |
} | |
return { render:render, update:update }; | |
}; | |
ElmRuntime.Render.Utils = function() { | |
function newElement(elementType) { | |
var e = document.createElement(elementType); | |
e.style.padding = "0"; | |
e.style.margin = "0"; | |
return e; | |
} | |
function addTo(container, elem) { | |
container.appendChild(elem); | |
} | |
function addTransform(style, trans) { | |
style.transform = trans; | |
style.msTransform = trans; | |
style.MozTransform = trans; | |
style.webkitTransform = trans; | |
style.OTransform = trans; | |
} | |
function removeTransform(style) { | |
style.transform = 'none'; | |
style.msTransform = 'none'; | |
style.MozTransform = 'none'; | |
style.webkitTransform = 'none'; | |
style.OTransform = 'none'; | |
} | |
var List = Elm.Native.List.make({}); | |
return {addTo:addTo, | |
newElement: newElement, | |
colorToCss: Elm.Native.Color.make({}).toCss, | |
fromList: List.toArray, | |
fromString: function(s) { return s; }, | |
toString: function(s) { return s; }, | |
eq: Elm.Native.Utils.make({}).eq, | |
addTransform: addTransform, | |
removeTransform: removeTransform}; | |
}; | |
ElmRuntime.Render.Collage = function() { | |
var Render = ElmRuntime.use(ElmRuntime.Render.Element); | |
var Transform = Elm.Transform2D.make({}); | |
var Utils = ElmRuntime.use(ElmRuntime.Render.Utils); | |
var newElement = Utils.newElement, | |
colorToCss = Utils.colorToCss, fromList = Utils.fromList, | |
fromString = Utils.fromString, addTransform = Utils.addTransform; | |
function trace(ctx, path) { | |
var points = fromList(path); | |
var i = points.length - 1; | |
if (i <= 0) return; | |
ctx.moveTo(points[i]._0, points[i]._1); | |
while (i--) { ctx.lineTo(points[i]._0, points[i]._1); } | |
if (path.closed) { | |
i = points.length - 1; | |
ctx.lineTo(points[i]._0, points[i]._1); | |
} | |
} | |
function line(ctx,style,path) { | |
style.dashing.ctor === 'Nil' ? trace(ctx, path) : customLineHelp(ctx, style, path); | |
ctx.scale(1,-1); | |
ctx.stroke(); | |
} | |
function customLineHelp(ctx, style, path) { | |
var points = fromList(path); | |
if (path.closed) points.push(points[0]); | |
var pattern = fromList(style.dashing); | |
var i = points.length - 1; | |
if (i <= 0) return; | |
var x0 = points[i]._0, y0 = points[i]._1; | |
var x1=0, y1=0, dx=0, dy=0, remaining=0, nx=0, ny=0; | |
var pindex = 0, plen = pattern.length; | |
var draw = true, segmentLength = pattern[0]; | |
ctx.moveTo(x0,y0); | |
while (i--) { | |
x1 = points[i]._0; y1 = points[i]._1; | |
dx = x1 - x0; dy = y1 - y0; | |
remaining = Math.sqrt(dx * dx + dy * dy); | |
while (segmentLength <= remaining) { | |
x0 += dx * segmentLength / remaining; | |
y0 += dy * segmentLength / remaining; | |
ctx[draw ? 'lineTo' : 'moveTo'](x0, y0); | |
// update starting position | |
dx = x1 - x0; dy = y1 - y0; | |
remaining = Math.sqrt(dx * dx + dy * dy); | |
// update pattern | |
draw = !draw; | |
pindex = (pindex + 1) % plen; | |
segmentLength = pattern[pindex]; | |
} | |
if (remaining > 0) { | |
ctx[draw ? 'lineTo' : 'moveTo'](x1, y1); | |
segmentLength -= remaining; | |
} | |
x0 = x1; y0 = y1; | |
} | |
} | |
function drawLine(ctx, style, path) { | |
ctx.lineWidth = style.width; | |
var cap = style.cap.ctor; | |
ctx.lineCap = cap === 'Flat' ? 'butt' : | |
cap === 'Round' ? 'round' : 'square'; | |
var join = style.join.ctor; | |
ctx.lineJoin = join === 'Smooth' ? 'round' : | |
join === 'Sharp' ? 'miter' : 'bevel'; | |
ctx.miterLimit = style.join._0 || 10; | |
ctx.strokeStyle = colorToCss(style.color); | |
return line(ctx, style, path); | |
} | |
function texture(redo, ctx, src) { | |
var img = new Image(); | |
img.src = fromString(src); | |
img.onload = redo; | |
return ctx.createPattern(img, 'repeat'); | |
} | |
function gradient(ctx, grad) { | |
var g; | |
var stops = []; | |
if (grad.ctor === 'Linear') { | |
var p0 = grad._0, p1 = grad._1; | |
g = ctx.createLinearGradient(p0._0, -p0._1, p1._0, -p1._1); | |
stops = fromList(grad._2); | |
} else { | |
var p0 = grad._0, p2 = grad._2; | |
g = ctx.createRadialGradient(p0._0, -p0._1, grad._1, p2._0, -p2._1, grad._3); | |
stops = fromList(grad._4); | |
} | |
var len = stops.length; | |
for (var i = 0; i < len; ++i) { | |
var stop = stops[i]; | |
g.addColorStop(stop._0, colorToCss(stop._1)); | |
} | |
return g; | |
} | |
function drawShape(redo, ctx, style, path) { | |
trace(ctx, path); | |
var sty = style.ctor; | |
ctx.fillStyle = | |
sty === 'Solid' ? colorToCss(style._0) : | |
sty === 'Texture' ? texture(redo, ctx, style._0) : gradient(ctx, style._0); | |
ctx.scale(1,-1); | |
ctx.fill(); | |
} | |
function drawImage(redo, ctx, form) { | |
var img = new Image(); | |
img.onload = redo; | |
img.src = fromString(form._3); | |
var w = form._0, | |
h = form._1, | |
pos = form._2, | |
srcX = pos._0, | |
srcY = pos._1, | |
srcW = w, | |
srcH = h, | |
destX = -w/2, | |
destY = -h/2, | |
destW = w, | |
destH = h; | |
ctx.scale(1,-1); | |
ctx.drawImage(img, srcX, srcY, srcW, srcH, destX, destY, destW, destH); | |
} | |
function renderForm(redo, ctx, form) { | |
ctx.save(); | |
var x = form.x, y = form.y, theta = form.theta, scale = form.scale; | |
if (x !== 0 || y !== 0) ctx.translate(x, y); | |
if (theta !== 0) ctx.rotate(theta); | |
if (scale !== 1) ctx.scale(scale,scale); | |
if (form.alpha !== 1) ctx.globalAlpha = ctx.globalAlpha * form.alpha; | |
ctx.beginPath(); | |
var f = form.form; | |
switch(f.ctor) { | |
case 'FPath' : drawLine(ctx, f._0, f._1); break; | |
case 'FImage': drawImage(redo, ctx, f); break; | |
case 'FShape': | |
if (f._0.ctor === 'Left') { | |
f._1.closed = true; | |
drawLine(ctx, f._0._0, f._1); | |
} else { | |
drawShape(redo, ctx, f._0._0, f._1); | |
} | |
break; | |
} | |
ctx.restore(); | |
} | |
function formToMatrix(form) { | |
var scale = form.scale; | |
var matrix = A6( Transform.matrix, scale, 0, 0, scale, form.x, form.y ); | |
var theta = form.theta | |
if (theta !== 0) | |
matrix = A2( Transform.multiply, matrix, Transform.rotation(theta) ); | |
return matrix; | |
} | |
function str(n) { | |
if (n < 0.00001 && n > -0.00001) return 0; | |
return n; | |
} | |
function makeTransform(w, h, form, matrices) { | |
var props = form.form._0.props; | |
var m = A6( Transform.matrix, 1, 0, 0, -1, | |
(w - props.width ) / 2, | |
(h - props.height) / 2 ); | |
var len = matrices.length; | |
for (var i = 0; i < len; ++i) { m = A2( Transform.multiply, m, matrices[i] ); } | |
m = A2( Transform.multiply, m, formToMatrix(form) ); | |
return 'matrix(' + str( m[0]) + ', ' + str( m[3]) + ', ' + | |
str(-m[1]) + ', ' + str(-m[4]) + ', ' + | |
str( m[2]) + ', ' + str( m[5]) + ')'; | |
} | |
function stepperHelp(list) { | |
var arr = fromList(list); | |
var i = 0; | |
function peekNext() { | |
return i < arr.length ? arr[i].form.ctor : ''; | |
} | |
// assumes that there is a next element | |
function next() { | |
var out = arr[i]; | |
++i; | |
return out; | |
} | |
return { peekNext:peekNext, next:next }; | |
} | |
function formStepper(forms) { | |
var ps = [stepperHelp(forms)]; | |
var matrices = []; | |
var alphas = []; | |
function peekNext() { | |
var len = ps.length; | |
var formType = ''; | |
for (var i = 0; i < len; ++i ) { | |
if (formType = ps[i].peekNext()) return formType; | |
} | |
return ''; | |
} | |
// assumes that there is a next element | |
function next(ctx) { | |
while (!ps[0].peekNext()) { | |
ps.shift(); | |
matrices.pop(); | |
alphas.shift(); | |
if (ctx) { ctx.restore(); } | |
} | |
var out = ps[0].next(); | |
var f = out.form; | |
if (f.ctor === 'FGroup') { | |
ps.unshift(stepperHelp(f._1)); | |
var m = A2(Transform.multiply, f._0, formToMatrix(out)); | |
ctx.save(); | |
ctx.transform(m[0], m[3], m[1], m[4], m[2], m[5]); | |
matrices.push(m); | |
var alpha = (alphas[0] || 1) * out.alpha; | |
alphas.unshift(alpha); | |
ctx.globalAlpha = alpha; | |
} | |
return out; | |
} | |
function transforms() { return matrices; } | |
function alpha() { return alphas[0] || 1; } | |
return { peekNext:peekNext, next:next, transforms:transforms, alpha:alpha }; | |
} | |
function makeCanvas(w,h) { | |
var canvas = newElement('canvas'); | |
canvas.style.width = w + 'px'; | |
canvas.style.height = h + 'px'; | |
canvas.style.display = "block"; | |
canvas.style.position = "absolute"; | |
canvas.width = w; | |
canvas.height = h; | |
return canvas; | |
} | |
function render(model) { | |
var div = newElement('div'); | |
div.style.overflow = 'hidden'; | |
div.style.position = 'relative'; | |
update(div, model, model); | |
return div; | |
} | |
function nodeStepper(w,h,div) { | |
var kids = div.childNodes; | |
var i = 0; | |
function transform(transforms, ctx) { | |
ctx.translate(w/2, h/2); | |
ctx.scale(1,-1); | |
var len = transforms.length; | |
for (var i = 0; i < len; ++i) { | |
var m = transforms[i]; | |
ctx.save(); | |
ctx.transform(m[0], m[3], m[1], m[4], m[2], m[5]); | |
} | |
return ctx; | |
} | |
function nextContext(transforms) { | |
while (i < kids.length) { | |
var node = kids[i]; | |
if (node.getContext) { | |
node.width = w; | |
node.height = h; | |
node.style.width = w + 'px'; | |
node.style.height = h + 'px'; | |
++i; | |
return transform(transforms, node.getContext('2d')); | |
} | |
div.removeChild(node); | |
} | |
var canvas = makeCanvas(w,h); | |
div.appendChild(canvas); | |
// we have added a new node, so we must step our position | |
++i; | |
return transform(transforms, canvas.getContext('2d')); | |
} | |
function addElement(matrices, alpha, form) { | |
var kid = kids[i]; | |
var elem = form.form._0; | |
var node = (!kid || kid.getContext) | |
? Render.render(elem) | |
: (Render.update(kid, kid.oldElement, elem), kids[i]); | |
node.style.position = 'absolute'; | |
node.style.opacity = alpha * form.alpha; | |
addTransform(node.style, makeTransform(w, h, form, matrices)); | |
node.oldElement = elem; | |
++i; | |
if (!kid) { | |
div.appendChild(node); | |
} else if (kid.getContext) { | |
div.insertBefore(node, kid); | |
} | |
} | |
function clearRest() { | |
while (i < kids.length) { | |
div.removeChild(kids[i]); | |
} | |
} | |
return { nextContext:nextContext, addElement:addElement, clearRest:clearRest }; | |
} | |
function update(div, _, model) { | |
var w = model.w; | |
var h = model.h; | |
var forms = formStepper(model.forms); | |
var nodes = nodeStepper(w,h,div); | |
var ctx = null; | |
var formType = ''; | |
while (formType = forms.peekNext()) { | |
// make sure we have context if we need it | |
if (ctx === null && formType !== 'FElement') { | |
ctx = nodes.nextContext(forms.transforms()); | |
ctx.globalAlpha = forms.alpha(); | |
} | |
var form = forms.next(ctx); | |
// if it is FGroup, all updates are made within formStepper when next is called. | |
if (formType === 'FElement') { | |
// update or insert an element, get a new context | |
nodes.addElement(forms.transforms(), forms.alpha(), form); | |
ctx = null; | |
} else if (formType !== 'FGroup') { | |
renderForm(function() { update(div, model, model); }, ctx, form); | |
} | |
} | |
nodes.clearRest(); | |
return false; | |
} | |
return { render:render, update:update }; | |
}; | |
</script> | |
<script type="text/javascript">Elm.Main = Elm.Main || {}; | |
Elm.Main.make = function (_elm) | |
{ | |
"use strict"; | |
_elm.Main = _elm.Main || {}; | |
if (_elm.Main.values) | |
return _elm.Main.values; | |
var _N = Elm.Native, | |
_U = _N.Utils.make(_elm), | |
_L = _N.List.make(_elm), | |
_A = _N.Array.make(_elm), | |
_E = _N.Error.make(_elm), | |
$moduleName = "Main"; | |
var Basics = Elm.Basics.make(_elm); | |
var Color = Elm.Color.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Collage = Elm.Graphics.Collage.make(_elm); | |
var Graphics = Graphics || {}; | |
Graphics.Element = Elm.Graphics.Element.make(_elm); | |
var List = Elm.List.make(_elm); | |
var Maybe = Elm.Maybe.make(_elm); | |
var Native = Native || {}; | |
Native.Json = Elm.Native.Json.make(_elm); | |
var Native = Native || {}; | |
Native.Ports = Elm.Native.Ports.make(_elm); | |
var Signal = Elm.Signal.make(_elm); | |
var String = Elm.String.make(_elm); | |
var Text = Elm.Text.make(_elm); | |
var Time = Elm.Time.make(_elm); | |
var _op = {}; | |
var longList = _L.range(1,1000000); | |
var time = Time.fps(60); | |
var sumSig = A2(Signal._op["<~"], | |
List.sum, | |
Signal.sampleOn(time)(Signal.constant(longList))); | |
var main = A2(Signal._op["<~"], | |
Text.asText, | |
A2(Signal._op["~"], | |
A2(Signal._op["<~"], | |
F2(function (v0,v1) | |
{ | |
return {ctor: "_Tuple2", _0: v0, _1: v1}; | |
}), | |
time), | |
sumSig)); | |
_elm.Main.values = {_op: _op, time: time, longList: longList, sumSig: sumSig, main: main}; | |
return _elm.Main.values; | |
}; | |
</script> | |
</head> | |
<body> | |
<script type="text/javascript">Elm.fullscreen(Elm.Main)</script> | |
<noscript></noscript> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment