From 14d50a8226b267cceabd3bf7a474aba459367f39 Mon Sep 17 00:00:00 2001 From: Brett Camper Date: Tue, 22 Sep 2015 17:18:07 -0400 Subject: [PATCH] v0.3.1 --- dist/tangram.debug.js | 12 ++++++------ dist/tangram.min.js | 4 ++-- src/utils/version.js | 4 ++-- 3 files changed, 10 insertions(+), 10 deletions(-) diff --git a/dist/tangram.debug.js b/dist/tangram.debug.js index 8089fcea4..12d60d0b9 100644 --- a/dist/tangram.debug.js +++ b/dist/tangram.debug.js @@ -28193,7 +28193,7 @@ var Scene = (function () { if (typeof this.config_source === "string") { this.config_path = config_path || Utils.pathForURL(this.config_source); } else { - this.config_path = null; + this.config_path = config_path; } return SceneLoader.loadScene(this.config_source, this.config_path).then(function (config) { @@ -36094,9 +36094,9 @@ Utils.addBaseURL = function (url, base) { Utils.pathForURL = function (url) { if (url.search(/^(data|blob):/) === -1) { - return url.substr(0, url.lastIndexOf("/") + 1); + return url.substr(0, url.lastIndexOf("/") + 1) || "./"; } - return ""; + return "./"; }; Utils.cacheBusterForUrl = function (url) { @@ -36789,10 +36789,10 @@ Utils.hashString = function (str) { var version; module.exports = version = { - string: "v0.3.0", + string: "v0.3.1", major: 0, minor: 3, - patch: 0, + patch: 1, pre: false }; @@ -37373,4 +37373,4 @@ Vector.lineIntersection = function (p1, p2, p3, p4, parallel_tolerance) { module.exports = require("./lib/babel/polyfill"); },{"./lib/babel/polyfill":1}]},{},[122,89]) -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/babel/lib/babel/polyfill.js","node_modules/babel/node_modules/core-js/shim.js","node_modules/babel/node_modules/regenerator-babel/runtime.js","node_modules/box-intersect/index.js","node_modules/box-intersect/lib/brute.js","node_modules/box-intersect/lib/intersect.js","node_modules/box-intersect/lib/median.js","node_modules/box-intersect/lib/partition.js","node_modules/box-intersect/lib/sort.js","node_modules/box-intersect/lib/sweep.js","node_modules/box-intersect/node_modules/bit-twiddle/twiddle.js","node_modules/box-intersect/node_modules/typedarray-pool/node_modules/dup/dup.js","node_modules/box-intersect/node_modules/typedarray-pool/pool.js","node_modules/browserify/node_modules/browser-resolve/empty.js","node_modules/browserify/node_modules/buffer/index.js","node_modules/browserify/node_modules/buffer/node_modules/base64-js/lib/b64.js","node_modules/browserify/node_modules/buffer/node_modules/ieee754/index.js","node_modules/browserify/node_modules/buffer/node_modules/is-array/index.js","node_modules/csscolorparser/csscolorparser.js","node_modules/earcut/src/earcut.js","node_modules/geojson-vt/src/clip.js","node_modules/geojson-vt/src/convert.js","node_modules/geojson-vt/src/index.js","node_modules/geojson-vt/src/simplify.js","node_modules/geojson-vt/src/tile.js","node_modules/geojson-vt/src/wrap.js","node_modules/gl-matrix/dist/gl-matrix.js","node_modules/gl-shader-errors/index.js","node_modules/js-yaml/index.js","node_modules/js-yaml/lib/js-yaml.js","node_modules/js-yaml/lib/js-yaml/common.js","node_modules/js-yaml/lib/js-yaml/dumper.js","node_modules/js-yaml/lib/js-yaml/exception.js","node_modules/js-yaml/lib/js-yaml/loader.js","node_modules/js-yaml/lib/js-yaml/mark.js","node_modules/js-yaml/lib/js-yaml/schema.js","node_modules/js-yaml/lib/js-yaml/schema/core.js","node_modules/js-yaml/lib/js-yaml/schema/default_full.js","node_modules/js-yaml/lib/js-yaml/schema/default_safe.js","node_modules/js-yaml/lib/js-yaml/schema/failsafe.js","node_modules/js-yaml/lib/js-yaml/schema/json.js","node_modules/js-yaml/lib/js-yaml/type.js","node_modules/js-yaml/lib/js-yaml/type/binary.js","node_modules/js-yaml/lib/js-yaml/type/bool.js","node_modules/js-yaml/lib/js-yaml/type/float.js","node_modules/js-yaml/lib/js-yaml/type/int.js","node_modules/js-yaml/lib/js-yaml/type/js/function.js","node_modules/js-yaml/lib/js-yaml/type/js/regexp.js","node_modules/js-yaml/lib/js-yaml/type/js/undefined.js","node_modules/js-yaml/lib/js-yaml/type/map.js","node_modules/js-yaml/lib/js-yaml/type/merge.js","node_modules/js-yaml/lib/js-yaml/type/null.js","node_modules/js-yaml/lib/js-yaml/type/omap.js","node_modules/js-yaml/lib/js-yaml/type/pairs.js","node_modules/js-yaml/lib/js-yaml/type/seq.js","node_modules/js-yaml/lib/js-yaml/type/set.js","node_modules/js-yaml/lib/js-yaml/type/str.js","node_modules/js-yaml/lib/js-yaml/type/timestamp.js","node_modules/js-yaml/node_modules/esprima/esprima.js","node_modules/loglevel/lib/loglevel.js","node_modules/match-feature/index.js","node_modules/pbf/buffer.js","node_modules/pbf/index.js","node_modules/strip-comments/index.js","node_modules/topojson/topojson.js","node_modules/vector-tile/index.js","node_modules/vector-tile/lib/vectortile.js","node_modules/vector-tile/lib/vectortilefeature.js","node_modules/vector-tile/lib/vectortilelayer.js","node_modules/vector-tile/node_modules/point-geometry/index.js","/Users/bcamper/Documents/dev/vector-map/src/camera.js","/Users/bcamper/Documents/dev/vector-map/src/geo.js","/Users/bcamper/Documents/dev/vector-map/src/gl/constants.js","/Users/bcamper/Documents/dev/vector-map/src/gl/context.js","/Users/bcamper/Documents/dev/vector-map/src/gl/extensions.js","/Users/bcamper/Documents/dev/vector-map/src/gl/glsl.js","/Users/bcamper/Documents/dev/vector-map/src/gl/render_state.js","/Users/bcamper/Documents/dev/vector-map/src/gl/shader_program.js","/Users/bcamper/Documents/dev/vector-map/src/gl/shader_sources.js","/Users/bcamper/Documents/dev/vector-map/src/gl/texture.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vao.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vbo_mesh.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vertex_data.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vertex_layout.js","/Users/bcamper/Documents/dev/vector-map/src/leaflet_layer.js","/Users/bcamper/Documents/dev/vector-map/src/light.js","/Users/bcamper/Documents/dev/vector-map/src/material.js","/Users/bcamper/Documents/dev/vector-map/src/module.js","/Users/bcamper/Documents/dev/vector-map/src/scene.js","/Users/bcamper/Documents/dev/vector-map/src/scene_loader.js","/Users/bcamper/Documents/dev/vector-map/src/scene_worker.js","/Users/bcamper/Documents/dev/vector-map/src/selection.js","/Users/bcamper/Documents/dev/vector-map/src/sources/data_source.js","/Users/bcamper/Documents/dev/vector-map/src/sources/geojson.js","/Users/bcamper/Documents/dev/vector-map/src/sources/mvt.js","/Users/bcamper/Documents/dev/vector-map/src/sources/topojson.js","/Users/bcamper/Documents/dev/vector-map/src/styles/builders.js","/Users/bcamper/Documents/dev/vector-map/src/styles/lines/lines.js","/Users/bcamper/Documents/dev/vector-map/src/styles/points/points.js","/Users/bcamper/Documents/dev/vector-map/src/styles/polygons/polygons.js","/Users/bcamper/Documents/dev/vector-map/src/styles/rule.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style_manager.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style_parser.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/feature_label.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_builder.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_line.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_options.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_point.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text.js","/Users/bcamper/Documents/dev/vector-map/src/tile.js","/Users/bcamper/Documents/dev/vector-map/src/tile_manager.js","/Users/bcamper/Documents/dev/vector-map/src/utils/errors.js","/Users/bcamper/Documents/dev/vector-map/src/utils/obb.js","/Users/bcamper/Documents/dev/vector-map/src/utils/subscribe.js","/Users/bcamper/Documents/dev/vector-map/src/utils/utils.js","/Users/bcamper/Documents/dev/vector-map/src/utils/version.js","/Users/bcamper/Documents/dev/vector-map/src/utils/worker_broker.js","/Users/bcamper/Documents/dev/vector-map/src/vector.js","node_modules/babel/polyfill.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACz7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5hBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7eA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxNA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5hCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjkBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC10BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACljDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzsKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACthBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;IClIO,GAAG,2BAAM,OAAO;;IAChB,KAAK,2BAAM,eAAe;;IAC1B,aAAa,2BAAM,qBAAqB;;IAExC,QAAQ,2BAAM,WAAW;;AAChC,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;AACzB,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;;;;IAGJ,MAAM;AAEZ,aAFM,MAAM,CAEX,IAAI,EAAE,KAAK,EAAgB;YAAd,OAAO,gCAAG,EAAE;;8BAFpB,MAAM;;AAGnB,YAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,YAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;AACjC,YAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;;KAE5B;;iBAPgB,MAAM;AAwBvB,cAAM;;;;mBAAA,kBAAG,EAER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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function (global){\n\"use strict\";\n\nif (global._babelPolyfill) {\n  throw new Error(\"only one instance of babel/polyfill is allowed\");\n}\nglobal._babelPolyfill = true;\n\nrequire(\"core-js/shim\");\n\nrequire(\"regenerator-babel/runtime\");\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9iYWJlbC9saWIvYmFiZWwvcG9seWZpbGwuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaWYgKGdsb2JhbC5fYmFiZWxQb2x5ZmlsbCkge1xuICB0aHJvdyBuZXcgRXJyb3IoXCJvbmx5IG9uZSBpbnN0YW5jZSBvZiBiYWJlbC9wb2x5ZmlsbCBpcyBhbGxvd2VkXCIpO1xufVxuZ2xvYmFsLl9iYWJlbFBvbHlmaWxsID0gdHJ1ZTtcblxucmVxdWlyZShcImNvcmUtanMvc2hpbVwiKTtcblxucmVxdWlyZShcInJlZ2VuZXJhdG9yLWJhYmVsL3J1bnRpbWVcIik7Il19","/**\n * Core.js 0.6.1\n * https://github.com/zloirock/core-js\n * License: http://rock.mit-license.org\n * © 2015 Denis Pushkarev\n */\n!function(global, framework, undefined){\n'use strict';\n\n/******************************************************************************\n * Module : common                                                            *\n ******************************************************************************/\n\n  // Shortcuts for [[Class]] & property names\r\nvar OBJECT          = 'Object'\r\n  , FUNCTION        = 'Function'\r\n  , ARRAY           = 'Array'\r\n  , STRING          = 'String'\r\n  , NUMBER          = 'Number'\r\n  , REGEXP          = 'RegExp'\r\n  , DATE            = 'Date'\r\n  , MAP             = 'Map'\r\n  , SET             = 'Set'\r\n  , WEAKMAP         = 'WeakMap'\r\n  , WEAKSET         = 'WeakSet'\r\n  , SYMBOL          = 'Symbol'\r\n  , PROMISE         = 'Promise'\r\n  , MATH            = 'Math'\r\n  , ARGUMENTS       = 'Arguments'\r\n  , PROTOTYPE       = 'prototype'\r\n  , CONSTRUCTOR     = 'constructor'\r\n  , TO_STRING       = 'toString'\r\n  , TO_STRING_TAG   = TO_STRING + 'Tag'\r\n  , TO_LOCALE       = 'toLocaleString'\r\n  , HAS_OWN         = 'hasOwnProperty'\r\n  , FOR_EACH        = 'forEach'\r\n  , ITERATOR        = 'iterator'\r\n  , FF_ITERATOR     = '@@' + ITERATOR\r\n  , PROCESS         = 'process'\r\n  , CREATE_ELEMENT  = 'createElement'\r\n  // Aliases global objects and prototypes\r\n  , Function        = global[FUNCTION]\r\n  , Object          = global[OBJECT]\r\n  , Array           = global[ARRAY]\r\n  , String          = global[STRING]\r\n  , Number          = global[NUMBER]\r\n  , RegExp          = global[REGEXP]\r\n  , Date            = global[DATE]\r\n  , Map             = global[MAP]\r\n  , Set             = global[SET]\r\n  , WeakMap         = global[WEAKMAP]\r\n  , WeakSet         = global[WEAKSET]\r\n  , Symbol          = global[SYMBOL]\r\n  , Math            = global[MATH]\r\n  , TypeError       = global.TypeError\r\n  , RangeError      = global.RangeError\r\n  , setTimeout      = global.setTimeout\r\n  , setImmediate    = global.setImmediate\r\n  , clearImmediate  = global.clearImmediate\r\n  , parseInt        = global.parseInt\r\n  , isFinite        = global.isFinite\r\n  , process         = global[PROCESS]\r\n  , nextTick        = process && process.nextTick\r\n  , document        = global.document\r\n  , html            = document && document.documentElement\r\n  , navigator       = global.navigator\r\n  , define          = global.define\r\n  , console         = global.console || {}\r\n  , ArrayProto      = Array[PROTOTYPE]\r\n  , ObjectProto     = Object[PROTOTYPE]\r\n  , FunctionProto   = Function[PROTOTYPE]\r\n  , Infinity        = 1 / 0\r\n  , DOT             = '.';\r\n\r\n// http://jsperf.com/core-js-isobject\r\nfunction isObject(it){\r\n  return it !== null && (typeof it == 'object' || typeof it == 'function');\r\n}\r\nfunction isFunction(it){\r\n  return typeof it == 'function';\r\n}\r\n// Native function?\r\nvar isNative = ctx(/./.test, /\\[native code\\]\\s*\\}\\s*$/, 1);\r\n\r\n// Object internal [[Class]] or toStringTag\r\n// http://people.mozilla.org/~jorendorff/es6-draft.html#sec-object.prototype.tostring\r\nvar toString = ObjectProto[TO_STRING];\r\nfunction setToStringTag(it, tag, stat){\r\n  if(it && !has(it = stat ? it : it[PROTOTYPE], SYMBOL_TAG))hidden(it, SYMBOL_TAG, tag);\r\n}\r\nfunction cof(it){\r\n  return toString.call(it).slice(8, -1);\r\n}\r\nfunction classof(it){\r\n  var O, T;\r\n  return it == undefined ? it === undefined ? 'Undefined' : 'Null'\r\n    : typeof (T = (O = Object(it))[SYMBOL_TAG]) == 'string' ? T : cof(O);\r\n}\r\n\r\n// Function\r\nvar call  = FunctionProto.call\r\n  , apply = FunctionProto.apply\r\n  , REFERENCE_GET;\r\n// Partial apply\r\nfunction part(/* ...args */){\r\n  var fn     = assertFunction(this)\r\n    , length = arguments.length\r\n    , args   = Array(length)\r\n    , i      = 0\r\n    , _      = path._\r\n    , holder = false;\r\n  while(length > i)if((args[i] = arguments[i++]) === _)holder = true;\r\n  return function(/* ...args */){\r\n    var that    = this\r\n      , _length = arguments.length\r\n      , i = 0, j = 0, _args;\r\n    if(!holder && !_length)return invoke(fn, args, that);\r\n    _args = args.slice();\r\n    if(holder)for(;length > i; i++)if(_args[i] === _)_args[i] = arguments[j++];\r\n    while(_length > j)_args.push(arguments[j++]);\r\n    return invoke(fn, _args, that);\r\n  }\r\n}\r\n// Optional / simple context binding\r\nfunction ctx(fn, that, length){\r\n  assertFunction(fn);\r\n  if(~length && that === undefined)return fn;\r\n  switch(length){\r\n    case 1: return function(a){\r\n      return fn.call(that, a);\r\n    }\r\n    case 2: return function(a, b){\r\n      return fn.call(that, a, b);\r\n    }\r\n    case 3: return function(a, b, c){\r\n      return fn.call(that, a, b, c);\r\n    }\r\n  } return function(/* ...args */){\r\n      return fn.apply(that, arguments);\r\n  }\r\n}\r\n// Fast apply\r\n// http://jsperf.lnkit.com/fast-apply/5\r\nfunction invoke(fn, args, that){\r\n  var un = that === undefined;\r\n  switch(args.length | 0){\r\n    case 0: return un ? fn()\r\n                      : fn.call(that);\r\n    case 1: return un ? fn(args[0])\r\n                      : fn.call(that, args[0]);\r\n    case 2: return un ? fn(args[0], args[1])\r\n                      : fn.call(that, args[0], args[1]);\r\n    case 3: return un ? fn(args[0], args[1], args[2])\r\n                      : fn.call(that, args[0], args[1], args[2]);\r\n    case 4: return un ? fn(args[0], args[1], args[2], args[3])\r\n                      : fn.call(that, args[0], args[1], args[2], args[3]);\r\n    case 5: return un ? fn(args[0], args[1], args[2], args[3], args[4])\r\n                      : fn.call(that, args[0], args[1], args[2], args[3], args[4]);\r\n  } return              fn.apply(that, args);\r\n}\r\n\r\n// Object:\r\nvar create           = Object.create\r\n  , getPrototypeOf   = Object.getPrototypeOf\r\n  , setPrototypeOf   = Object.setPrototypeOf\r\n  , defineProperty   = Object.defineProperty\r\n  , defineProperties = Object.defineProperties\r\n  , getOwnDescriptor = Object.getOwnPropertyDescriptor\r\n  , getKeys          = Object.keys\r\n  , getNames         = Object.getOwnPropertyNames\r\n  , getSymbols       = Object.getOwnPropertySymbols\r\n  , isFrozen         = Object.isFrozen\r\n  , has              = ctx(call, ObjectProto[HAS_OWN], 2)\r\n  // Dummy, fix for not array-like ES3 string in es5 module\r\n  , ES5Object        = Object\r\n  , Dict;\r\nfunction toObject(it){\r\n  return ES5Object(assertDefined(it));\r\n}\r\nfunction returnIt(it){\r\n  return it;\r\n}\r\nfunction returnThis(){\r\n  return this;\r\n}\r\nfunction get(object, key){\r\n  if(has(object, key))return object[key];\r\n}\r\nfunction ownKeys(it){\r\n  assertObject(it);\r\n  return getSymbols ? getNames(it).concat(getSymbols(it)) : getNames(it);\r\n}\r\n// 19.1.2.1 Object.assign(target, source, ...)\r\nvar assign = Object.assign || function(target, source){\r\n  var T = Object(assertDefined(target))\r\n    , l = arguments.length\r\n    , i = 1;\r\n  while(l > i){\r\n    var S      = ES5Object(arguments[i++])\r\n      , keys   = getKeys(S)\r\n      , length = keys.length\r\n      , j      = 0\r\n      , key;\r\n    while(length > j)T[key = keys[j++]] = S[key];\r\n  }\r\n  return T;\r\n}\r\nfunction keyOf(object, el){\r\n  var O      = toObject(object)\r\n    , keys   = getKeys(O)\r\n    , length = keys.length\r\n    , index  = 0\r\n    , key;\r\n  while(length > index)if(O[key = keys[index++]] === el)return key;\r\n}\r\n\r\n// Array\r\n// array('str1,str2,str3') => ['str1', 'str2', 'str3']\r\nfunction array(it){\r\n  return String(it).split(',');\r\n}\r\nvar push    = ArrayProto.push\r\n  , unshift = ArrayProto.unshift\r\n  , slice   = ArrayProto.slice\r\n  , splice  = ArrayProto.splice\r\n  , indexOf = ArrayProto.indexOf\r\n  , forEach = ArrayProto[FOR_EACH];\r\n/*\r\n * 0 -> forEach\r\n * 1 -> map\r\n * 2 -> filter\r\n * 3 -> some\r\n * 4 -> every\r\n * 5 -> find\r\n * 6 -> findIndex\r\n */\r\nfunction createArrayMethod(type){\r\n  var isMap       = type == 1\r\n    , isFilter    = type == 2\r\n    , isSome      = type == 3\r\n    , isEvery     = type == 4\r\n    , isFindIndex = type == 6\r\n    , noholes     = type == 5 || isFindIndex;\r\n  return function(callbackfn/*, that = undefined */){\r\n    var O      = Object(assertDefined(this))\r\n      , that   = arguments[1]\r\n      , self   = ES5Object(O)\r\n      , f      = ctx(callbackfn, that, 3)\r\n      , length = toLength(self.length)\r\n      , index  = 0\r\n      , result = isMap ? Array(length) : isFilter ? [] : undefined\r\n      , val, res;\r\n    for(;length > index; index++)if(noholes || index in self){\r\n      val = self[index];\r\n      res = f(val, index, O);\r\n      if(type){\r\n        if(isMap)result[index] = res;             // map\r\n        else if(res)switch(type){\r\n          case 3: return true;                    // some\r\n          case 5: return val;                     // find\r\n          case 6: return index;                   // findIndex\r\n          case 2: result.push(val);               // filter\r\n        } else if(isEvery)return false;           // every\r\n      }\r\n    }\r\n    return isFindIndex ? -1 : isSome || isEvery ? isEvery : result;\r\n  }\r\n}\r\nfunction createArrayContains(isContains){\r\n  return function(el /*, fromIndex = 0 */){\r\n    var O      = toObject(this)\r\n      , length = toLength(O.length)\r\n      , index  = toIndex(arguments[1], length);\r\n    if(isContains && el != el){\r\n      for(;length > index; index++)if(sameNaN(O[index]))return isContains || index;\r\n    } else for(;length > index; index++)if(isContains || index in O){\r\n      if(O[index] === el)return isContains || index;\r\n    } return !isContains && -1;\r\n  }\r\n}\r\nfunction generic(A, B){\r\n  // strange IE quirks mode bug -> use typeof vs isFunction\r\n  return typeof A == 'function' ? A : B;\r\n}\r\n\r\n// Math\r\nvar MAX_SAFE_INTEGER = 0x1fffffffffffff // pow(2, 53) - 1 == 9007199254740991\r\n  , pow    = Math.pow\r\n  , abs    = Math.abs\r\n  , ceil   = Math.ceil\r\n  , floor  = Math.floor\r\n  , max    = Math.max\r\n  , min    = Math.min\r\n  , random = Math.random\r\n  , trunc  = Math.trunc || function(it){\r\n      return (it > 0 ? floor : ceil)(it);\r\n    }\r\n// 20.1.2.4 Number.isNaN(number)\r\nfunction sameNaN(number){\r\n  return number != number;\r\n}\r\n// 7.1.4 ToInteger\r\nfunction toInteger(it){\r\n  return isNaN(it) ? 0 : trunc(it);\r\n}\r\n// 7.1.15 ToLength\r\nfunction toLength(it){\r\n  return it > 0 ? min(toInteger(it), MAX_SAFE_INTEGER) : 0;\r\n}\r\nfunction toIndex(index, length){\r\n  var index = toInteger(index);\r\n  return index < 0 ? max(index + length, 0) : min(index, length);\r\n}\r\nfunction lz(num){\r\n  return num > 9 ? num : '0' + num;\r\n}\r\n\r\nfunction createReplacer(regExp, replace, isStatic){\r\n  var replacer = isObject(replace) ? function(part){\r\n    return replace[part];\r\n  } : replace;\r\n  return function(it){\r\n    return String(isStatic ? it : this).replace(regExp, replacer);\r\n  }\r\n}\r\nfunction createPointAt(toString){\r\n  return function(pos){\r\n    var s = String(assertDefined(this))\r\n      , i = toInteger(pos)\r\n      , l = s.length\r\n      , a, b;\r\n    if(i < 0 || i >= l)return toString ? '' : undefined;\r\n    a = s.charCodeAt(i);\r\n    return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\r\n      ? toString ? s.charAt(i) : a\r\n      : toString ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\r\n  }\r\n}\r\n\r\n// Assertion & errors\r\nvar REDUCE_ERROR = 'Reduce of empty object with no initial value';\r\nfunction assert(condition, msg1, msg2){\r\n  if(!condition)throw TypeError(msg2 ? msg1 + msg2 : msg1);\r\n}\r\nfunction assertDefined(it){\r\n  if(it == undefined)throw TypeError('Function called on null or undefined');\r\n  return it;\r\n}\r\nfunction assertFunction(it){\r\n  assert(isFunction(it), it, ' is not a function!');\r\n  return it;\r\n}\r\nfunction assertObject(it){\r\n  assert(isObject(it), it, ' is not an object!');\r\n  return it;\r\n}\r\nfunction assertInstance(it, Constructor, name){\r\n  assert(it instanceof Constructor, name, \": use the 'new' operator!\");\r\n}\r\n\r\n// Property descriptors & Symbol\r\nfunction descriptor(bitmap, value){\r\n  return {\r\n    enumerable  : !(bitmap & 1),\r\n    configurable: !(bitmap & 2),\r\n    writable    : !(bitmap & 4),\r\n    value       : value\r\n  }\r\n}\r\nfunction simpleSet(object, key, value){\r\n  object[key] = value;\r\n  return object;\r\n}\r\nfunction createDefiner(bitmap){\r\n  return DESC ? function(object, key, value){\r\n    return defineProperty(object, key, descriptor(bitmap, value));\r\n  } : simpleSet;\r\n}\r\nfunction uid(key){\r\n  return SYMBOL + '(' + key + ')_' + (++sid + random())[TO_STRING](36);\r\n}\r\nfunction getWellKnownSymbol(name, setter){\r\n  return (Symbol && Symbol[name]) || (setter ? Symbol : safeSymbol)(SYMBOL + DOT + name);\r\n}\r\n// The engine works fine with descriptors? Thank's IE8 for his funny defineProperty.\r\nvar DESC = !!function(){\r\n      try {\r\n        return defineProperty({}, 'a', {get: function(){ return 2 }}).a == 2;\r\n      } catch(e){}\r\n    }()\r\n  , sid    = 0\r\n  , hidden = createDefiner(1)\r\n  , set    = Symbol ? simpleSet : hidden\r\n  , safeSymbol = Symbol || uid;\r\nfunction assignHidden(target, src){\r\n  for(var key in src)hidden(target, key, src[key]);\r\n  return target;\r\n}\r\n\r\nvar SYMBOL_UNSCOPABLES = getWellKnownSymbol('unscopables')\r\n  , ArrayUnscopables   = ArrayProto[SYMBOL_UNSCOPABLES] || {}\r\n  , SYMBOL_TAG         = getWellKnownSymbol(TO_STRING_TAG)\r\n  , SYMBOL_SPECIES     = getWellKnownSymbol('species')\r\n  , SYMBOL_ITERATOR;\r\nfunction setSpecies(C){\r\n  if(DESC && (framework || !isNative(C)))defineProperty(C, SYMBOL_SPECIES, {\r\n    configurable: true,\r\n    get: returnThis\r\n  });\r\n}\n\n/******************************************************************************\n * Module : common.export                                                     *\n ******************************************************************************/\n\nvar NODE = cof(process) == PROCESS\r\n  , core = {}\r\n  , path = framework ? global : core\r\n  , old  = global.core\r\n  , exportGlobal\r\n  // type bitmap\r\n  , FORCED = 1\r\n  , GLOBAL = 2\r\n  , STATIC = 4\r\n  , PROTO  = 8\r\n  , BIND   = 16\r\n  , WRAP   = 32;\r\nfunction $define(type, name, source){\r\n  var key, own, out, exp\r\n    , isGlobal = type & GLOBAL\r\n    , target   = isGlobal ? global : (type & STATIC)\r\n        ? global[name] : (global[name] || ObjectProto)[PROTOTYPE]\r\n    , exports  = isGlobal ? core : core[name] || (core[name] = {});\r\n  if(isGlobal)source = name;\r\n  for(key in source){\r\n    // there is a similar native\r\n    own = !(type & FORCED) && target && key in target\r\n      && (!isFunction(target[key]) || isNative(target[key]));\r\n    // export native or passed\r\n    out = (own ? target : source)[key];\r\n    // prevent global pollution for namespaces\r\n    if(!framework && isGlobal && !isFunction(target[key]))exp = source[key];\r\n    // bind timers to global for call from export context\r\n    else if(type & BIND && own)exp = ctx(out, global);\r\n    // wrap global constructors for prevent change them in library\r\n    else if(type & WRAP && !framework && target[key] == out){\r\n      exp = function(param){\r\n        return this instanceof out ? new out(param) : out(param);\r\n      }\r\n      exp[PROTOTYPE] = out[PROTOTYPE];\r\n    } else exp = type & PROTO && isFunction(out) ? ctx(call, out) : out;\r\n    // extend global\r\n    if(framework && target && !own){\r\n      if(isGlobal)target[key] = out;\r\n      else delete target[key] && hidden(target, key, out);\r\n    }\r\n    // export\r\n    if(exports[key] != out)hidden(exports, key, exp);\r\n  }\r\n}\r\n// CommonJS export\r\nif(typeof module != 'undefined' && module.exports)module.exports = core;\r\n// RequireJS export\r\nelse if(isFunction(define) && define.amd)define(function(){return core});\r\n// Export to global object\r\nelse exportGlobal = true;\r\nif(exportGlobal || framework){\r\n  core.noConflict = function(){\r\n    global.core = old;\r\n    return core;\r\n  }\r\n  global.core = core;\r\n}\n\n/******************************************************************************\n * Module : common.iterators                                                  *\n ******************************************************************************/\n\nSYMBOL_ITERATOR = getWellKnownSymbol(ITERATOR);\r\nvar ITER  = safeSymbol('iter')\r\n  , KEY   = 1\r\n  , VALUE = 2\r\n  , Iterators = {}\r\n  , IteratorPrototype = {}\r\n    // Safari has byggy iterators w/o `next`\r\n  , BUGGY_ITERATORS = 'keys' in ArrayProto && !('next' in [].keys());\r\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\r\nsetIterator(IteratorPrototype, returnThis);\r\nfunction setIterator(O, value){\r\n  hidden(O, SYMBOL_ITERATOR, value);\r\n  // Add iterator for FF iterator protocol\r\n  FF_ITERATOR in ArrayProto && hidden(O, FF_ITERATOR, value);\r\n}\r\nfunction createIterator(Constructor, NAME, next, proto){\r\n  Constructor[PROTOTYPE] = create(proto || IteratorPrototype, {next: descriptor(1, next)});\r\n  setToStringTag(Constructor, NAME + ' Iterator');\r\n}\r\nfunction defineIterator(Constructor, NAME, value, DEFAULT){\r\n  var proto = Constructor[PROTOTYPE]\r\n    , iter  = get(proto, SYMBOL_ITERATOR) || get(proto, FF_ITERATOR) || (DEFAULT && get(proto, DEFAULT)) || value;\r\n  if(framework){\r\n    // Define iterator\r\n    setIterator(proto, iter);\r\n    if(iter !== value){\r\n      var iterProto = getPrototypeOf(iter.call(new Constructor));\r\n      // Set @@toStringTag to native iterators\r\n      setToStringTag(iterProto, NAME + ' Iterator', true);\r\n      // FF fix\r\n      has(proto, FF_ITERATOR) && setIterator(iterProto, returnThis);\r\n    }\r\n  }\r\n  // Plug for library\r\n  Iterators[NAME] = iter;\r\n  // FF & v8 fix\r\n  Iterators[NAME + ' Iterator'] = returnThis;\r\n  return iter;\r\n}\r\nfunction defineStdIterators(Base, NAME, Constructor, next, DEFAULT, IS_SET){\r\n  function createIter(kind){\r\n    return function(){\r\n      return new Constructor(this, kind);\r\n    }\r\n  }\r\n  createIterator(Constructor, NAME, next);\r\n  var entries = createIter(KEY+VALUE)\r\n    , values  = createIter(VALUE);\r\n  if(DEFAULT == VALUE)values = defineIterator(Base, NAME, values, 'values');\r\n  else entries = defineIterator(Base, NAME, entries, 'entries');\r\n  if(DEFAULT){\r\n    $define(PROTO + FORCED * BUGGY_ITERATORS, NAME, {\r\n      entries: entries,\r\n      keys: IS_SET ? values : createIter(KEY),\r\n      values: values\r\n    });\r\n  }\r\n}\r\nfunction iterResult(done, value){\r\n  return {value: value, done: !!done};\r\n}\r\nfunction isIterable(it){\r\n  var O      = Object(it)\r\n    , Symbol = global[SYMBOL]\r\n    , hasExt = (Symbol && Symbol[ITERATOR] || FF_ITERATOR) in O;\r\n  return hasExt || SYMBOL_ITERATOR in O || has(Iterators, classof(O));\r\n}\r\nfunction getIterator(it){\r\n  var Symbol  = global[SYMBOL]\r\n    , ext     = it[Symbol && Symbol[ITERATOR] || FF_ITERATOR]\r\n    , getIter = ext || it[SYMBOL_ITERATOR] || Iterators[classof(it)];\r\n  return assertObject(getIter.call(it));\r\n}\r\nfunction stepCall(fn, value, entries){\r\n  return entries ? invoke(fn, value) : fn(value);\r\n}\r\nfunction checkDangerIterClosing(fn){\r\n  var danger = true;\r\n  var O = {\r\n    next: function(){ throw 1 },\r\n    'return': function(){ danger = false }\r\n  };\r\n  O[SYMBOL_ITERATOR] = returnThis;\r\n  try {\r\n    fn(O);\r\n  } catch(e){}\r\n  return danger;\r\n}\r\nfunction closeIterator(iterator){\r\n  var ret = iterator['return'];\r\n  if(ret !== undefined)ret.call(iterator);\r\n}\r\nfunction safeIterClose(exec, iterator){\r\n  try {\r\n    exec(iterator);\r\n  } catch(e){\r\n    closeIterator(iterator);\r\n    throw e;\r\n  }\r\n}\r\nfunction forOf(iterable, entries, fn, that){\r\n  safeIterClose(function(iterator){\r\n    var f = ctx(fn, that, entries ? 2 : 1)\r\n      , step;\r\n    while(!(step = iterator.next()).done)if(stepCall(f, step.value, entries) === false){\r\n      return closeIterator(iterator);\r\n    }\r\n  }, getIterator(iterable));\r\n}\n\n/******************************************************************************\n * Module : es6.symbol                                                        *\n ******************************************************************************/\n\n// ECMAScript 6 symbols shim\r\n!function(TAG, SymbolRegistry, AllSymbols, setter){\r\n  // 19.4.1.1 Symbol([description])\r\n  if(!isNative(Symbol)){\r\n    Symbol = function(description){\r\n      assert(!(this instanceof Symbol), SYMBOL + ' is not a ' + CONSTRUCTOR);\r\n      var tag = uid(description)\r\n        , sym = set(create(Symbol[PROTOTYPE]), TAG, tag);\r\n      AllSymbols[tag] = sym;\r\n      DESC && setter && defineProperty(ObjectProto, tag, {\r\n        configurable: true,\r\n        set: function(value){\r\n          hidden(this, tag, value);\r\n        }\r\n      });\r\n      return sym;\r\n    }\r\n    hidden(Symbol[PROTOTYPE], TO_STRING, function(){\r\n      return this[TAG];\r\n    });\r\n  }\r\n  $define(GLOBAL + WRAP, {Symbol: Symbol});\r\n  \r\n  var symbolStatics = {\r\n    // 19.4.2.1 Symbol.for(key)\r\n    'for': function(key){\r\n      return has(SymbolRegistry, key += '')\r\n        ? SymbolRegistry[key]\r\n        : SymbolRegistry[key] = Symbol(key);\r\n    },\r\n    // 19.4.2.4 Symbol.iterator\r\n    iterator: SYMBOL_ITERATOR || getWellKnownSymbol(ITERATOR),\r\n    // 19.4.2.5 Symbol.keyFor(sym)\r\n    keyFor: part.call(keyOf, SymbolRegistry),\r\n    // 19.4.2.10 Symbol.species\r\n    species: SYMBOL_SPECIES,\r\n    // 19.4.2.13 Symbol.toStringTag\r\n    toStringTag: SYMBOL_TAG = getWellKnownSymbol(TO_STRING_TAG, true),\r\n    // 19.4.2.14 Symbol.unscopables\r\n    unscopables: SYMBOL_UNSCOPABLES,\r\n    pure: safeSymbol,\r\n    set: set,\r\n    useSetter: function(){setter = true},\r\n    useSimple: function(){setter = false}\r\n  };\r\n  // 19.4.2.2 Symbol.hasInstance\r\n  // 19.4.2.3 Symbol.isConcatSpreadable\r\n  // 19.4.2.6 Symbol.match\r\n  // 19.4.2.8 Symbol.replace\r\n  // 19.4.2.9 Symbol.search\r\n  // 19.4.2.11 Symbol.split\r\n  // 19.4.2.12 Symbol.toPrimitive\r\n  forEach.call(array('hasInstance,isConcatSpreadable,match,replace,search,split,toPrimitive'),\r\n    function(it){\r\n      symbolStatics[it] = getWellKnownSymbol(it);\r\n    }\r\n  );\r\n  $define(STATIC, SYMBOL, symbolStatics);\r\n  \r\n  setToStringTag(Symbol, SYMBOL);\r\n  \r\n  $define(STATIC + FORCED * !isNative(Symbol), OBJECT, {\r\n    // 19.1.2.7 Object.getOwnPropertyNames(O)\r\n    getOwnPropertyNames: function(it){\r\n      var names = getNames(toObject(it)), result = [], key, i = 0;\r\n      while(names.length > i)has(AllSymbols, key = names[i++]) || result.push(key);\r\n      return result;\r\n    },\r\n    // 19.1.2.8 Object.getOwnPropertySymbols(O)\r\n    getOwnPropertySymbols: function(it){\r\n      var names = getNames(toObject(it)), result = [], key, i = 0;\r\n      while(names.length > i)has(AllSymbols, key = names[i++]) && result.push(AllSymbols[key]);\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  // 20.2.1.9 Math[@@toStringTag]\r\n  setToStringTag(Math, MATH, true);\r\n  // 24.3.3 JSON[@@toStringTag]\r\n  setToStringTag(global.JSON, 'JSON', true);\r\n}(safeSymbol('tag'), {}, {}, true);\n\n/******************************************************************************\n * Module : es6.object.statics                                                *\n ******************************************************************************/\n\n!function(){\r\n  var objectStatic = {\r\n    // 19.1.3.1 Object.assign(target, source)\r\n    assign: assign,\r\n    // 19.1.3.10 Object.is(value1, value2)\r\n    is: function(x, y){\r\n      return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\r\n    }\r\n  };\r\n  // 19.1.3.19 Object.setPrototypeOf(O, proto)\r\n  // Works with __proto__ only. Old v8 can't works with null proto objects.\r\n  '__proto__' in ObjectProto && function(buggy, set){\r\n    try {\r\n      set = ctx(call, getOwnDescriptor(ObjectProto, '__proto__').set, 2);\r\n      set({}, ArrayProto);\r\n    } catch(e){ buggy = true }\r\n    objectStatic.setPrototypeOf = setPrototypeOf = setPrototypeOf || function(O, proto){\r\n      assertObject(O);\r\n      assert(proto === null || isObject(proto), proto, \": can't set as prototype!\");\r\n      if(buggy)O.__proto__ = proto;\r\n      else set(O, proto);\r\n      return O;\r\n    }\r\n  }();\r\n  $define(STATIC, OBJECT, objectStatic);\r\n}();\n\n/******************************************************************************\n * Module : es6.object.prototype                                              *\n ******************************************************************************/\n\n!function(tmp){\r\n  // 19.1.3.6 Object.prototype.toString()\r\n  tmp[SYMBOL_TAG] = DOT;\r\n  if(cof(tmp) != DOT)hidden(ObjectProto, TO_STRING, function(){\r\n    return '[object ' + classof(this) + ']';\r\n  });\r\n}({});\n\n/******************************************************************************\n * Module : es6.object.statics-accept-primitives                              *\n ******************************************************************************/\n\n!function(){\r\n  // Object static methods accept primitives\r\n  function wrapObjectMethod(key, MODE){\r\n    var fn  = Object[key]\r\n      , exp = core[OBJECT][key]\r\n      , f   = 0\r\n      , o   = {};\r\n    if(!exp || isNative(exp)){\r\n      o[key] = MODE == 1 ? function(it){\r\n        return isObject(it) ? fn(it) : it;\r\n      } : MODE == 2 ? function(it){\r\n        return isObject(it) ? fn(it) : true;\r\n      } : MODE == 3 ? function(it){\r\n        return isObject(it) ? fn(it) : false;\r\n      } : MODE == 4 ? function(it, key){\r\n        return fn(toObject(it), key);\r\n      } : function(it){\r\n        return fn(toObject(it));\r\n      };\r\n      try { fn(DOT) }\r\n      catch(e){ f = 1 }\r\n      $define(STATIC + FORCED * f, OBJECT, o);\r\n    }\r\n  }\r\n  wrapObjectMethod('freeze', 1);\r\n  wrapObjectMethod('seal', 1);\r\n  wrapObjectMethod('preventExtensions', 1);\r\n  wrapObjectMethod('isFrozen', 2);\r\n  wrapObjectMethod('isSealed', 2);\r\n  wrapObjectMethod('isExtensible', 3);\r\n  wrapObjectMethod('getOwnPropertyDescriptor', 4);\r\n  wrapObjectMethod('getPrototypeOf');\r\n  wrapObjectMethod('keys');\r\n  wrapObjectMethod('getOwnPropertyNames');\r\n}();\n\n/******************************************************************************\n * Module : es6.function                                                      *\n ******************************************************************************/\n\n!function(NAME){\r\n  // 19.2.4.2 name\r\n  NAME in FunctionProto || (DESC && defineProperty(FunctionProto, NAME, {\r\n    configurable: true,\r\n    get: function(){\r\n      var match = String(this).match(/^\\s*function ([^ (]*)/)\r\n        , name  = match ? match[1] : '';\r\n      has(this, NAME) || defineProperty(this, NAME, descriptor(5, name));\r\n      return name;\r\n    },\r\n    set: function(value){\r\n      has(this, NAME) || defineProperty(this, NAME, descriptor(0, value));\r\n    }\r\n  }));\r\n}('name');\n\n/******************************************************************************\n * Module : es6.number.constructor                                            *\n ******************************************************************************/\n\nNumber('0o1') && Number('0b1') || function(_Number, NumberProto){\r\n  function toNumber(it){\r\n    if(isObject(it))it = toPrimitive(it);\r\n    if(typeof it == 'string' && it.length > 2 && it.charCodeAt(0) == 48){\r\n      var binary = false;\r\n      switch(it.charCodeAt(1)){\r\n        case 66 : case 98  : binary = true;\r\n        case 79 : case 111 : return parseInt(it.slice(2), binary ? 2 : 8);\r\n      }\r\n    } return +it;\r\n  }\r\n  function toPrimitive(it){\r\n    var fn, val;\r\n    if(isFunction(fn = it.valueOf) && !isObject(val = fn.call(it)))return val;\r\n    if(isFunction(fn = it[TO_STRING]) && !isObject(val = fn.call(it)))return val;\r\n    throw TypeError(\"Can't convert object to number\");\r\n  }\r\n  Number = function Number(it){\r\n    return this instanceof Number ? new _Number(toNumber(it)) : toNumber(it);\r\n  }\r\n  forEach.call(DESC ? getNames(_Number)\r\n  : array('MAX_VALUE,MIN_VALUE,NaN,NEGATIVE_INFINITY,POSITIVE_INFINITY'), function(key){\r\n    key in Number || defineProperty(Number, key, getOwnDescriptor(_Number, key));\r\n  });\r\n  Number[PROTOTYPE] = NumberProto;\r\n  NumberProto[CONSTRUCTOR] = Number;\r\n  hidden(global, NUMBER, Number);\r\n}(Number, Number[PROTOTYPE]);\n\n/******************************************************************************\n * Module : es6.number.statics                                                *\n ******************************************************************************/\n\n!function(isInteger){\r\n  $define(STATIC, NUMBER, {\r\n    // 20.1.2.1 Number.EPSILON\r\n    EPSILON: pow(2, -52),\r\n    // 20.1.2.2 Number.isFinite(number)\r\n    isFinite: function(it){\r\n      return typeof it == 'number' && isFinite(it);\r\n    },\r\n    // 20.1.2.3 Number.isInteger(number)\r\n    isInteger: isInteger,\r\n    // 20.1.2.4 Number.isNaN(number)\r\n    isNaN: sameNaN,\r\n    // 20.1.2.5 Number.isSafeInteger(number)\r\n    isSafeInteger: function(number){\r\n      return isInteger(number) && abs(number) <= MAX_SAFE_INTEGER;\r\n    },\r\n    // 20.1.2.6 Number.MAX_SAFE_INTEGER\r\n    MAX_SAFE_INTEGER: MAX_SAFE_INTEGER,\r\n    // 20.1.2.10 Number.MIN_SAFE_INTEGER\r\n    MIN_SAFE_INTEGER: -MAX_SAFE_INTEGER,\r\n    // 20.1.2.12 Number.parseFloat(string)\r\n    parseFloat: parseFloat,\r\n    // 20.1.2.13 Number.parseInt(string, radix)\r\n    parseInt: parseInt\r\n  });\r\n// 20.1.2.3 Number.isInteger(number)\r\n}(Number.isInteger || function(it){\r\n  return !isObject(it) && isFinite(it) && floor(it) === it;\r\n});\n\n/******************************************************************************\n * Module : es6.math                                                          *\n ******************************************************************************/\n\n// ECMAScript 6 shim\r\n!function(){\r\n  // 20.2.2.28 Math.sign(x)\r\n  var E    = Math.E\r\n    , exp  = Math.exp\r\n    , log  = Math.log\r\n    , sqrt = Math.sqrt\r\n    , sign = Math.sign || function(x){\r\n        return (x = +x) == 0 || x != x ? x : x < 0 ? -1 : 1;\r\n      };\r\n  \r\n  // 20.2.2.5 Math.asinh(x)\r\n  function asinh(x){\r\n    return !isFinite(x = +x) || x == 0 ? x : x < 0 ? -asinh(-x) : log(x + sqrt(x * x + 1));\r\n  }\r\n  // 20.2.2.14 Math.expm1(x)\r\n  function expm1(x){\r\n    return (x = +x) == 0 ? x : x > -1e-6 && x < 1e-6 ? x + x * x / 2 : exp(x) - 1;\r\n  }\r\n    \r\n  $define(STATIC, MATH, {\r\n    // 20.2.2.3 Math.acosh(x)\r\n    acosh: function(x){\r\n      return (x = +x) < 1 ? NaN : isFinite(x) ? log(x / E + sqrt(x + 1) * sqrt(x - 1) / E) + 1 : x;\r\n    },\r\n    // 20.2.2.5 Math.asinh(x)\r\n    asinh: asinh,\r\n    // 20.2.2.7 Math.atanh(x)\r\n    atanh: function(x){\r\n      return (x = +x) == 0 ? x : log((1 + x) / (1 - x)) / 2;\r\n    },\r\n    // 20.2.2.9 Math.cbrt(x)\r\n    cbrt: function(x){\r\n      return sign(x = +x) * pow(abs(x), 1 / 3);\r\n    },\r\n    // 20.2.2.11 Math.clz32(x)\r\n    clz32: function(x){\r\n      return (x >>>= 0) ? 32 - x[TO_STRING](2).length : 32;\r\n    },\r\n    // 20.2.2.12 Math.cosh(x)\r\n    cosh: function(x){\r\n      return (exp(x = +x) + exp(-x)) / 2;\r\n    },\r\n    // 20.2.2.14 Math.expm1(x)\r\n    expm1: expm1,\r\n    // 20.2.2.16 Math.fround(x)\r\n    // TODO: fallback for IE9-\r\n    fround: function(x){\r\n      return new Float32Array([x])[0];\r\n    },\r\n    // 20.2.2.17 Math.hypot([value1[, value2[, … ]]])\r\n    hypot: function(value1, value2){\r\n      var sum  = 0\r\n        , len1 = arguments.length\r\n        , len2 = len1\r\n        , args = Array(len1)\r\n        , larg = -Infinity\r\n        , arg;\r\n      while(len1--){\r\n        arg = args[len1] = +arguments[len1];\r\n        if(arg == Infinity || arg == -Infinity)return Infinity;\r\n        if(arg > larg)larg = arg;\r\n      }\r\n      larg = arg || 1;\r\n      while(len2--)sum += pow(args[len2] / larg, 2);\r\n      return larg * sqrt(sum);\r\n    },\r\n    // 20.2.2.18 Math.imul(x, y)\r\n    imul: function(x, y){\r\n      var UInt16 = 0xffff\r\n        , xn = +x\r\n        , yn = +y\r\n        , xl = UInt16 & xn\r\n        , yl = UInt16 & yn;\r\n      return 0 | xl * yl + ((UInt16 & xn >>> 16) * yl + xl * (UInt16 & yn >>> 16) << 16 >>> 0);\r\n    },\r\n    // 20.2.2.20 Math.log1p(x)\r\n    log1p: function(x){\r\n      return (x = +x) > -1e-8 && x < 1e-8 ? x - x * x / 2 : log(1 + x);\r\n    },\r\n    // 20.2.2.21 Math.log10(x)\r\n    log10: function(x){\r\n      return log(x) / Math.LN10;\r\n    },\r\n    // 20.2.2.22 Math.log2(x)\r\n    log2: function(x){\r\n      return log(x) / Math.LN2;\r\n    },\r\n    // 20.2.2.28 Math.sign(x)\r\n    sign: sign,\r\n    // 20.2.2.30 Math.sinh(x)\r\n    sinh: function(x){\r\n      return (abs(x = +x) < 1) ? (expm1(x) - expm1(-x)) / 2 : (exp(x - 1) - exp(-x - 1)) * (E / 2);\r\n    },\r\n    // 20.2.2.33 Math.tanh(x)\r\n    tanh: function(x){\r\n      var a = expm1(x = +x)\r\n        , b = expm1(-x);\r\n      return a == Infinity ? 1 : b == Infinity ? -1 : (a - b) / (exp(x) + exp(-x));\r\n    },\r\n    // 20.2.2.34 Math.trunc(x)\r\n    trunc: trunc\r\n  });\r\n}();\n\n/******************************************************************************\n * Module : es6.string                                                        *\n ******************************************************************************/\n\n!function(fromCharCode){\r\n  function assertNotRegExp(it){\r\n    if(cof(it) == REGEXP)throw TypeError();\r\n  }\r\n  \r\n  $define(STATIC, STRING, {\r\n    // 21.1.2.2 String.fromCodePoint(...codePoints)\r\n    fromCodePoint: function(x){\r\n      var res = []\r\n        , len = arguments.length\r\n        , i   = 0\r\n        , code\r\n      while(len > i){\r\n        code = +arguments[i++];\r\n        if(toIndex(code, 0x10ffff) !== code)throw RangeError(code + ' is not a valid code point');\r\n        res.push(code < 0x10000\r\n          ? fromCharCode(code)\r\n          : fromCharCode(((code -= 0x10000) >> 10) + 0xd800, code % 0x400 + 0xdc00)\r\n        );\r\n      } return res.join('');\r\n    },\r\n    // 21.1.2.4 String.raw(callSite, ...substitutions)\r\n    raw: function(callSite){\r\n      var raw = toObject(callSite.raw)\r\n        , len = toLength(raw.length)\r\n        , sln = arguments.length\r\n        , res = []\r\n        , i   = 0;\r\n      while(len > i){\r\n        res.push(String(raw[i++]));\r\n        if(i < sln)res.push(String(arguments[i]));\r\n      } return res.join('');\r\n    }\r\n  });\r\n  \r\n  $define(PROTO, STRING, {\r\n    // 21.1.3.3 String.prototype.codePointAt(pos)\r\n    codePointAt: createPointAt(false),\r\n    // 21.1.3.6 String.prototype.endsWith(searchString [, endPosition])\r\n    endsWith: function(searchString /*, endPosition = @length */){\r\n      assertNotRegExp(searchString);\r\n      var that = String(assertDefined(this))\r\n        , endPosition = arguments[1]\r\n        , len = toLength(that.length)\r\n        , end = endPosition === undefined ? len : min(toLength(endPosition), len);\r\n      searchString += '';\r\n      return that.slice(end - searchString.length, end) === searchString;\r\n    },\r\n    // 21.1.3.7 String.prototype.includes(searchString, position = 0)\r\n    includes: function(searchString /*, position = 0 */){\r\n      assertNotRegExp(searchString);\r\n      return !!~String(assertDefined(this)).indexOf(searchString, arguments[1]);\r\n    },\r\n    // 21.1.3.13 String.prototype.repeat(count)\r\n    repeat: function(count){\r\n      var str = String(assertDefined(this))\r\n        , res = ''\r\n        , n   = toInteger(count);\r\n      if(0 > n || n == Infinity)throw RangeError(\"Count can't be negative\");\r\n      for(;n > 0; (n >>>= 1) && (str += str))if(n & 1)res += str;\r\n      return res;\r\n    },\r\n    // 21.1.3.18 String.prototype.startsWith(searchString [, position ])\r\n    startsWith: function(searchString /*, position = 0 */){\r\n      assertNotRegExp(searchString);\r\n      var that  = String(assertDefined(this))\r\n        , index = toLength(min(arguments[1], that.length));\r\n      searchString += '';\r\n      return that.slice(index, index + searchString.length) === searchString;\r\n    }\r\n  });\r\n}(String.fromCharCode);\n\n/******************************************************************************\n * Module : es6.array.statics                                                 *\n ******************************************************************************/\n\n!function(){\r\n  $define(STATIC + FORCED * checkDangerIterClosing(Array.from), ARRAY, {\r\n    // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\r\n    from: function(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\r\n      var O       = Object(assertDefined(arrayLike))\r\n        , mapfn   = arguments[1]\r\n        , mapping = mapfn !== undefined\r\n        , f       = mapping ? ctx(mapfn, arguments[2], 2) : undefined\r\n        , index   = 0\r\n        , length, result, step;\r\n      if(isIterable(O)){\r\n        result = new (generic(this, Array));\r\n        safeIterClose(function(iterator){\r\n          for(; !(step = iterator.next()).done; index++){\r\n            result[index] = mapping ? f(step.value, index) : step.value;\r\n          }\r\n        }, getIterator(O));\r\n      } else {\r\n        result = new (generic(this, Array))(length = toLength(O.length));\r\n        for(; length > index; index++){\r\n          result[index] = mapping ? f(O[index], index) : O[index];\r\n        }\r\n      }\r\n      result.length = index;\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  $define(STATIC, ARRAY, {\r\n    // 22.1.2.3 Array.of( ...items)\r\n    of: function(/* ...args */){\r\n      var index  = 0\r\n        , length = arguments.length\r\n        , result = new (generic(this, Array))(length);\r\n      while(length > index)result[index] = arguments[index++];\r\n      result.length = length;\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  setSpecies(Array);\r\n}();\n\n/******************************************************************************\n * Module : es6.array.prototype                                               *\n ******************************************************************************/\n\n!function(){\r\n  $define(PROTO, ARRAY, {\r\n    // 22.1.3.3 Array.prototype.copyWithin(target, start, end = this.length)\r\n    copyWithin: function(target /* = 0 */, start /* = 0, end = @length */){\r\n      var O     = Object(assertDefined(this))\r\n        , len   = toLength(O.length)\r\n        , to    = toIndex(target, len)\r\n        , from  = toIndex(start, len)\r\n        , end   = arguments[2]\r\n        , fin   = end === undefined ? len : toIndex(end, len)\r\n        , count = min(fin - from, len - to)\r\n        , inc   = 1;\r\n      if(from < to && to < from + count){\r\n        inc  = -1;\r\n        from = from + count - 1;\r\n        to   = to + count - 1;\r\n      }\r\n      while(count-- > 0){\r\n        if(from in O)O[to] = O[from];\r\n        else delete O[to];\r\n        to += inc;\r\n        from += inc;\r\n      } return O;\r\n    },\r\n    // 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length)\r\n    fill: function(value /*, start = 0, end = @length */){\r\n      var O      = Object(assertDefined(this))\r\n        , length = toLength(O.length)\r\n        , index  = toIndex(arguments[1], length)\r\n        , end    = arguments[2]\r\n        , endPos = end === undefined ? length : toIndex(end, length);\r\n      while(endPos > index)O[index++] = value;\r\n      return O;\r\n    },\r\n    // 22.1.3.8 Array.prototype.find(predicate, thisArg = undefined)\r\n    find: createArrayMethod(5),\r\n    // 22.1.3.9 Array.prototype.findIndex(predicate, thisArg = undefined)\r\n    findIndex: createArrayMethod(6)\r\n  });\r\n  \r\n  if(framework){\r\n    // 22.1.3.31 Array.prototype[@@unscopables]\r\n    forEach.call(array('find,findIndex,fill,copyWithin,entries,keys,values'), function(it){\r\n      ArrayUnscopables[it] = true;\r\n    });\r\n    SYMBOL_UNSCOPABLES in ArrayProto || hidden(ArrayProto, SYMBOL_UNSCOPABLES, ArrayUnscopables);\r\n  }\r\n}();\n\n/******************************************************************************\n * Module : es6.iterators                                                     *\n ******************************************************************************/\n\n!function(at){\r\n  // 22.1.3.4 Array.prototype.entries()\r\n  // 22.1.3.13 Array.prototype.keys()\r\n  // 22.1.3.29 Array.prototype.values()\r\n  // 22.1.3.30 Array.prototype[@@iterator]()\r\n  defineStdIterators(Array, ARRAY, function(iterated, kind){\r\n    set(this, ITER, {o: toObject(iterated), i: 0, k: kind});\r\n  // 22.1.5.2.1 %ArrayIteratorPrototype%.next()\r\n  }, function(){\r\n    var iter  = this[ITER]\r\n      , O     = iter.o\r\n      , kind  = iter.k\r\n      , index = iter.i++;\r\n    if(!O || index >= O.length){\r\n      iter.o = undefined;\r\n      return iterResult(1);\r\n    }\r\n    if(kind == KEY)  return iterResult(0, index);\r\n    if(kind == VALUE)return iterResult(0, O[index]);\r\n                     return iterResult(0, [index, O[index]]);\r\n  }, VALUE);\r\n  \r\n  // argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\r\n  Iterators[ARGUMENTS] = Iterators[ARRAY];\r\n  \r\n  // 21.1.3.27 String.prototype[@@iterator]()\r\n  defineStdIterators(String, STRING, function(iterated){\r\n    set(this, ITER, {o: String(iterated), i: 0});\r\n  // 21.1.5.2.1 %StringIteratorPrototype%.next()\r\n  }, function(){\r\n    var iter  = this[ITER]\r\n      , O     = iter.o\r\n      , index = iter.i\r\n      , point;\r\n    if(index >= O.length)return iterResult(1);\r\n    point = at.call(O, index);\r\n    iter.i += point.length;\r\n    return iterResult(0, point);\r\n  });\r\n}(createPointAt(true));\n\n/******************************************************************************\n * Module : es6.regexp                                                        *\n ******************************************************************************/\n\nDESC && !function(RegExpProto, _RegExp){  \r\n  // RegExp allows a regex with flags as the pattern\r\n  if(!function(){try{return RegExp(/a/g, 'i') == '/a/i'}catch(e){}}()){\r\n    RegExp = function RegExp(pattern, flags){\r\n      return new _RegExp(cof(pattern) == REGEXP && flags !== undefined\r\n        ? pattern.source : pattern, flags);\r\n    }\r\n    forEach.call(getNames(_RegExp), function(key){\r\n      key in RegExp || defineProperty(RegExp, key, {\r\n        configurable: true,\r\n        get: function(){ return _RegExp[key] },\r\n        set: function(it){ _RegExp[key] = it }\r\n      });\r\n    });\r\n    RegExpProto[CONSTRUCTOR] = RegExp;\r\n    RegExp[PROTOTYPE] = RegExpProto;\r\n    hidden(global, REGEXP, RegExp);\r\n  }\r\n  \r\n  // 21.2.5.3 get RegExp.prototype.flags()\r\n  if(/./g.flags != 'g')defineProperty(RegExpProto, 'flags', {\r\n    configurable: true,\r\n    get: createReplacer(/^.*\\/(\\w*)$/, '$1')\r\n  });\r\n  \r\n  setSpecies(RegExp);\r\n}(RegExp[PROTOTYPE], RegExp);\n\n/******************************************************************************\n * Module : web.immediate                                                     *\n ******************************************************************************/\n\n// setImmediate shim\r\n// Node.js 0.9+ & IE10+ has setImmediate, else:\r\nisFunction(setImmediate) && isFunction(clearImmediate) || function(ONREADYSTATECHANGE){\r\n  var postMessage      = global.postMessage\r\n    , addEventListener = global.addEventListener\r\n    , MessageChannel   = global.MessageChannel\r\n    , counter          = 0\r\n    , queue            = {}\r\n    , defer, channel, port;\r\n  setImmediate = function(fn){\r\n    var args = [], i = 1;\r\n    while(arguments.length > i)args.push(arguments[i++]);\r\n    queue[++counter] = function(){\r\n      invoke(isFunction(fn) ? fn : Function(fn), args);\r\n    }\r\n    defer(counter);\r\n    return counter;\r\n  }\r\n  clearImmediate = function(id){\r\n    delete queue[id];\r\n  }\r\n  function run(id){\r\n    if(has(queue, id)){\r\n      var fn = queue[id];\r\n      delete queue[id];\r\n      fn();\r\n    }\r\n  }\r\n  function listner(event){\r\n    run(event.data);\r\n  }\r\n  // Node.js 0.8-\r\n  if(NODE){\r\n    defer = function(id){\r\n      nextTick(part.call(run, id));\r\n    }\r\n  // Modern browsers, skip implementation for WebWorkers\r\n  // IE8 has postMessage, but it's sync & typeof its postMessage is object\r\n  } else if(addEventListener && isFunction(postMessage) && !global.importScripts){\r\n    defer = function(id){\r\n      postMessage(id, '*');\r\n    }\r\n    addEventListener('message', listner, false);\r\n  // WebWorkers\r\n  } else if(isFunction(MessageChannel)){\r\n    channel = new MessageChannel;\r\n    port    = channel.port2;\r\n    channel.port1.onmessage = listner;\r\n    defer = ctx(port.postMessage, port, 1);\r\n  // IE8-\r\n  } else if(document && ONREADYSTATECHANGE in document[CREATE_ELEMENT]('script')){\r\n    defer = function(id){\r\n      html.appendChild(document[CREATE_ELEMENT]('script'))[ONREADYSTATECHANGE] = function(){\r\n        html.removeChild(this);\r\n        run(id);\r\n      }\r\n    }\r\n  // Rest old browsers\r\n  } else {\r\n    defer = function(id){\r\n      setTimeout(run, 0, id);\r\n    }\r\n  }\r\n}('onreadystatechange');\r\n$define(GLOBAL + BIND, {\r\n  setImmediate:   setImmediate,\r\n  clearImmediate: clearImmediate\r\n});\n\n/******************************************************************************\n * Module : es6.promise                                                       *\n ******************************************************************************/\n\n// ES6 promises shim\r\n// Based on https://github.com/getify/native-promise-only/\r\n!function(Promise, test){\r\n  isFunction(Promise) && isFunction(Promise.resolve)\r\n  && Promise.resolve(test = new Promise(function(){})) == test\r\n  || function(asap, RECORD){\r\n    function isThenable(it){\r\n      var then;\r\n      if(isObject(it))then = it.then;\r\n      return isFunction(then) ? then : false;\r\n    }\r\n    function handledRejectionOrHasOnRejected(promise){\r\n      var record = promise[RECORD]\r\n        , chain  = record.c\r\n        , i      = 0\r\n        , react;\r\n      if(record.h)return true;\r\n      while(chain.length > i){\r\n        react = chain[i++];\r\n        if(react.fail || handledRejectionOrHasOnRejected(react.P))return true;\r\n      }\r\n    }\r\n    function notify(record, reject){\r\n      var chain = record.c;\r\n      if(reject || chain.length)asap(function(){\r\n        var promise = record.p\r\n          , value   = record.v\r\n          , ok      = record.s == 1\r\n          , i       = 0;\r\n        if(reject && !handledRejectionOrHasOnRejected(promise)){\r\n          setTimeout(function(){\r\n            if(!handledRejectionOrHasOnRejected(promise)){\r\n              if(NODE){\r\n                if(!process.emit('unhandledRejection', value, promise)){\r\n                  // default node.js behavior\r\n                }\r\n              } else if(isFunction(console.error)){\r\n                console.error('Unhandled promise rejection', value);\r\n              }\r\n            }\r\n          }, 1e3);\r\n        } else while(chain.length > i)!function(react){\r\n          var cb = ok ? react.ok : react.fail\r\n            , ret, then;\r\n          try {\r\n            if(cb){\r\n              if(!ok)record.h = true;\r\n              ret = cb === true ? value : cb(value);\r\n              if(ret === react.P){\r\n                react.rej(TypeError(PROMISE + '-chain cycle'));\r\n              } else if(then = isThenable(ret)){\r\n                then.call(ret, react.res, react.rej);\r\n              } else react.res(ret);\r\n            } else react.rej(value);\r\n          } catch(err){\r\n            react.rej(err);\r\n          }\r\n        }(chain[i++]);\r\n        chain.length = 0;\r\n      });\r\n    }\r\n    function resolve(value){\r\n      var record = this\r\n        , then, wrapper;\r\n      if(record.d)return;\r\n      record.d = true;\r\n      record = record.r || record; // unwrap\r\n      try {\r\n        if(then = isThenable(value)){\r\n          wrapper = {r: record, d: false}; // wrap\r\n          then.call(value, ctx(resolve, wrapper, 1), ctx(reject, wrapper, 1));\r\n        } else {\r\n          record.v = value;\r\n          record.s = 1;\r\n          notify(record);\r\n        }\r\n      } catch(err){\r\n        reject.call(wrapper || {r: record, d: false}, err); // wrap\r\n      }\r\n    }\r\n    function reject(value){\r\n      var record = this;\r\n      if(record.d)return;\r\n      record.d = true;\r\n      record = record.r || record; // unwrap\r\n      record.v = value;\r\n      record.s = 2;\r\n      notify(record, true);\r\n    }\r\n    function getConstructor(C){\r\n      var S = assertObject(C)[SYMBOL_SPECIES];\r\n      return S != undefined ? S : C;\r\n    }\r\n    // 25.4.3.1 Promise(executor)\r\n    Promise = function(executor){\r\n      assertFunction(executor);\r\n      assertInstance(this, Promise, PROMISE);\r\n      var record = {\r\n        p: this,      // promise\r\n        c: [],        // chain\r\n        s: 0,         // state\r\n        d: false,     // done\r\n        v: undefined, // value\r\n        h: false      // handled rejection\r\n      };\r\n      hidden(this, RECORD, record);\r\n      try {\r\n        executor(ctx(resolve, record, 1), ctx(reject, record, 1));\r\n      } catch(err){\r\n        reject.call(record, err);\r\n      }\r\n    }\r\n    assignHidden(Promise[PROTOTYPE], {\r\n      // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\r\n      then: function(onFulfilled, onRejected){\r\n        var S = assertObject(assertObject(this)[CONSTRUCTOR])[SYMBOL_SPECIES];\r\n        var react = {\r\n          ok:   isFunction(onFulfilled) ? onFulfilled : true,\r\n          fail: isFunction(onRejected)  ? onRejected  : false\r\n        } , P = react.P = new (S != undefined ? S : Promise)(function(resolve, reject){\r\n          react.res = assertFunction(resolve);\r\n          react.rej = assertFunction(reject);\r\n        }), record = this[RECORD];\r\n        record.c.push(react);\r\n        record.s && notify(record);\r\n        return P;\r\n      },\r\n      // 25.4.5.1 Promise.prototype.catch(onRejected)\r\n      'catch': function(onRejected){\r\n        return this.then(undefined, onRejected);\r\n      }\r\n    });\r\n    assignHidden(Promise, {\r\n      // 25.4.4.1 Promise.all(iterable)\r\n      all: function(iterable){\r\n        var Promise = getConstructor(this)\r\n          , values  = [];\r\n        return new Promise(function(resolve, reject){\r\n          forOf(iterable, false, push, values);\r\n          var remaining = values.length\r\n            , results   = Array(remaining);\r\n          if(remaining)forEach.call(values, function(promise, index){\r\n            Promise.resolve(promise).then(function(value){\r\n              results[index] = value;\r\n              --remaining || resolve(results);\r\n            }, reject);\r\n          });\r\n          else resolve(results);\r\n        });\r\n      },\r\n      // 25.4.4.4 Promise.race(iterable)\r\n      race: function(iterable){\r\n        var Promise = getConstructor(this);\r\n        return new Promise(function(resolve, reject){\r\n          forOf(iterable, false, function(promise){\r\n            Promise.resolve(promise).then(resolve, reject);\r\n          });\r\n        });\r\n      },\r\n      // 25.4.4.5 Promise.reject(r)\r\n      reject: function(r){\r\n        return new (getConstructor(this))(function(resolve, reject){\r\n          reject(r);\r\n        });\r\n      },\r\n      // 25.4.4.6 Promise.resolve(x)\r\n      resolve: function(x){\r\n        return isObject(x) && RECORD in x && getPrototypeOf(x) === this[PROTOTYPE]\r\n          ? x : new (getConstructor(this))(function(resolve, reject){\r\n            resolve(x);\r\n          });\r\n      }\r\n    });\r\n  }(nextTick || setImmediate, safeSymbol('record'));\r\n  setToStringTag(Promise, PROMISE);\r\n  setSpecies(Promise);\r\n  $define(GLOBAL + FORCED * !isNative(Promise), {Promise: Promise});\r\n}(global[PROMISE]);\n\n/******************************************************************************\n * Module : es6.collections                                                   *\n ******************************************************************************/\n\n// ECMAScript 6 collections shim\r\n!function(){\r\n  var UID   = safeSymbol('uid')\r\n    , O1    = safeSymbol('O1')\r\n    , WEAK  = safeSymbol('weak')\r\n    , LEAK  = safeSymbol('leak')\r\n    , LAST  = safeSymbol('last')\r\n    , FIRST = safeSymbol('first')\r\n    , SIZE  = DESC ? safeSymbol('size') : 'size'\r\n    , uid   = 0\r\n    , tmp   = {};\r\n  \r\n  function getCollection(C, NAME, methods, commonMethods, isMap, isWeak){\r\n    var ADDER = isMap ? 'set' : 'add'\r\n      , proto = C && C[PROTOTYPE]\r\n      , O     = {};\r\n    function initFromIterable(that, iterable){\r\n      if(iterable != undefined)forOf(iterable, isMap, that[ADDER], that);\r\n      return that;\r\n    }\r\n    function fixSVZ(key, chain){\r\n      var method = proto[key];\r\n      if(framework)proto[key] = function(a, b){\r\n        var result = method.call(this, a === 0 ? 0 : a, b);\r\n        return chain ? this : result;\r\n      };\r\n    }\r\n    if(!isNative(C) || !(isWeak || (!BUGGY_ITERATORS && has(proto, FOR_EACH) && has(proto, 'entries')))){\r\n      // create collection constructor\r\n      C = isWeak\r\n        ? function(iterable){\r\n            assertInstance(this, C, NAME);\r\n            set(this, UID, uid++);\r\n            initFromIterable(this, iterable);\r\n          }\r\n        : function(iterable){\r\n            var that = this;\r\n            assertInstance(that, C, NAME);\r\n            set(that, O1, create(null));\r\n            set(that, SIZE, 0);\r\n            set(that, LAST, undefined);\r\n            set(that, FIRST, undefined);\r\n            initFromIterable(that, iterable);\r\n          };\r\n      assignHidden(assignHidden(C[PROTOTYPE], methods), commonMethods);\r\n      isWeak || !DESC || defineProperty(C[PROTOTYPE], 'size', {get: function(){\r\n        return assertDefined(this[SIZE]);\r\n      }});\r\n    } else {\r\n      var Native = C\r\n        , inst   = new C\r\n        , chain  = inst[ADDER](isWeak ? {} : -0, 1)\r\n        , buggyZero;\r\n      // wrap to init collections from iterable\r\n      if(checkDangerIterClosing(function(O){ new C(O) })){\r\n        C = function(iterable){\r\n          assertInstance(this, C, NAME);\r\n          return initFromIterable(new Native, iterable);\r\n        }\r\n        C[PROTOTYPE] = proto;\r\n        if(framework)proto[CONSTRUCTOR] = C;\r\n      }\r\n      isWeak || inst[FOR_EACH](function(val, key){\r\n        buggyZero = 1 / key === -Infinity;\r\n      });\r\n      // fix converting -0 key to +0\r\n      if(buggyZero){\r\n        fixSVZ('delete');\r\n        fixSVZ('has');\r\n        isMap && fixSVZ('get');\r\n      }\r\n      // + fix .add & .set for chaining\r\n      if(buggyZero || chain !== inst)fixSVZ(ADDER, true);\r\n    }\r\n    setToStringTag(C, NAME);\r\n    setSpecies(C);\r\n    \r\n    O[NAME] = C;\r\n    $define(GLOBAL + WRAP + FORCED * !isNative(C), O);\r\n    \r\n    // add .keys, .values, .entries, [@@iterator]\r\n    // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\r\n    isWeak || defineStdIterators(C, NAME, function(iterated, kind){\r\n      set(this, ITER, {o: iterated, k: kind});\r\n    }, function(){\r\n      var iter  = this[ITER]\r\n        , kind  = iter.k\r\n        , entry = iter.l;\r\n      // revert to the last existing entry\r\n      while(entry && entry.r)entry = entry.p;\r\n      // get next entry\r\n      if(!iter.o || !(iter.l = entry = entry ? entry.n : iter.o[FIRST])){\r\n        // or finish the iteration\r\n        iter.o = undefined;\r\n        return iterResult(1);\r\n      }\r\n      // return step by kind\r\n      if(kind == KEY)  return iterResult(0, entry.k);\r\n      if(kind == VALUE)return iterResult(0, entry.v);\r\n                       return iterResult(0, [entry.k, entry.v]);   \r\n    }, isMap ? KEY+VALUE : VALUE, !isMap);\r\n    \r\n    return C;\r\n  }\r\n  \r\n  function fastKey(it, create){\r\n    // return primitive with prefix\r\n    if(!isObject(it))return (typeof it == 'string' ? 'S' : 'P') + it;\r\n    // can't set id to frozen object\r\n    if(isFrozen(it))return 'F';\r\n    if(!has(it, UID)){\r\n      // not necessary to add id\r\n      if(!create)return 'E';\r\n      // add missing object id\r\n      hidden(it, UID, ++uid);\r\n    // return object id with prefix\r\n    } return 'O' + it[UID];\r\n  }\r\n  function getEntry(that, key){\r\n    // fast case\r\n    var index = fastKey(key), entry;\r\n    if(index != 'F')return that[O1][index];\r\n    // frozen object case\r\n    for(entry = that[FIRST]; entry; entry = entry.n){\r\n      if(entry.k == key)return entry;\r\n    }\r\n  }\r\n  function def(that, key, value){\r\n    var entry = getEntry(that, key)\r\n      , prev, index;\r\n    // change existing entry\r\n    if(entry)entry.v = value;\r\n    // create new entry\r\n    else {\r\n      that[LAST] = entry = {\r\n        i: index = fastKey(key, true), // <- index\r\n        k: key,                        // <- key\r\n        v: value,                      // <- value\r\n        p: prev = that[LAST],          // <- previous entry\r\n        n: undefined,                  // <- next entry\r\n        r: false                       // <- removed\r\n      };\r\n      if(!that[FIRST])that[FIRST] = entry;\r\n      if(prev)prev.n = entry;\r\n      that[SIZE]++;\r\n      // add to index\r\n      if(index != 'F')that[O1][index] = entry;\r\n    } return that;\r\n  }\r\n\r\n  var collectionMethods = {\r\n    // 23.1.3.1 Map.prototype.clear()\r\n    // 23.2.3.2 Set.prototype.clear()\r\n    clear: function(){\r\n      for(var that = this, data = that[O1], entry = that[FIRST]; entry; entry = entry.n){\r\n        entry.r = true;\r\n        if(entry.p)entry.p = entry.p.n = undefined;\r\n        delete data[entry.i];\r\n      }\r\n      that[FIRST] = that[LAST] = undefined;\r\n      that[SIZE] = 0;\r\n    },\r\n    // 23.1.3.3 Map.prototype.delete(key)\r\n    // 23.2.3.4 Set.prototype.delete(value)\r\n    'delete': function(key){\r\n      var that  = this\r\n        , entry = getEntry(that, key);\r\n      if(entry){\r\n        var next = entry.n\r\n          , prev = entry.p;\r\n        delete that[O1][entry.i];\r\n        entry.r = true;\r\n        if(prev)prev.n = next;\r\n        if(next)next.p = prev;\r\n        if(that[FIRST] == entry)that[FIRST] = next;\r\n        if(that[LAST] == entry)that[LAST] = prev;\r\n        that[SIZE]--;\r\n      } return !!entry;\r\n    },\r\n    // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\r\n    // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\r\n    forEach: function(callbackfn /*, that = undefined */){\r\n      var f = ctx(callbackfn, arguments[1], 3)\r\n        , entry;\r\n      while(entry = entry ? entry.n : this[FIRST]){\r\n        f(entry.v, entry.k, this);\r\n        // revert to the last existing entry\r\n        while(entry && entry.r)entry = entry.p;\r\n      }\r\n    },\r\n    // 23.1.3.7 Map.prototype.has(key)\r\n    // 23.2.3.7 Set.prototype.has(value)\r\n    has: function(key){\r\n      return !!getEntry(this, key);\r\n    }\r\n  }\r\n  \r\n  // 23.1 Map Objects\r\n  Map = getCollection(Map, MAP, {\r\n    // 23.1.3.6 Map.prototype.get(key)\r\n    get: function(key){\r\n      var entry = getEntry(this, key);\r\n      return entry && entry.v;\r\n    },\r\n    // 23.1.3.9 Map.prototype.set(key, value)\r\n    set: function(key, value){\r\n      return def(this, key === 0 ? 0 : key, value);\r\n    }\r\n  }, collectionMethods, true);\r\n  \r\n  // 23.2 Set Objects\r\n  Set = getCollection(Set, SET, {\r\n    // 23.2.3.1 Set.prototype.add(value)\r\n    add: function(value){\r\n      return def(this, value = value === 0 ? 0 : value, value);\r\n    }\r\n  }, collectionMethods);\r\n  \r\n  function defWeak(that, key, value){\r\n    if(isFrozen(assertObject(key)))leakStore(that).set(key, value);\r\n    else {\r\n      has(key, WEAK) || hidden(key, WEAK, {});\r\n      key[WEAK][that[UID]] = value;\r\n    } return that;\r\n  }\r\n  function leakStore(that){\r\n    return that[LEAK] || hidden(that, LEAK, new Map)[LEAK];\r\n  }\r\n  \r\n  var weakMethods = {\r\n    // 23.3.3.2 WeakMap.prototype.delete(key)\r\n    // 23.4.3.3 WeakSet.prototype.delete(value)\r\n    'delete': function(key){\r\n      if(!isObject(key))return false;\r\n      if(isFrozen(key))return leakStore(this)['delete'](key);\r\n      return has(key, WEAK) && has(key[WEAK], this[UID]) && delete key[WEAK][this[UID]];\r\n    },\r\n    // 23.3.3.4 WeakMap.prototype.has(key)\r\n    // 23.4.3.4 WeakSet.prototype.has(value)\r\n    has: function(key){\r\n      if(!isObject(key))return false;\r\n      if(isFrozen(key))return leakStore(this).has(key);\r\n      return has(key, WEAK) && has(key[WEAK], this[UID]);\r\n    }\r\n  };\r\n  \r\n  // 23.3 WeakMap Objects\r\n  WeakMap = getCollection(WeakMap, WEAKMAP, {\r\n    // 23.3.3.3 WeakMap.prototype.get(key)\r\n    get: function(key){\r\n      if(isObject(key)){\r\n        if(isFrozen(key))return leakStore(this).get(key);\r\n        if(has(key, WEAK))return key[WEAK][this[UID]];\r\n      }\r\n    },\r\n    // 23.3.3.5 WeakMap.prototype.set(key, value)\r\n    set: function(key, value){\r\n      return defWeak(this, key, value);\r\n    }\r\n  }, weakMethods, true, true);\r\n  \r\n  // IE11 WeakMap frozen keys fix\r\n  if(framework && new WeakMap().set(Object.freeze(tmp), 7).get(tmp) != 7){\r\n    forEach.call(array('delete,has,get,set'), function(key){\r\n      var method = WeakMap[PROTOTYPE][key];\r\n      WeakMap[PROTOTYPE][key] = function(a, b){\r\n        // store frozen objects on leaky map\r\n        if(isObject(a) && isFrozen(a)){\r\n          var result = leakStore(this)[key](a, b);\r\n          return key == 'set' ? this : result;\r\n        // store all the rest on native weakmap\r\n        } return method.call(this, a, b);\r\n      };\r\n    });\r\n  }\r\n  \r\n  // 23.4 WeakSet Objects\r\n  WeakSet = getCollection(WeakSet, WEAKSET, {\r\n    // 23.4.3.1 WeakSet.prototype.add(value)\r\n    add: function(value){\r\n      return defWeak(this, value, true);\r\n    }\r\n  }, weakMethods, false, true);\r\n}();\n\n/******************************************************************************\n * Module : es6.reflect                                                       *\n ******************************************************************************/\n\n!function(){\r\n  function Enumerate(iterated){\r\n    var keys = [], key;\r\n    for(key in iterated)keys.push(key);\r\n    set(this, ITER, {o: iterated, a: keys, i: 0});\r\n  }\r\n  createIterator(Enumerate, OBJECT, function(){\r\n    var iter = this[ITER]\r\n      , keys = iter.a\r\n      , key;\r\n    do {\r\n      if(iter.i >= keys.length)return iterResult(1);\r\n    } while(!((key = keys[iter.i++]) in iter.o));\r\n    return iterResult(0, key);\r\n  });\r\n  \r\n  function wrap(fn){\r\n    return function(it){\r\n      assertObject(it);\r\n      try {\r\n        return fn.apply(undefined, arguments), true;\r\n      } catch(e){\r\n        return false;\r\n      }\r\n    }\r\n  }\r\n  \r\n  function reflectGet(target, propertyKey/*, receiver*/){\r\n    var receiver = arguments.length < 3 ? target : arguments[2]\r\n      , desc = getOwnDescriptor(assertObject(target), propertyKey), proto;\r\n    if(desc)return has(desc, 'value')\r\n      ? desc.value\r\n      : desc.get === undefined\r\n        ? undefined\r\n        : desc.get.call(receiver);\r\n    return isObject(proto = getPrototypeOf(target))\r\n      ? reflectGet(proto, propertyKey, receiver)\r\n      : undefined;\r\n  }\r\n  function reflectSet(target, propertyKey, V/*, receiver*/){\r\n    var receiver = arguments.length < 4 ? target : arguments[3]\r\n      , ownDesc  = getOwnDescriptor(assertObject(target), propertyKey)\r\n      , existingDescriptor, proto;\r\n    if(!ownDesc){\r\n      if(isObject(proto = getPrototypeOf(target))){\r\n        return reflectSet(proto, propertyKey, V, receiver);\r\n      }\r\n      ownDesc = descriptor(0);\r\n    }\r\n    if(has(ownDesc, 'value')){\r\n      if(ownDesc.writable === false || !isObject(receiver))return false;\r\n      existingDescriptor = getOwnDescriptor(receiver, propertyKey) || descriptor(0);\r\n      existingDescriptor.value = V;\r\n      return defineProperty(receiver, propertyKey, existingDescriptor), true;\r\n    }\r\n    return ownDesc.set === undefined\r\n      ? false\r\n      : (ownDesc.set.call(receiver, V), true);\r\n  }\r\n  var isExtensible = Object.isExtensible || returnIt;\r\n  \r\n  var reflect = {\r\n    // 26.1.1 Reflect.apply(target, thisArgument, argumentsList)\r\n    apply: ctx(call, apply, 3),\r\n    // 26.1.2 Reflect.construct(target, argumentsList [, newTarget])\r\n    construct: function(target, argumentsList /*, newTarget*/){\r\n      var proto    = assertFunction(arguments.length < 3 ? target : arguments[2])[PROTOTYPE]\r\n        , instance = create(isObject(proto) ? proto : ObjectProto)\r\n        , result   = apply.call(target, instance, argumentsList);\r\n      return isObject(result) ? result : instance;\r\n    },\r\n    // 26.1.3 Reflect.defineProperty(target, propertyKey, attributes)\r\n    defineProperty: wrap(defineProperty),\r\n    // 26.1.4 Reflect.deleteProperty(target, propertyKey)\r\n    deleteProperty: function(target, propertyKey){\r\n      var desc = getOwnDescriptor(assertObject(target), propertyKey);\r\n      return desc && !desc.configurable ? false : delete target[propertyKey];\r\n    },\r\n    // 26.1.5 Reflect.enumerate(target)\r\n    enumerate: function(target){\r\n      return new Enumerate(assertObject(target));\r\n    },\r\n    // 26.1.6 Reflect.get(target, propertyKey [, receiver])\r\n    get: reflectGet,\r\n    // 26.1.7 Reflect.getOwnPropertyDescriptor(target, propertyKey)\r\n    getOwnPropertyDescriptor: function(target, propertyKey){\r\n      return getOwnDescriptor(assertObject(target), propertyKey);\r\n    },\r\n    // 26.1.8 Reflect.getPrototypeOf(target)\r\n    getPrototypeOf: function(target){\r\n      return getPrototypeOf(assertObject(target));\r\n    },\r\n    // 26.1.9 Reflect.has(target, propertyKey)\r\n    has: function(target, propertyKey){\r\n      return propertyKey in target;\r\n    },\r\n    // 26.1.10 Reflect.isExtensible(target)\r\n    isExtensible: function(target){\r\n      return !!isExtensible(assertObject(target));\r\n    },\r\n    // 26.1.11 Reflect.ownKeys(target)\r\n    ownKeys: ownKeys,\r\n    // 26.1.12 Reflect.preventExtensions(target)\r\n    preventExtensions: wrap(Object.preventExtensions || returnIt),\r\n    // 26.1.13 Reflect.set(target, propertyKey, V [, receiver])\r\n    set: reflectSet\r\n  }\r\n  // 26.1.14 Reflect.setPrototypeOf(target, proto)\r\n  if(setPrototypeOf)reflect.setPrototypeOf = function(target, proto){\r\n    return setPrototypeOf(assertObject(target), proto), true;\r\n  };\r\n  \r\n  $define(GLOBAL, {Reflect: {}});\r\n  $define(STATIC, 'Reflect', reflect);\r\n}();\n\n/******************************************************************************\n * Module : es7.proposals                                                     *\n ******************************************************************************/\n\n!function(){\r\n  $define(PROTO, ARRAY, {\r\n    // https://github.com/domenic/Array.prototype.includes\r\n    includes: createArrayContains(true)\r\n  });\r\n  $define(PROTO, STRING, {\r\n    // https://github.com/mathiasbynens/String.prototype.at\r\n    at: createPointAt(true)\r\n  });\r\n  \r\n  function createObjectToArray(isEntries){\r\n    return function(object){\r\n      var O      = toObject(object)\r\n        , keys   = getKeys(object)\r\n        , length = keys.length\r\n        , i      = 0\r\n        , result = Array(length)\r\n        , key;\r\n      if(isEntries)while(length > i)result[i] = [key = keys[i++], O[key]];\r\n      else while(length > i)result[i] = O[keys[i++]];\r\n      return result;\r\n    }\r\n  }\r\n  $define(STATIC, OBJECT, {\r\n    // https://gist.github.com/WebReflection/9353781\r\n    getOwnPropertyDescriptors: function(object){\r\n      var O      = toObject(object)\r\n        , result = {};\r\n      forEach.call(ownKeys(O), function(key){\r\n        defineProperty(result, key, descriptor(0, getOwnDescriptor(O, key)));\r\n      });\r\n      return result;\r\n    },\r\n    // https://github.com/rwaldron/tc39-notes/blob/master/es6/2014-04/apr-9.md#51-objectentries-objectvalues\r\n    values:  createObjectToArray(false),\r\n    entries: createObjectToArray(true)\r\n  });\r\n  $define(STATIC, REGEXP, {\r\n    // https://gist.github.com/kangax/9698100\r\n    escape: createReplacer(/([\\\\\\-[\\]{}()*+?.,^$|])/g, '\\\\$1', true)\r\n  });\r\n}();\n\n/******************************************************************************\n * Module : es7.abstract-refs                                                 *\n ******************************************************************************/\n\n// https://github.com/zenparsing/es-abstract-refs\r\n!function(REFERENCE){\r\n  REFERENCE_GET = getWellKnownSymbol(REFERENCE+'Get', true);\r\n  var REFERENCE_SET = getWellKnownSymbol(REFERENCE+SET, true)\r\n    , REFERENCE_DELETE = getWellKnownSymbol(REFERENCE+'Delete', true);\r\n  \r\n  $define(STATIC, SYMBOL, {\r\n    referenceGet: REFERENCE_GET,\r\n    referenceSet: REFERENCE_SET,\r\n    referenceDelete: REFERENCE_DELETE\r\n  });\r\n  \r\n  hidden(FunctionProto, REFERENCE_GET, returnThis);\r\n  \r\n  function setMapMethods(Constructor){\r\n    if(Constructor){\r\n      var MapProto = Constructor[PROTOTYPE];\r\n      hidden(MapProto, REFERENCE_GET, MapProto.get);\r\n      hidden(MapProto, REFERENCE_SET, MapProto.set);\r\n      hidden(MapProto, REFERENCE_DELETE, MapProto['delete']);\r\n    }\r\n  }\r\n  setMapMethods(Map);\r\n  setMapMethods(WeakMap);\r\n}('reference');\n\n/******************************************************************************\n * Module : js.array.statics                                                  *\n ******************************************************************************/\n\n// JavaScript 1.6 / Strawman array statics shim\r\n!function(arrayStatics){\r\n  function setArrayStatics(keys, length){\r\n    forEach.call(array(keys), function(key){\r\n      if(key in ArrayProto)arrayStatics[key] = ctx(call, ArrayProto[key], length);\r\n    });\r\n  }\r\n  setArrayStatics('pop,reverse,shift,keys,values,entries', 1);\r\n  setArrayStatics('indexOf,every,some,forEach,map,filter,find,findIndex,includes', 3);\r\n  setArrayStatics('join,slice,concat,push,splice,unshift,sort,lastIndexOf,' +\r\n                  'reduce,reduceRight,copyWithin,fill,turn');\r\n  $define(STATIC, ARRAY, arrayStatics);\r\n}({});\n\n/******************************************************************************\n * Module : web.dom.itarable                                                  *\n ******************************************************************************/\n\n!function(NodeList){\r\n  if(framework && NodeList && !(SYMBOL_ITERATOR in NodeList[PROTOTYPE])){\r\n    hidden(NodeList[PROTOTYPE], SYMBOL_ITERATOR, Iterators[ARRAY]);\r\n  }\r\n  Iterators.NodeList = Iterators[ARRAY];\r\n}(global.NodeList);\n}(typeof self != 'undefined' && self.Math === Math ? self : Function('return this')(), true);","(function (global){\n/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n  \"use strict\";\n\n  var hasOwn = Object.prototype.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var iteratorSymbol =\n    typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n  var inModule = typeof module === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    return new Generator(innerFn, outerFn, self || null, tryLocsList || []);\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    return new Promise(function(resolve, reject) {\n      var generator = wrap(innerFn, outerFn, self, tryLocsList);\n      var callNext = step.bind(generator.next);\n      var callThrow = step.bind(generator[\"throw\"]);\n\n      function step(arg) {\n        var record = tryCatch(this, null, arg);\n        if (record.type === \"throw\") {\n          reject(record.arg);\n          return;\n        }\n\n        var info = record.arg;\n        if (info.done) {\n          resolve(info.value);\n        } else {\n          Promise.resolve(info.value).then(callNext, callThrow);\n        }\n      }\n\n      callNext();\n    });\n  };\n\n  function Generator(innerFn, outerFn, self, tryLocsList) {\n    var generator = outerFn ? Object.create(outerFn.prototype) : this;\n    var context = new Context(tryLocsList);\n    var state = GenStateSuspendedStart;\n\n    function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var record = tryCatch(\n            delegate.iterator[method],\n            delegate.iterator,\n            arg\n          );\n\n          if (record.type === \"throw\") {\n            context.delegate = null;\n\n            // Like returning generator.throw(uncaught), but without the\n            // overhead of an extra function call.\n            method = \"throw\";\n            arg = record.arg;\n\n            continue;\n          }\n\n          // Delegate generator ran and handled its own exceptions so\n          // regardless of what the method was, we continue as if it is\n          // \"next\" with an undefined arg.\n          method = \"next\";\n          arg = undefined;\n\n          var info = record.arg;\n          if (info.done) {\n            context[delegate.resultName] = info.value;\n            context.next = delegate.nextLoc;\n          } else {\n            state = GenStateSuspendedYield;\n            return info;\n          }\n\n          context.delegate = null;\n        }\n\n        if (method === \"next\") {\n          if (state === GenStateSuspendedStart &&\n              typeof arg !== \"undefined\") {\n            // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n            throw new TypeError(\n              \"attempt to send \" + JSON.stringify(arg) + \" to newborn generator\"\n            );\n          }\n\n          if (state === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            delete context.sent;\n          }\n\n        } else if (method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw arg;\n          }\n\n          if (context.dispatchException(arg)) {\n            // If the dispatched exception was caught by a catch block,\n            // then let that catch block handle the exception normally.\n            method = \"next\";\n            arg = undefined;\n          }\n\n        } else if (method === \"return\") {\n          context.abrupt(\"return\", arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          var info = {\n            value: record.arg,\n            done: context.done\n          };\n\n          if (record.arg === ContinueSentinel) {\n            if (context.delegate && method === \"next\") {\n              // Deliberately forget the last sent value so that we don't\n              // accidentally pass it on to the delegate.\n              arg = undefined;\n            }\n          } else {\n            return info;\n          }\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n\n          if (method === \"next\") {\n            context.dispatchException(record.arg);\n          } else {\n            arg = record.arg;\n          }\n        }\n      }\n    }\n\n    generator.next = invoke.bind(generator, \"next\");\n    generator[\"throw\"] = invoke.bind(generator, \"throw\");\n    generator[\"return\"] = invoke.bind(generator, \"return\");\n\n    return generator;\n  }\n\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset();\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function() {\n      this.prev = 0;\n      this.next = 0;\n      this.sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      // Pre-initialize at least 20 temporary variables to enable hidden\n      // class optimizations for simple generators.\n      for (var tempIndex = 0, tempName;\n           hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n           ++tempIndex) {\n        this[tempName] = null;\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n        return !!caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg < finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.next = finallyEntry.finallyLoc;\n      } else {\n        this.complete(record);\n      }\n\n      return ContinueSentinel;\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = record.arg;\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          return this.complete(entry.completion, entry.afterLoc);\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // Among the various tricks for obtaining a reference to the global\n  // object, this seems to be the most reliable technique that does not\n  // use indirect eval (which violates Content Security Policy).\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window : this\n);\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/babel/node_modules/regenerator-babel/runtime.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n  \"use strict\";\n\n  var hasOwn = Object.prototype.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var iteratorSymbol =\n    typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n  var inModule = typeof module === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    return new Generator(innerFn, outerFn, self || null, tryLocsList || []);\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    return new Promise(function(resolve, reject) {\n      var generator = wrap(innerFn, outerFn, self, tryLocsList);\n      var callNext = step.bind(generator.next);\n      var callThrow = step.bind(generator[\"throw\"]);\n\n      function step(arg) {\n        var record = tryCatch(this, null, arg);\n        if (record.type === \"throw\") {\n          reject(record.arg);\n          return;\n        }\n\n        var info = record.arg;\n        if (info.done) {\n          resolve(info.value);\n        } else {\n          Promise.resolve(info.value).then(callNext, callThrow);\n        }\n      }\n\n      callNext();\n    });\n  };\n\n  function Generator(innerFn, outerFn, self, tryLocsList) {\n    var generator = outerFn ? Object.create(outerFn.prototype) : this;\n    var context = new Context(tryLocsList);\n    var state = GenStateSuspendedStart;\n\n    function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var record = tryCatch(\n            delegate.iterator[method],\n            delegate.iterator,\n            arg\n          );\n\n          if (record.type === \"throw\") {\n            context.delegate = null;\n\n            // Like returning generator.throw(uncaught), but without the\n            // overhead of an extra function call.\n            method = \"throw\";\n            arg = record.arg;\n\n            continue;\n          }\n\n          // Delegate generator ran and handled its own exceptions so\n          // regardless of what the method was, we continue as if it is\n          // \"next\" with an undefined arg.\n          method = \"next\";\n          arg = undefined;\n\n          var info = record.arg;\n          if (info.done) {\n            context[delegate.resultName] = info.value;\n            context.next = delegate.nextLoc;\n          } else {\n            state = GenStateSuspendedYield;\n            return info;\n          }\n\n          context.delegate = null;\n        }\n\n        if (method === \"next\") {\n          if (state === GenStateSuspendedStart &&\n              typeof arg !== \"undefined\") {\n            // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n            throw new TypeError(\n              \"attempt to send \" + JSON.stringify(arg) + \" to newborn generator\"\n            );\n          }\n\n          if (state === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            delete context.sent;\n          }\n\n        } else if (method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw arg;\n          }\n\n          if (context.dispatchException(arg)) {\n            // If the dispatched exception was caught by a catch block,\n            // then let that catch block handle the exception normally.\n            method = \"next\";\n            arg = undefined;\n          }\n\n        } else if (method === \"return\") {\n          context.abrupt(\"return\", arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          var info = {\n            value: record.arg,\n            done: context.done\n          };\n\n          if (record.arg === ContinueSentinel) {\n            if (context.delegate && method === \"next\") {\n              // Deliberately forget the last sent value so that we don't\n              // accidentally pass it on to the delegate.\n              arg = undefined;\n            }\n          } else {\n            return info;\n          }\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n\n          if (method === \"next\") {\n            context.dispatchException(record.arg);\n          } else {\n            arg = record.arg;\n          }\n        }\n      }\n    }\n\n    generator.next = invoke.bind(generator, \"next\");\n    generator[\"throw\"] = invoke.bind(generator, \"throw\");\n    generator[\"return\"] = invoke.bind(generator, \"return\");\n\n    return generator;\n  }\n\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset();\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function() {\n      this.prev = 0;\n      this.next = 0;\n      this.sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      // Pre-initialize at least 20 temporary variables to enable hidden\n      // class optimizations for simple generators.\n      for (var tempIndex = 0, tempName;\n           hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n           ++tempIndex) {\n        this[tempName] = null;\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n        return !!caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg < finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.next = finallyEntry.finallyLoc;\n      } else {\n        this.complete(record);\n      }\n\n      return ContinueSentinel;\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = record.arg;\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          return this.complete(entry.completion, entry.afterLoc);\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // Among the various tricks for obtaining a reference to the global\n  // object, this seems to be the most reliable technique that does not\n  // use indirect eval (which violates Content Security Policy).\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window : this\n);\n"]}","'use strict'\n\nmodule.exports = boxIntersectWrapper\n\nvar pool = require('typedarray-pool')\nvar sweep = require('./lib/sweep')\nvar boxIntersectIter = require('./lib/intersect')\n\nfunction boxEmpty(d, box) {\n  for(var j=0; j<d; ++j) {\n    if(!(box[j] <= box[j+d])) {\n      return true\n    }\n  }\n  return false\n}\n\n//Unpack boxes into a flat typed array, remove empty boxes\nfunction convertBoxes(boxes, d, data, ids) {\n  var ptr = 0\n  var count = 0\n  for(var i=0, n=boxes.length; i<n; ++i) {\n    var b = boxes[i]\n    if(boxEmpty(d, b)) {\n      continue\n    }\n    for(var j=0; j<2*d; ++j) {\n      data[ptr++] = b[j]\n    }\n    ids[count++] = i\n  }\n  return count\n}\n\n//Perform type conversions, check bounds\nfunction boxIntersect(red, blue, visit, full) {\n  var n = red.length\n  var m = blue.length\n\n  //If either array is empty, then we can skip this whole thing\n  if(n <= 0 || m <= 0) {\n    return\n  }\n\n  //Compute dimension, if it is 0 then we skip\n  var d = (red[0].length)>>>1\n  if(d <= 0) {\n    return\n  }\n\n  var retval\n\n  //Convert red boxes\n  var redList  = pool.mallocDouble(2*d*n)\n  var redIds   = pool.mallocInt32(n)\n  n = convertBoxes(red, d, redList, redIds)\n\n  if(n > 0) {\n    if(d === 1 && full) {\n      //Special case: 1d complete\n      sweep.init(n)\n      retval = sweep.sweepComplete(\n        d, visit, \n        0, n, redList, redIds,\n        0, n, redList, redIds)\n    } else {\n\n      //Convert blue boxes\n      var blueList = pool.mallocDouble(2*d*m)\n      var blueIds  = pool.mallocInt32(m)\n      m = convertBoxes(blue, d, blueList, blueIds)\n\n      if(m > 0) {\n        sweep.init(n+m)\n\n        if(d === 1) {\n          //Special case: 1d bipartite\n          retval = sweep.sweepBipartite(\n            d, visit, \n            0, n, redList,  redIds,\n            0, m, blueList, blueIds)\n        } else {\n          //General case:  d>1\n          retval = boxIntersectIter(\n            d, visit,    full,\n            n, redList,  redIds,\n            m, blueList, blueIds)\n        }\n\n        pool.free(blueList)\n        pool.free(blueIds)\n      }\n    }\n\n    pool.free(redList)\n    pool.free(redIds)\n  }\n\n  return retval\n}\n\n\nvar RESULT\n\nfunction appendItem(i,j) {\n  RESULT.push([i,j])\n}\n\nfunction intersectFullArray(x) {\n  RESULT = []\n  boxIntersect(x, x, appendItem, true)\n  return RESULT\n}\n\nfunction intersectBipartiteArray(x, y) {\n  RESULT = []\n  boxIntersect(x, y, appendItem, false)\n  return RESULT\n}\n\n//User-friendly wrapper, handle full input and no-visitor cases\nfunction boxIntersectWrapper(arg0, arg1, arg2) {\n  var result\n  switch(arguments.length) {\n    case 1:\n      return intersectFullArray(arg0)\n    case 2:\n      if(typeof arg1 === 'function') {\n        return boxIntersect(arg0, arg0, arg1, true)\n      } else {\n        return intersectBipartiteArray(arg0, arg1)\n      }\n    case 3:\n      return boxIntersect(arg0, arg1, arg2, false)\n    default:\n      throw new Error('box-intersect: Invalid arguments')\n  }\n}","'use strict'\n\nvar DIMENSION   = 'd'\nvar AXIS        = 'ax'\nvar VISIT       = 'vv'\nvar FLIP        = 'fp'\n\nvar ELEM_SIZE   = 'es'\n\nvar RED_START   = 'rs'\nvar RED_END     = 're'\nvar RED_BOXES   = 'rb'\nvar RED_INDEX   = 'ri'\nvar RED_PTR     = 'rp'\n\nvar BLUE_START  = 'bs'\nvar BLUE_END    = 'be'\nvar BLUE_BOXES  = 'bb'\nvar BLUE_INDEX  = 'bi'\nvar BLUE_PTR    = 'bp'\n\nvar RETVAL      = 'rv'\n\nvar INNER_LABEL = 'Q'\n\nvar ARGS = [\n  DIMENSION,\n  AXIS,\n  VISIT,\n  RED_START,\n  RED_END,\n  RED_BOXES,\n  RED_INDEX,\n  BLUE_START,\n  BLUE_END,\n  BLUE_BOXES,\n  BLUE_INDEX\n]\n\nfunction generateBruteForce(redMajor, flip, full) {\n  var funcName = 'bruteForce' + \n    (redMajor ? 'Red' : 'Blue') + \n    (flip ? 'Flip' : '') +\n    (full ? 'Full' : '')\n\n  var code = ['function ', funcName, '(', ARGS.join(), '){',\n    'var ', ELEM_SIZE, '=2*', DIMENSION, ';']\n\n  var redLoop = \n    'for(var i=' + RED_START + ',' + RED_PTR + '=' + ELEM_SIZE + '*' + RED_START + ';' +\n        'i<' + RED_END +';' +\n        '++i,' + RED_PTR + '+=' + ELEM_SIZE + '){' +\n        'var x0=' + RED_BOXES + '[' + AXIS + '+' + RED_PTR + '],' +\n            'x1=' + RED_BOXES + '[' + AXIS + '+' + RED_PTR + '+' + DIMENSION + '],' +\n            'xi=' + RED_INDEX + '[i];'\n\n  var blueLoop = \n    'for(var j=' + BLUE_START + ',' + BLUE_PTR + '=' + ELEM_SIZE + '*' + BLUE_START + ';' +\n        'j<' + BLUE_END + ';' +\n        '++j,' + BLUE_PTR + '+=' + ELEM_SIZE + '){' +\n        'var y0=' + BLUE_BOXES + '[' + AXIS + '+' + BLUE_PTR + '],' +\n            (full ? 'y1=' + BLUE_BOXES + '[' + AXIS + '+' + BLUE_PTR + '+' + DIMENSION + '],' : '') +\n            'yi=' + BLUE_INDEX + '[j];'\n\n  if(redMajor) {\n    code.push(redLoop, INNER_LABEL, ':', blueLoop)\n  } else {\n    code.push(blueLoop, INNER_LABEL, ':', redLoop)\n  }\n\n  if(full) {\n    code.push('if(y1<x0||x1<y0)continue;')\n  } else if(flip) {\n    code.push('if(y0<=x0||x1<y0)continue;')\n  } else {\n    code.push('if(y0<x0||x1<y0)continue;')\n  }\n\n  code.push('for(var k='+AXIS+'+1;k<'+DIMENSION+';++k){'+\n    'var r0='+RED_BOXES+'[k+'+RED_PTR+'],'+\n        'r1='+RED_BOXES+'[k+'+DIMENSION+'+'+RED_PTR+'],'+\n        'b0='+BLUE_BOXES+'[k+'+BLUE_PTR+'],'+\n        'b1='+BLUE_BOXES+'[k+'+DIMENSION+'+'+BLUE_PTR+'];'+\n      'if(r1<b0||b1<r0)continue ' + INNER_LABEL + ';}' +\n      'var ' + RETVAL + '=' + VISIT + '(')\n\n  if(flip) {\n    code.push('yi,xi')\n  } else {\n    code.push('xi,yi')\n  }\n\n  code.push(');if(' + RETVAL + '!==void 0)return ' + RETVAL + ';}}}')\n\n  return {\n    name: funcName, \n    code: code.join('')\n  }\n}\n\nfunction bruteForcePlanner(full) {\n  var funcName = 'bruteForce' + (full ? 'Full' : 'Partial')\n  var prefix = []\n  var fargs = ARGS.slice()\n  if(!full) {\n    fargs.splice(3, 0, FLIP)\n  }\n\n  var code = ['function ' + funcName + '(' + fargs.join() + '){']\n\n  function invoke(redMajor, flip) {\n    var res = generateBruteForce(redMajor, flip, full)\n    prefix.push(res.code)\n    code.push('return ' + res.name + '(' + ARGS.join() + ');')\n  }\n\n  code.push('if(' + RED_END + '-' + RED_START + '>' +\n                    BLUE_END + '-' + BLUE_START + '){')\n\n  if(full) {\n    invoke(true, false)\n    code.push('}else{')\n    invoke(false, false)\n  } else {\n    code.push('if(' + FLIP + '){')\n    invoke(true, true)\n    code.push('}else{')\n    invoke(true, false)\n    code.push('}}else{if(' + FLIP + '){')\n    invoke(false, true)\n    code.push('}else{')\n    invoke(false, false)\n    code.push('}')\n  }\n  code.push('}}return ' + funcName)\n\n  var codeStr = prefix.join('') + code.join('')\n  var proc = new Function(codeStr)\n  return proc()\n}\n\n\nexports.partial = bruteForcePlanner(false)\nexports.full    = bruteForcePlanner(true)","'use strict'\n\nmodule.exports = boxIntersectIter\n\nvar pool = require('typedarray-pool')\nvar bits = require('bit-twiddle')\nvar bruteForce = require('./brute')\nvar bruteForcePartial = bruteForce.partial\nvar bruteForceFull = bruteForce.full\nvar sweep = require('./sweep')\nvar findMedian = require('./median')\nvar genPartition = require('./partition')\n\n//Twiddle parameters\nvar BRUTE_FORCE_CUTOFF    = 128       //Cut off for brute force search\nvar SCAN_CUTOFF           = (1<<22)   //Cut off for two way scan\nvar SCAN_COMPLETE_CUTOFF  = (1<<22)  \n\n//Partition functions\nvar partitionInteriorContainsInterval = genPartition(\n  '!(lo>=p0)&&!(p1>=hi)', \n  ['p0', 'p1'])\n\nvar partitionStartEqual = genPartition(\n  'lo===p0',\n  ['p0'])\n\nvar partitionStartLessThan = genPartition(\n  'lo<p0',\n  ['p0'])\n\nvar partitionEndLessThanEqual = genPartition(\n  'hi<=p0',\n  ['p0'])\n\nvar partitionContainsPoint = genPartition(\n  'lo<=p0&&p0<=hi',\n  ['p0'])\n\nvar partitionContainsPointProper = genPartition(\n  'lo<p0&&p0<=hi',\n  ['p0'])\n\n//Frame size for iterative loop\nvar IFRAME_SIZE = 6\nvar DFRAME_SIZE = 2\n\n//Data for box statck\nvar INIT_CAPACITY = 1024\nvar BOX_ISTACK  = pool.mallocInt32(INIT_CAPACITY)\nvar BOX_DSTACK  = pool.mallocDouble(INIT_CAPACITY)\n\n//Initialize iterative loop queue\nfunction iterInit(d, count) {\n  var levels = (8 * bits.log2(count+1) * (d+1))|0\n  var maxInts = bits.nextPow2(IFRAME_SIZE*levels)\n  if(BOX_ISTACK.length < maxInts) {\n    pool.free(BOX_ISTACK)\n    BOX_ISTACK = pool.mallocInt32(maxInts)\n  }\n  var maxDoubles = bits.nextPow2(DFRAME_SIZE*levels)\n  if(BOX_DSTACK < maxDoubles) {\n    pool.free(BOX_DSTACK)\n    BOX_DSTACK = pool.mallocDouble(maxDoubles)\n  }\n}\n\n//Append item to queue\nfunction iterPush(ptr,\n  axis, \n  redStart, redEnd, \n  blueStart, blueEnd, \n  state, \n  lo, hi) {\n\n  var iptr = IFRAME_SIZE * ptr\n  BOX_ISTACK[iptr]   = axis\n  BOX_ISTACK[iptr+1] = redStart\n  BOX_ISTACK[iptr+2] = redEnd\n  BOX_ISTACK[iptr+3] = blueStart\n  BOX_ISTACK[iptr+4] = blueEnd\n  BOX_ISTACK[iptr+5] = state\n\n  var dptr = DFRAME_SIZE * ptr\n  BOX_DSTACK[dptr]   = lo\n  BOX_DSTACK[dptr+1] = hi\n}\n\n//Special case:  Intersect single point with list of intervals\nfunction onePointPartial(\n  d, axis, visit, flip,\n  redStart, redEnd, red, redIndex,\n  blueOffset, blue, blueId) {\n\n  var elemSize = 2 * d\n  var bluePtr  = blueOffset * elemSize\n  var blueX    = blue[bluePtr + axis]\n\nred_loop:\n  for(var i=redStart, redPtr=redStart*elemSize; i<redEnd; ++i, redPtr+=elemSize) {\n    var r0 = red[redPtr+axis]\n    var r1 = red[redPtr+axis+d]\n    if(blueX < r0 || r1 < blueX) {\n      continue\n    }\n    if(flip && blueX === r0) {\n      continue\n    }\n    var redId = redIndex[i]\n    for(var j=axis+1; j<d; ++j) {\n      var r0 = red[redPtr+j]\n      var r1 = red[redPtr+j+d]\n      var b0 = blue[bluePtr+j]\n      var b1 = blue[bluePtr+j+d]\n      if(r1 < b0 || b1 < r0) {\n        continue red_loop\n      }\n    }\n    var retval\n    if(flip) {\n      retval = visit(blueId, redId)\n    } else {\n      retval = visit(redId, blueId)\n    }\n    if(retval !== void 0) {\n      return retval\n    }\n  }\n}\n\n//Special case:  Intersect one point with list of intervals\nfunction onePointFull(\n  d, axis, visit,\n  redStart, redEnd, red, redIndex,\n  blueOffset, blue, blueId) {\n\n  var elemSize = 2 * d\n  var bluePtr  = blueOffset * elemSize\n  var blueX    = blue[bluePtr + axis]\n\nred_loop:\n  for(var i=redStart, redPtr=redStart*elemSize; i<redEnd; ++i, redPtr+=elemSize) {\n    var redId = redIndex[i]\n    if(redId === blueId) {\n      continue\n    }\n    var r0 = red[redPtr+axis]\n    var r1 = red[redPtr+axis+d]\n    if(blueX < r0 || r1 < blueX) {\n      continue\n    }\n    for(var j=axis+1; j<d; ++j) {\n      var r0 = red[redPtr+j]\n      var r1 = red[redPtr+j+d]\n      var b0 = blue[bluePtr+j]\n      var b1 = blue[bluePtr+j+d]\n      if(r1 < b0 || b1 < r0) {\n        continue red_loop\n      }\n    }\n    var retval = visit(redId, blueId)\n    if(retval !== void 0) {\n      return retval\n    }\n  }\n}\n\n//The main box intersection routine\nfunction boxIntersectIter(\n  d, visit, initFull,\n  xSize, xBoxes, xIndex,\n  ySize, yBoxes, yIndex) {\n\n  //Reserve memory for stack\n  iterInit(d, xSize + ySize)\n\n  var top  = 0\n  var elemSize = 2 * d\n  var retval\n\n  iterPush(top++,\n      0,\n      0, xSize,\n      0, ySize,\n      initFull ? 16 : 0, \n      -Infinity, Infinity)\n  if(!initFull) {\n    iterPush(top++,\n      0,\n      0, ySize,\n      0, xSize,\n      1, \n      -Infinity, Infinity)\n  }\n\n  while(top > 0) {\n    top  -= 1\n\n    var iptr = top * IFRAME_SIZE\n    var axis      = BOX_ISTACK[iptr]\n    var redStart  = BOX_ISTACK[iptr+1]\n    var redEnd    = BOX_ISTACK[iptr+2]\n    var blueStart = BOX_ISTACK[iptr+3]\n    var blueEnd   = BOX_ISTACK[iptr+4]\n    var state     = BOX_ISTACK[iptr+5]\n\n    var dptr = top * DFRAME_SIZE\n    var lo        = BOX_DSTACK[dptr]\n    var hi        = BOX_DSTACK[dptr+1]\n\n    //Unpack state info\n    var flip      = (state & 1)\n    var full      = !!(state & 16)\n\n    //Unpack indices\n    var red       = xBoxes\n    var redIndex  = xIndex\n    var blue      = yBoxes\n    var blueIndex = yIndex\n    if(flip) {\n      red         = yBoxes\n      redIndex    = yIndex\n      blue        = xBoxes\n      blueIndex   = xIndex\n    }\n\n    if(state & 2) {\n      redEnd = partitionStartLessThan(\n        d, axis,\n        redStart, redEnd, red, redIndex,\n        hi)\n      if(redStart >= redEnd) {\n        continue\n      }\n    }\n    if(state & 4) {\n      redStart = partitionEndLessThanEqual(\n        d, axis,\n        redStart, redEnd, red, redIndex,\n        lo)\n      if(redStart >= redEnd) {\n        continue\n      }\n    }\n    \n    var redCount  = redEnd  - redStart\n    var blueCount = blueEnd - blueStart\n\n    if(full) {\n      if(d * redCount * (redCount + blueCount) < SCAN_COMPLETE_CUTOFF) {\n        retval = sweep.scanComplete(\n          d, axis, visit, \n          redStart, redEnd, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      }\n    } else {\n      if(d * Math.min(redCount, blueCount) < BRUTE_FORCE_CUTOFF) {\n        //If input small, then use brute force\n        retval = bruteForcePartial(\n            d, axis, visit, flip,\n            redStart,  redEnd,  red,  redIndex,\n            blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      } else if(d * redCount * blueCount < SCAN_CUTOFF) {\n        //If input medium sized, then use sweep and prune\n        retval = sweep.scanBipartite(\n          d, axis, visit, flip, \n          redStart, redEnd, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      }\n    }\n    \n    //First, find all red intervals whose interior contains (lo,hi)\n    var red0 = partitionInteriorContainsInterval(\n      d, axis, \n      redStart, redEnd, red, redIndex,\n      lo, hi)\n\n    //Lower dimensional case\n    if(redStart < red0) {\n\n      if(d * (red0 - redStart) < BRUTE_FORCE_CUTOFF) {\n        //Special case for small inputs: use brute force\n        retval = bruteForceFull(\n          d, axis+1, visit,\n          redStart, red0, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n      } else if(axis === d-2) {\n        if(flip) {\n          retval = sweep.sweepBipartite(\n            d, visit,\n            blueStart, blueEnd, blue, blueIndex,\n            redStart, red0, red, redIndex)\n        } else {\n          retval = sweep.sweepBipartite(\n            d, visit,\n            redStart, red0, red, redIndex,\n            blueStart, blueEnd, blue, blueIndex)\n        }\n        if(retval !== void 0) {\n          return retval\n        }\n      } else {\n        iterPush(top++,\n          axis+1,\n          redStart, red0,\n          blueStart, blueEnd,\n          flip,\n          -Infinity, Infinity)\n        iterPush(top++,\n          axis+1,\n          blueStart, blueEnd,\n          redStart, red0,\n          flip^1,\n          -Infinity, Infinity)\n      }\n    }\n\n    //Divide and conquer phase\n    if(red0 < redEnd) {\n\n      //Cut blue into 3 parts:\n      //\n      //  Points < mid point\n      //  Points = mid point\n      //  Points > mid point\n      //\n      var blue0 = findMedian(\n        d, axis, \n        blueStart, blueEnd, blue, blueIndex)\n      var mid = blue[elemSize * blue0 + axis]\n      var blue1 = partitionStartEqual(\n        d, axis,\n        blue0, blueEnd, blue, blueIndex,\n        mid)\n\n      //Right case\n      if(blue1 < blueEnd) {\n        iterPush(top++,\n          axis,\n          red0, redEnd,\n          blue1, blueEnd,\n          (flip|4) + (full ? 16 : 0),\n          mid, hi)\n      }\n\n      //Left case\n      if(blueStart < blue0) {\n        iterPush(top++,\n          axis,\n          red0, redEnd,\n          blueStart, blue0,\n          (flip|2) + (full ? 16 : 0),\n          lo, mid)\n      }\n\n      //Center case (the hard part)\n      if(blue0 + 1 === blue1) {\n        //Optimization: Range with exactly 1 point, use a brute force scan\n        if(full) {\n          retval = onePointFull(\n            d, axis, visit,\n            red0, redEnd, red, redIndex,\n            blue0, blue, blueIndex[blue0])\n        } else {\n          retval = onePointPartial(\n            d, axis, visit, flip,\n            red0, redEnd, red, redIndex,\n            blue0, blue, blueIndex[blue0])\n        }\n        if(retval !== void 0) {\n          return retval\n        }\n      } else if(blue0 < blue1) {\n        var red1\n        if(full) {\n          //If full intersection, need to handle special case\n          red1 = partitionContainsPoint(\n            d, axis,\n            red0, redEnd, red, redIndex,\n            mid)\n          if(red0 < red1) {\n            var redX = partitionStartEqual(\n              d, axis,\n              red0, red1, red, redIndex,\n              mid)\n            if(axis === d-2) {\n              //Degenerate sweep intersection:\n              //  [red0, redX] with [blue0, blue1]\n              if(red0 < redX) {\n                retval = sweep.sweepComplete(\n                  d, visit,\n                  red0, redX, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n                if(retval !== void 0) {\n                  return retval\n                }\n              }\n\n              //Normal sweep intersection:\n              //  [redX, red1] with [blue0, blue1]\n              if(redX < red1) {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  redX, red1, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n                if(retval !== void 0) {\n                  return retval\n                }\n              }\n            } else {\n              if(red0 < redX) {\n                iterPush(top++,\n                  axis+1,\n                  red0, redX,\n                  blue0, blue1,\n                  16,\n                  -Infinity, Infinity)\n              }\n              if(redX < red1) {\n                iterPush(top++,\n                  axis+1,\n                  redX, red1,\n                  blue0, blue1,\n                  0,\n                  -Infinity, Infinity)\n                iterPush(top++,\n                  axis+1,\n                  blue0, blue1,\n                  redX, red1,\n                  1,\n                  -Infinity, Infinity)\n              }\n            }\n          }\n        } else {\n          if(flip) {\n            red1 = partitionContainsPointProper(\n              d, axis,\n              red0, redEnd, red, redIndex,\n              mid)\n          } else {\n            red1 = partitionContainsPoint(\n              d, axis,\n              red0, redEnd, red, redIndex,\n              mid)\n          }\n          if(red0 < red1) {\n            if(axis === d-2) {\n              if(flip) {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  blue0, blue1, blue, blueIndex,\n                  red0, red1, red, redIndex)\n              } else {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  red0, red1, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n              }\n            } else {\n              iterPush(top++,\n                axis+1,\n                red0, red1,\n                blue0, blue1,\n                flip,\n                -Infinity, Infinity)\n              iterPush(top++,\n                axis+1,\n                blue0, blue1,\n                red0, red1,\n                flip^1,\n                -Infinity, Infinity)\n            }\n          }\n        }\n      }\n    }\n  }\n}","'use strict'\n\nmodule.exports = findMedian\n\nvar genPartition = require('./partition')\n\nvar partitionStartLessThan = genPartition('lo<p0', ['p0'])\n\nvar PARTITION_THRESHOLD = 8   //Cut off for using insertion sort in findMedian\n\n//Base case for median finding:  Use insertion sort\nfunction insertionSort(d, axis, start, end, boxes, ids) {\n  var elemSize = 2 * d\n  var boxPtr = elemSize * (start+1) + axis\n  for(var i=start+1; i<end; ++i, boxPtr+=elemSize) {\n    var x = boxes[boxPtr]\n    for(var j=i, ptr=elemSize*(i-1); \n        j>start && boxes[ptr+axis] > x; \n        --j, ptr-=elemSize) {\n      //Swap\n      var aPtr = ptr\n      var bPtr = ptr+elemSize\n      for(var k=0; k<elemSize; ++k, ++aPtr, ++bPtr) {\n        var y = boxes[aPtr]\n        boxes[aPtr] = boxes[bPtr]\n        boxes[bPtr] = y\n      }\n      var tmp = ids[j]\n      ids[j] = ids[j-1]\n      ids[j-1] = tmp\n    }\n  }\n}\n\n//Find median using quick select algorithm\n//  takes O(n) time with high probability\nfunction findMedian(d, axis, start, end, boxes, ids) {\n  if(end <= start+1) {\n    return start\n  }\n\n  var lo       = start\n  var hi       = end\n  var mid      = ((end + start) >>> 1)\n  var elemSize = 2*d\n  var pivot    = mid\n  var value    = boxes[elemSize*mid+axis]\n  \n  while(lo < hi) {\n    if(hi - lo < PARTITION_THRESHOLD) {\n      insertionSort(d, axis, lo, hi, boxes, ids)\n      value = boxes[elemSize*mid+axis]\n      break\n    }\n    \n    //Select pivot using median-of-3\n    var count  = hi - lo\n    var pivot0 = (Math.random()*count+lo)|0\n    var value0 = boxes[elemSize*pivot0 + axis]\n    var pivot1 = (Math.random()*count+lo)|0\n    var value1 = boxes[elemSize*pivot1 + axis]\n    var pivot2 = (Math.random()*count+lo)|0\n    var value2 = boxes[elemSize*pivot2 + axis]\n    if(value0 <= value1) {\n      if(value2 >= value1) {\n        pivot = pivot1\n        value = value1\n      } else if(value0 >= value2) {\n        pivot = pivot0\n        value = value0\n      } else {\n        pivot = pivot2\n        value = value2\n      }\n    } else {\n      if(value1 >= value2) {\n        pivot = pivot1\n        value = value1\n      } else if(value2 >= value0) {\n        pivot = pivot0\n        value = value0\n      } else {\n        pivot = pivot2\n        value = value2\n      }\n    }\n\n    //Swap pivot to end of array\n    var aPtr = elemSize * (hi-1)\n    var bPtr = elemSize * pivot\n    for(var i=0; i<elemSize; ++i, ++aPtr, ++bPtr) {\n      var x = boxes[aPtr]\n      boxes[aPtr] = boxes[bPtr]\n      boxes[bPtr] = x\n    }\n    var y = ids[hi-1]\n    ids[hi-1] = ids[pivot]\n    ids[pivot] = y\n\n    //Partition using pivot\n    pivot = partitionStartLessThan(\n      d, axis, \n      lo, hi-1, boxes, ids,\n      value)\n\n    //Swap pivot back\n    var aPtr = elemSize * (hi-1)\n    var bPtr = elemSize * pivot\n    for(var i=0; i<elemSize; ++i, ++aPtr, ++bPtr) {\n      var x = boxes[aPtr]\n      boxes[aPtr] = boxes[bPtr]\n      boxes[bPtr] = x\n    }\n    var y = ids[hi-1]\n    ids[hi-1] = ids[pivot]\n    ids[pivot] = y\n\n    //Swap pivot to last pivot\n    if(mid < pivot) {\n      hi = pivot-1\n      while(lo < hi && \n        boxes[elemSize*(hi-1)+axis] === value) {\n        hi -= 1\n      }\n      hi += 1\n    } else if(pivot < mid) {\n      lo = pivot + 1\n      while(lo < hi &&\n        boxes[elemSize*lo+axis] === value) {\n        lo += 1\n      }\n    } else {\n      break\n    }\n  }\n\n  //Make sure pivot is at start\n  return partitionStartLessThan(\n    d, axis, \n    start, mid, boxes, ids,\n    boxes[elemSize*mid+axis])\n}","'use strict'\n\nmodule.exports = genPartition\n\nvar code = 'for(var j=2*a,k=j*c,l=k,m=c,n=b,o=a+b,p=c;d>p;++p,k+=j){var _;if($)if(m===p)m+=1,l+=j;else{for(var s=0;j>s;++s){var t=e[k+s];e[k+s]=e[l],e[l++]=t}var u=f[p];f[p]=f[m],f[m++]=u}}return m'\n\nfunction genPartition(predicate, args) {\n  var fargs ='abcdef'.split('').concat(args)\n  var reads = []\n  if(predicate.indexOf('lo') >= 0) {\n    reads.push('lo=e[k+n]')\n  }\n  if(predicate.indexOf('hi') >= 0) {\n    reads.push('hi=e[k+o]')\n  }\n  fargs.push(\n    code.replace('_', reads.join())\n        .replace('$', predicate))\n  return Function.apply(void 0, fargs)\n}","'use strict';\n\n//This code is extracted from ndarray-sort\n//It is inlined here as a temporary workaround\n\nmodule.exports = wrapper;\n\nvar INSERT_SORT_CUTOFF = 32\n\nfunction wrapper(data, n0) {\n  if (n0 <= 4*INSERT_SORT_CUTOFF) {\n    insertionSort(0, n0 - 1, data);\n  } else {\n    quickSort(0, n0 - 1, data);\n  }\n}\n\nfunction insertionSort(left, right, data) {\n  var ptr = 2*(left+1)\n  for(var i=left+1; i<=right; ++i) {\n    var a = data[ptr++]\n    var b = data[ptr++]\n    var j = i\n    var jptr = ptr-2\n    while(j-- > left) {\n      var x = data[jptr-2]\n      var y = data[jptr-1]\n      if(x < a) {\n        break\n      } else if(x === a && y < b) {\n        break\n      }\n      data[jptr]   = x\n      data[jptr+1] = y\n      jptr -= 2\n    }\n    data[jptr]   = a\n    data[jptr+1] = b\n  }\n}\n\nfunction swap(i, j, data) {\n  i *= 2\n  j *= 2\n  var x = data[i]\n  var y = data[i+1]\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n  data[j] = x\n  data[j+1] = y\n}\n\nfunction move(i, j, data) {\n  i *= 2\n  j *= 2\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n}\n\nfunction rotate(i, j, k, data) {\n  i *= 2\n  j *= 2\n  k *= 2\n  var x = data[i]\n  var y = data[i+1]\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n  data[j] = data[k]\n  data[j+1] = data[k+1]\n  data[k] = x\n  data[k+1] = y\n}\n\nfunction shufflePivot(i, j, px, py, data) {\n  i *= 2\n  j *= 2\n  data[i] = data[j]\n  data[j] = px\n  data[i+1] = data[j+1]\n  data[j+1] = py\n}\n\nfunction compare(i, j, data) {\n  i *= 2\n  j *= 2\n  var x = data[i],\n      y = data[j]\n  if(x < y) {\n    return false\n  } else if(x === y) {\n    return data[i+1] > data[j+1]\n  }\n  return true\n}\n\nfunction comparePivot(i, y, b, data) {\n  i *= 2\n  var x = data[i]\n  if(x < y) {\n    return true\n  } else if(x === y) {\n    return data[i+1] < b\n  }\n  return false\n}\n\nfunction quickSort(left, right, data) {\n  var sixth = (right - left + 1) / 6 | 0, \n      index1 = left + sixth, \n      index5 = right - sixth, \n      index3 = left + right >> 1, \n      index2 = index3 - sixth, \n      index4 = index3 + sixth, \n      el1 = index1, \n      el2 = index2, \n      el3 = index3, \n      el4 = index4, \n      el5 = index5, \n      less = left + 1, \n      great = right - 1, \n      tmp = 0\n  if(compare(el1, el2, data)) {\n    tmp = el1\n    el1 = el2\n    el2 = tmp\n  }\n  if(compare(el4, el5, data)) {\n    tmp = el4\n    el4 = el5\n    el5 = tmp\n  }\n  if(compare(el1, el3, data)) {\n    tmp = el1\n    el1 = el3\n    el3 = tmp\n  }\n  if(compare(el2, el3, data)) {\n    tmp = el2\n    el2 = el3\n    el3 = tmp\n  }\n  if(compare(el1, el4, data)) {\n    tmp = el1\n    el1 = el4\n    el4 = tmp\n  }\n  if(compare(el3, el4, data)) {\n    tmp = el3\n    el3 = el4\n    el4 = tmp\n  }\n  if(compare(el2, el5, data)) {\n    tmp = el2\n    el2 = el5\n    el5 = tmp\n  }\n  if(compare(el2, el3, data)) {\n    tmp = el2\n    el2 = el3\n    el3 = tmp\n  }\n  if(compare(el4, el5, data)) {\n    tmp = el4\n    el4 = el5\n    el5 = tmp\n  }\n\n  var pivot1X = data[2*el2]\n  var pivot1Y = data[2*el2+1]\n  var pivot2X = data[2*el4]\n  var pivot2Y = data[2*el4+1]\n\n  var ptr0 = 2 * el1;\n  var ptr2 = 2 * el3;\n  var ptr4 = 2 * el5;\n  var ptr5 = 2 * index1;\n  var ptr6 = 2 * index3;\n  var ptr7 = 2 * index5;\n  for (var i1 = 0; i1 < 2; ++i1) {\n    var x = data[ptr0+i1];\n    var y = data[ptr2+i1];\n    var z = data[ptr4+i1];\n    data[ptr5+i1] = x;\n    data[ptr6+i1] = y;\n    data[ptr7+i1] = z;\n  }\n\n  move(index2, left, data)\n  move(index4, right, data)\n  for (var k = less; k <= great; ++k) {\n    if (comparePivot(k, pivot1X, pivot1Y, data)) {\n      if (k !== less) {\n        swap(k, less, data)\n      }\n      ++less;\n    } else {\n      if (!comparePivot(k, pivot2X, pivot2Y, data)) {\n        while (true) {\n          if (!comparePivot(great, pivot2X, pivot2Y, data)) {\n            if (--great < k) {\n              break;\n            }\n            continue;\n          } else {\n            if (comparePivot(great, pivot1X, pivot1Y, data)) {\n              rotate(k, less, great, data)\n              ++less;\n              --great;\n            } else {\n              swap(k, great, data)\n              --great;\n            }\n            break;\n          }\n        }\n      }\n    }\n  }\n  shufflePivot(left, less-1, pivot1X, pivot1Y, data)\n  shufflePivot(right, great+1, pivot2X, pivot2Y, data)\n  if (less - 2 - left <= INSERT_SORT_CUTOFF) {\n    insertionSort(left, less - 2, data);\n  } else {\n    quickSort(left, less - 2, data);\n  }\n  if (right - (great + 2) <= INSERT_SORT_CUTOFF) {\n    insertionSort(great + 2, right, data);\n  } else {\n    quickSort(great + 2, right, data);\n  }\n  if (great - less <= INSERT_SORT_CUTOFF) {\n    insertionSort(less, great, data);\n  } else {\n    quickSort(less, great, data);\n  }\n}","'use strict'\n\nmodule.exports = {\n  init:           sqInit,\n  sweepBipartite: sweepBipartite,\n  sweepComplete:  sweepComplete,\n  scanBipartite:  scanBipartite,\n  scanComplete:   scanComplete\n}\n\nvar pool  = require('typedarray-pool')\nvar bits  = require('bit-twiddle')\nvar isort = require('./sort')\n\n//Flag for blue\nvar BLUE_FLAG = (1<<28)\n\n//1D sweep event queue stuff (use pool to save space)\nvar INIT_CAPACITY      = 1024\nvar RED_SWEEP_QUEUE    = pool.mallocInt32(INIT_CAPACITY)\nvar RED_SWEEP_INDEX    = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_QUEUE   = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_INDEX   = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_QUEUE = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_INDEX = pool.mallocInt32(INIT_CAPACITY)\nvar SWEEP_EVENTS       = pool.mallocDouble(INIT_CAPACITY * 8)\n\n//Reserves memory for the 1D sweep data structures\nfunction sqInit(count) {\n  var rcount = bits.nextPow2(count)\n  if(RED_SWEEP_QUEUE.length < rcount) {\n    pool.free(RED_SWEEP_QUEUE)\n    RED_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(RED_SWEEP_INDEX.length < rcount) {\n    pool.free(RED_SWEEP_INDEX)\n    RED_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  if(BLUE_SWEEP_QUEUE.length < rcount) {\n    pool.free(BLUE_SWEEP_QUEUE)\n    BLUE_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(BLUE_SWEEP_INDEX.length < rcount) {\n    pool.free(BLUE_SWEEP_INDEX)\n    BLUE_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  if(COMMON_SWEEP_QUEUE.length < rcount) {\n    pool.free(COMMON_SWEEP_QUEUE)\n    COMMON_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(COMMON_SWEEP_INDEX.length < rcount) {\n    pool.free(COMMON_SWEEP_INDEX)\n    COMMON_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  var eventLength = 8 * rcount\n  if(SWEEP_EVENTS.length < eventLength) {\n    pool.free(SWEEP_EVENTS)\n    SWEEP_EVENTS = pool.mallocDouble(eventLength)\n  }\n}\n\n//Remove an item from the active queue in O(1)\nfunction sqPop(queue, index, count, item) {\n  var idx = index[item]\n  var top = queue[count-1]\n  queue[idx] = top\n  index[top] = idx\n}\n\n//Insert an item into the active queue in O(1)\nfunction sqPush(queue, index, count, item) {\n  queue[count] = item\n  index[item]  = count\n}\n\n//Recursion base case: use 1D sweep algorithm\nfunction sweepBipartite(\n    d, visit,\n    redStart,  redEnd, red, redIndex,\n    blueStart, blueEnd, blue, blueIndex) {\n\n  //store events as pairs [coordinate, idx]\n  //\n  //  red create:  -(idx+1)\n  //  red destroy: idx\n  //  blue create: -(idx+BLUE_FLAG)\n  //  blue destroy: idx+BLUE_FLAG\n  //\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = d-1\n  var iend     = elemSize-1\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = redIndex[i]\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -(idx+1)\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = blueIndex[i]+BLUE_FLAG\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive  = 0\n  var blueActive = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e >= BLUE_FLAG) {\n      //blue destroy event\n      e = (e-BLUE_FLAG)|0\n      sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, e)\n    } else if(e >= 0) {\n      //red destroy event\n      sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, e)\n    } else if(e <= -BLUE_FLAG) {\n      //blue create event\n      e = (-e-BLUE_FLAG)|0\n      for(var j=0; j<redActive; ++j) {\n        var retval = visit(RED_SWEEP_QUEUE[j], e)\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n      sqPush(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive++, e)\n    } else {\n      //red create event\n      e = (-e-1)|0\n      for(var j=0; j<blueActive; ++j) {\n        var retval = visit(e, BLUE_SWEEP_QUEUE[j])\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n      sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, e)\n    }\n  }\n}\n\n//Complete sweep\nfunction sweepComplete(d, visit, \n  redStart, redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = d-1\n  var iend     = elemSize-1\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = (redIndex[i]+1)<<1\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = (blueIndex[i]+1)<<1\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = (-idx)|1\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx|1\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  var blueActive   = 0\n  var commonActive = 0\n  for(var i=0; i<n; ++i) {\n    var e     = SWEEP_EVENTS[2*i+1]|0\n    var color = e&1\n    if(i < n-1 && (e>>1) === (SWEEP_EVENTS[2*i+3]>>1)) {\n      color = 2\n      i += 1\n    }\n    \n    if(e < 0) {\n      //Create event\n      var id = -(e>>1) - 1\n\n      //Intersect with common\n      for(var j=0; j<commonActive; ++j) {\n        var retval = visit(COMMON_SWEEP_QUEUE[j], id)\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n\n      if(color !== 0) {\n        //Intersect with red\n        for(var j=0; j<redActive; ++j) {\n          var retval = visit(RED_SWEEP_QUEUE[j], id)\n          if(retval !== void 0) {\n            return retval\n          }\n        }\n      }\n\n      if(color !== 1) {\n        //Intersect with blue\n        for(var j=0; j<blueActive; ++j) {\n          var retval = visit(BLUE_SWEEP_QUEUE[j], id)\n          if(retval !== void 0) {\n            return retval\n          }\n        }\n      }\n\n      if(color === 0) {\n        //Red\n        sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, id)\n      } else if(color === 1) {\n        //Blue\n        sqPush(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive++, id)\n      } else if(color === 2) {\n        //Both\n        sqPush(COMMON_SWEEP_QUEUE, COMMON_SWEEP_INDEX, commonActive++, id)\n      }\n    } else {\n      //Destroy event\n      var id = (e>>1) - 1\n      if(color === 0) {\n        //Red\n        sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, id)\n      } else if(color === 1) {\n        //Blue\n        sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, id)\n      } else if(color === 2) {\n        //Both\n        sqPop(COMMON_SWEEP_QUEUE, COMMON_SWEEP_INDEX, commonActive--, id)\n      }\n    }\n  }\n}\n\n//Sweep and prune/scanline algorithm:\n//  Scan along axis, detect intersections\n//  Brute force all boxes along axis\nfunction scanBipartite(\n  d, axis, visit, flip,\n  redStart,  redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n  \n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = axis\n  var iend     = axis+d\n\n  var redShift  = 1\n  var blueShift = 1\n  if(flip) {\n    blueShift = BLUE_FLAG\n  } else {\n    redShift  = BLUE_FLAG\n  }\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = i + redShift\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = i + blueShift\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e < 0) {\n      var idx   = -e\n      var isRed = false\n      if(idx >= BLUE_FLAG) {\n        isRed = !flip\n        idx -= BLUE_FLAG \n      } else {\n        isRed = !!flip\n        idx -= 1\n      }\n      if(isRed) {\n        sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, idx)\n      } else {\n        var blueId  = blueIndex[idx]\n        var bluePtr = elemSize * idx\n        \n        var b0 = blue[bluePtr+axis+1]\n        var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n        for(var j=0; j<redActive; ++j) {\n          var oidx   = RED_SWEEP_QUEUE[j]\n          var redPtr = elemSize * oidx\n\n          if(b1 < red[redPtr+axis+1] || \n             red[redPtr+axis+1+d] < b0) {\n            continue\n          }\n\n          for(var k=axis+2; k<d; ++k) {\n            if(blue[bluePtr + k + d] < red[redPtr + k] || \n               red[redPtr + k + d] < blue[bluePtr + k]) {\n              continue red_loop\n            }\n          }\n\n          var redId  = redIndex[oidx]\n          var retval\n          if(flip) {\n            retval = visit(blueId, redId)\n          } else {\n            retval = visit(redId, blueId)\n          }\n          if(retval !== void 0) {\n            return retval \n          }\n        }\n      }\n    } else {\n      sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, e - redShift)\n    }\n  }\n}\n\nfunction scanComplete(\n  d, axis, visit,\n  redStart,  redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = axis\n  var iend     = axis+d\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = i + BLUE_FLAG\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = i + 1\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e < 0) {\n      var idx   = -e\n      if(idx >= BLUE_FLAG) {\n        RED_SWEEP_QUEUE[redActive++] = idx - BLUE_FLAG\n      } else {\n        idx -= 1\n        var blueId  = blueIndex[idx]\n        var bluePtr = elemSize * idx\n\n        var b0 = blue[bluePtr+axis+1]\n        var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n        for(var j=0; j<redActive; ++j) {\n          var oidx   = RED_SWEEP_QUEUE[j]\n          var redId  = redIndex[oidx]\n\n          if(redId === blueId) {\n            break\n          }\n\n          var redPtr = elemSize * oidx\n          if(b1 < red[redPtr+axis+1] || \n            red[redPtr+axis+1+d] < b0) {\n            continue\n          }\n          for(var k=axis+2; k<d; ++k) {\n            if(blue[bluePtr + k + d] < red[redPtr + k] || \n               red[redPtr + k + d]   < blue[bluePtr + k]) {\n              continue red_loop\n            }\n          }\n\n          var retval = visit(redId, blueId)\n          if(retval !== void 0) {\n            return retval \n          }\n        }\n      }\n    } else {\n      var idx = e - BLUE_FLAG\n      for(var j=redActive-1; j>=0; --j) {\n        if(RED_SWEEP_QUEUE[j] === idx) {\n          for(var k=j+1; k<redActive; ++k) {\n            RED_SWEEP_QUEUE[k-1] = RED_SWEEP_QUEUE[k]\n          }\n          break\n        }\n      }\n      --redActive\n    }\n  }\n}","/**\n * Bit twiddling hacks for JavaScript.\n *\n * Author: Mikola Lysenko\n *\n * Ported from Stanford bit twiddling hack library:\n *    http://graphics.stanford.edu/~seander/bithacks.html\n */\n\n\"use strict\"; \"use restrict\";\n\n//Number of bits in an integer\nvar INT_BITS = 32;\n\n//Constants\nexports.INT_BITS  = INT_BITS;\nexports.INT_MAX   =  0x7fffffff;\nexports.INT_MIN   = -1<<(INT_BITS-1);\n\n//Returns -1, 0, +1 depending on sign of x\nexports.sign = function(v) {\n  return (v > 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n  var mask = v >> (INT_BITS-1);\n  return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n  return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n  return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n  return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n  var r, shift;\n  r =     (v > 0xFFFF) << 4; v >>>= r;\n  shift = (v > 0xFF  ) << 3; v >>>= shift; r |= shift;\n  shift = (v > 0xF   ) << 2; v >>>= shift; r |= shift;\n  shift = (v > 0x3   ) << 1; v >>>= shift; r |= shift;\n  return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n  return  (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n          (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n          (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n  v = v - ((v >>> 1) & 0x55555555);\n  v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n  return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n  var c = 32;\n  v &= -v;\n  if (v) c--;\n  if (v & 0x0000FFFF) c -= 16;\n  if (v & 0x00FF00FF) c -= 8;\n  if (v & 0x0F0F0F0F) c -= 4;\n  if (v & 0x33333333) c -= 2;\n  if (v & 0x55555555) c -= 1;\n  return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n  v += v === 0;\n  --v;\n  v |= v >>> 1;\n  v |= v >>> 2;\n  v |= v >>> 4;\n  v |= v >>> 8;\n  v |= v >>> 16;\n  return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n  v |= v >>> 1;\n  v |= v >>> 2;\n  v |= v >>> 4;\n  v |= v >>> 8;\n  v |= v >>> 16;\n  return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n  v ^= v >>> 16;\n  v ^= v >>> 8;\n  v ^= v >>> 4;\n  v &= 0xf;\n  return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n  for(var i=0; i<256; ++i) {\n    var v = i, r = i, s = 7;\n    for (v >>>= 1; v; v >>>= 1) {\n      r <<= 1;\n      r |= v & 1;\n      --s;\n    }\n    tab[i] = (r << s) & 0xff;\n  }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n  return  (REVERSE_TABLE[ v         & 0xff] << 24) |\n          (REVERSE_TABLE[(v >>> 8)  & 0xff] << 16) |\n          (REVERSE_TABLE[(v >>> 16) & 0xff] << 8)  |\n           REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits.  Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n  x &= 0xFFFF;\n  x = (x | (x << 8)) & 0x00FF00FF;\n  x = (x | (x << 4)) & 0x0F0F0F0F;\n  x = (x | (x << 2)) & 0x33333333;\n  x = (x | (x << 1)) & 0x55555555;\n\n  y &= 0xFFFF;\n  y = (y | (y << 8)) & 0x00FF00FF;\n  y = (y | (y << 4)) & 0x0F0F0F0F;\n  y = (y | (y << 2)) & 0x33333333;\n  y = (y | (y << 1)) & 0x55555555;\n\n  return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n  v = (v >>> n) & 0x55555555;\n  v = (v | (v >>> 1))  & 0x33333333;\n  v = (v | (v >>> 2))  & 0x0F0F0F0F;\n  v = (v | (v >>> 4))  & 0x00FF00FF;\n  v = (v | (v >>> 16)) & 0x000FFFF;\n  return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits.  Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n  x &= 0x3FF;\n  x  = (x | (x<<16)) & 4278190335;\n  x  = (x | (x<<8))  & 251719695;\n  x  = (x | (x<<4))  & 3272356035;\n  x  = (x | (x<<2))  & 1227133513;\n\n  y &= 0x3FF;\n  y  = (y | (y<<16)) & 4278190335;\n  y  = (y | (y<<8))  & 251719695;\n  y  = (y | (y<<4))  & 3272356035;\n  y  = (y | (y<<2))  & 1227133513;\n  x |= (y << 1);\n  \n  z &= 0x3FF;\n  z  = (z | (z<<16)) & 4278190335;\n  z  = (z | (z<<8))  & 251719695;\n  z  = (z | (z<<4))  & 3272356035;\n  z  = (z | (z<<2))  & 1227133513;\n  \n  return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n  v = (v >>> n)       & 1227133513;\n  v = (v | (v>>>2))   & 3272356035;\n  v = (v | (v>>>4))   & 251719695;\n  v = (v | (v>>>8))   & 4278190335;\n  v = (v | (v>>>16))  & 0x3FF;\n  return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n  var t = v | (v - 1);\n  return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n","\"use strict\"\n\nfunction dupe_array(count, value, i) {\n  var c = count[i]|0\n  if(c <= 0) {\n    return []\n  }\n  var result = new Array(c), j\n  if(i === count.length-1) {\n    for(j=0; j<c; ++j) {\n      result[j] = value\n    }\n  } else {\n    for(j=0; j<c; ++j) {\n      result[j] = dupe_array(count, value, i+1)\n    }\n  }\n  return result\n}\n\nfunction dupe_number(count, value) {\n  var result, i\n  result = new Array(count)\n  for(i=0; i<count; ++i) {\n    result[i] = value\n  }\n  return result\n}\n\nfunction dupe(count, value) {\n  if(typeof value === \"undefined\") {\n    value = 0\n  }\n  switch(typeof count) {\n    case \"number\":\n      if(count > 0) {\n        return dupe_number(count|0, value)\n      }\n    break\n    case \"object\":\n      if(typeof (count.length) === \"number\") {\n        return dupe_array(count, value, 0)\n      }\n    break\n  }\n  return []\n}\n\nmodule.exports = dupe","(function (global,Buffer){\n'use strict'\n\nvar bits = require('bit-twiddle')\nvar dup = require('dup')\n\n//Legacy pool support\nif(!global.__TYPEDARRAY_POOL) {\n  global.__TYPEDARRAY_POOL = {\n      UINT8   : dup([32, 0])\n    , UINT16  : dup([32, 0])\n    , UINT32  : dup([32, 0])\n    , INT8    : dup([32, 0])\n    , INT16   : dup([32, 0])\n    , INT32   : dup([32, 0])\n    , FLOAT   : dup([32, 0])\n    , DOUBLE  : dup([32, 0])\n    , DATA    : dup([32, 0])\n    , UINT8C  : dup([32, 0])\n    , BUFFER  : dup([32, 0])\n  }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar POOL = global.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n  POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n  POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA    = POOL.DATA\n  , BUFFER  = POOL.BUFFER\n\nexports.free = function free(array) {\n  if(Buffer.isBuffer(array)) {\n    BUFFER[bits.log2(array.length)].push(array)\n  } else {\n    if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n      array = array.buffer\n    }\n    if(!array) {\n      return\n    }\n    var n = array.length || array.byteLength\n    var log_n = bits.log2(n)|0\n    DATA[log_n].push(array)\n  }\n}\n\nfunction freeArrayBuffer(buffer) {\n  if(!buffer) {\n    return\n  }\n  var n = buffer.length || buffer.byteLength\n  var log_n = bits.log2(n)\n  DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n  freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n  BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n  if(dtype === undefined || dtype === 'arraybuffer') {\n    return mallocArrayBuffer(n)\n  } else {\n    switch(dtype) {\n      case 'uint8':\n        return mallocUint8(n)\n      case 'uint16':\n        return mallocUint16(n)\n      case 'uint32':\n        return mallocUint32(n)\n      case 'int8':\n        return mallocInt8(n)\n      case 'int16':\n        return mallocInt16(n)\n      case 'int32':\n        return mallocInt32(n)\n      case 'float':\n      case 'float32':\n        return mallocFloat(n)\n      case 'double':\n      case 'float64':\n        return mallocDouble(n)\n      case 'uint8_clamped':\n        return mallocUint8Clamped(n)\n      case 'buffer':\n        return mallocBuffer(n)\n      case 'data':\n      case 'dataview':\n        return mallocDataView(n)\n\n      default:\n        return null\n    }\n  }\n  return null\n}\n\nfunction mallocArrayBuffer(n) {\n  var n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var d = DATA[log_n]\n  if(d.length > 0) {\n    return d.pop()\n  }\n  return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n  return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n  return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n  return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n  return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n  return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n  return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n  return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n  return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n  if(hasUint8C) {\n    return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n  } else {\n    return mallocUint8(n)\n  }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocDataView(n) {\n  return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n  n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var cache = BUFFER[log_n]\n  if(cache.length > 0) {\n    return cache.pop()\n  }\n  return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n  for(var i=0; i<32; ++i) {\n    POOL.UINT8[i].length = 0\n    POOL.UINT16[i].length = 0\n    POOL.UINT32[i].length = 0\n    POOL.INT8[i].length = 0\n    POOL.INT16[i].length = 0\n    POOL.INT32[i].length = 0\n    POOL.FLOAT[i].length = 0\n    POOL.DOUBLE[i].length = 0\n    POOL.UINT8C[i].length = 0\n    DATA[i].length = 0\n    BUFFER[i].length = 0\n  }\n}\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {},require(\"buffer\").Buffer)\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/box-intersect/node_modules/typedarray-pool/pool.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["'use strict'\n\nvar bits = require('bit-twiddle')\nvar dup = require('dup')\n\n//Legacy pool support\nif(!global.__TYPEDARRAY_POOL) {\n  global.__TYPEDARRAY_POOL = {\n      UINT8   : dup([32, 0])\n    , UINT16  : dup([32, 0])\n    , UINT32  : dup([32, 0])\n    , INT8    : dup([32, 0])\n    , INT16   : dup([32, 0])\n    , INT32   : dup([32, 0])\n    , FLOAT   : dup([32, 0])\n    , DOUBLE  : dup([32, 0])\n    , DATA    : dup([32, 0])\n    , UINT8C  : dup([32, 0])\n    , BUFFER  : dup([32, 0])\n  }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar POOL = global.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n  POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n  POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA    = POOL.DATA\n  , BUFFER  = POOL.BUFFER\n\nexports.free = function free(array) {\n  if(Buffer.isBuffer(array)) {\n    BUFFER[bits.log2(array.length)].push(array)\n  } else {\n    if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n      array = array.buffer\n    }\n    if(!array) {\n      return\n    }\n    var n = array.length || array.byteLength\n    var log_n = bits.log2(n)|0\n    DATA[log_n].push(array)\n  }\n}\n\nfunction freeArrayBuffer(buffer) {\n  if(!buffer) {\n    return\n  }\n  var n = buffer.length || buffer.byteLength\n  var log_n = bits.log2(n)\n  DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n  freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n  BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n  if(dtype === undefined || dtype === 'arraybuffer') {\n    return mallocArrayBuffer(n)\n  } else {\n    switch(dtype) {\n      case 'uint8':\n        return mallocUint8(n)\n      case 'uint16':\n        return mallocUint16(n)\n      case 'uint32':\n        return mallocUint32(n)\n      case 'int8':\n        return mallocInt8(n)\n      case 'int16':\n        return mallocInt16(n)\n      case 'int32':\n        return mallocInt32(n)\n      case 'float':\n      case 'float32':\n        return mallocFloat(n)\n      case 'double':\n      case 'float64':\n        return mallocDouble(n)\n      case 'uint8_clamped':\n        return mallocUint8Clamped(n)\n      case 'buffer':\n        return mallocBuffer(n)\n      case 'data':\n      case 'dataview':\n        return mallocDataView(n)\n\n      default:\n        return null\n    }\n  }\n  return null\n}\n\nfunction mallocArrayBuffer(n) {\n  var n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var d = DATA[log_n]\n  if(d.length > 0) {\n    return d.pop()\n  }\n  return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n  return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n  return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n  return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n  return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n  return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n  return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n  return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n  return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n  if(hasUint8C) {\n    return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n  } else {\n    return mallocUint8(n)\n  }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocDataView(n) {\n  return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n  n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var cache = BUFFER[log_n]\n  if(cache.length > 0) {\n    return cache.pop()\n  }\n  return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n  for(var i=0; i<32; ++i) {\n    POOL.UINT8[i].length = 0\n    POOL.UINT16[i].length = 0\n    POOL.UINT32[i].length = 0\n    POOL.INT8[i].length = 0\n    POOL.INT16[i].length = 0\n    POOL.INT32[i].length = 0\n    POOL.FLOAT[i].length = 0\n    POOL.DOUBLE[i].length = 0\n    POOL.UINT8C[i].length = 0\n    DATA[i].length = 0\n    BUFFER[i].length = 0\n  }\n}"]}",null,"/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('is-array')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = Buffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192 // not used by this implementation\n\nvar kMaxLength = 0x3fffffff\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Note:\n *\n * - Implementation must support adding new properties to `Uint8Array` instances.\n *   Firefox 4-29 lacked support, fixed in Firefox 30+.\n *   See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *  - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *  - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *    incorrect length in some situations.\n *\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they will\n * get the Object implementation, which is slower but will work correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = (function () {\n  try {\n    var buf = new ArrayBuffer(0)\n    var arr = new Uint8Array(buf)\n    arr.foo = function () { return 42 }\n    return 42 === arr.foo() && // typed array instances can be augmented\n        typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n        new Uint8Array(1).subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  } catch (e) {\n    return false\n  }\n})()\n\n/**\n * Class: Buffer\n * =============\n *\n * The Buffer constructor returns instances of `Uint8Array` that are augmented\n * with function properties for all the node `Buffer` API functions. We use\n * `Uint8Array` so that square bracket notation works as expected -- it returns\n * a single octet.\n *\n * By augmenting the instances, we can avoid modifying the `Uint8Array`\n * prototype.\n */\nfunction Buffer (subject, encoding, noZero) {\n  if (!(this instanceof Buffer))\n    return new Buffer(subject, encoding, noZero)\n\n  var type = typeof subject\n\n  // Find the length\n  var length\n  if (type === 'number')\n    length = subject > 0 ? subject >>> 0 : 0\n  else if (type === 'string') {\n    if (encoding === 'base64')\n      subject = base64clean(subject)\n    length = Buffer.byteLength(subject, encoding)\n  } else if (type === 'object' && subject !== null) { // assume object is array-like\n    if (subject.type === 'Buffer' && isArray(subject.data))\n      subject = subject.data\n    length = +subject.length > 0 ? Math.floor(+subject.length) : 0\n  } else\n    throw new TypeError('must start with number, buffer, array or string')\n\n  if (this.length > kMaxLength)\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n      'size: 0x' + kMaxLength.toString(16) + ' bytes')\n\n  var buf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Preferred: Return an augmented `Uint8Array` instance for best performance\n    buf = Buffer._augment(new Uint8Array(length))\n  } else {\n    // Fallback: Return THIS instance of Buffer (created by `new`)\n    buf = this\n    buf.length = length\n    buf._isBuffer = true\n  }\n\n  var i\n  if (Buffer.TYPED_ARRAY_SUPPORT && typeof subject.byteLength === 'number') {\n    // Speed optimization -- use set if we're copying from a typed array\n    buf._set(subject)\n  } else if (isArrayish(subject)) {\n    // Treat array-ish objects as a byte array\n    if (Buffer.isBuffer(subject)) {\n      for (i = 0; i < length; i++)\n        buf[i] = subject.readUInt8(i)\n    } else {\n      for (i = 0; i < length; i++)\n        buf[i] = ((subject[i] % 256) + 256) % 256\n    }\n  } else if (type === 'string') {\n    buf.write(subject, 0, encoding)\n  } else if (type === 'number' && !Buffer.TYPED_ARRAY_SUPPORT && !noZero) {\n    for (i = 0; i < length; i++) {\n      buf[i] = 0\n    }\n  }\n\n  return buf\n}\n\nBuffer.isBuffer = function (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b))\n    throw new TypeError('Arguments must be Buffers')\n\n  var x = a.length\n  var y = b.length\n  for (var i = 0, len = Math.min(x, y); i < len && a[i] === b[i]; i++) {}\n  if (i !== len) {\n    x = a[i]\n    y = b[i]\n  }\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'binary':\n    case 'base64':\n    case 'raw':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function (list, totalLength) {\n  if (!isArray(list)) throw new TypeError('Usage: Buffer.concat(list[, length])')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  } else if (list.length === 1) {\n    return list[0]\n  }\n\n  var i\n  if (totalLength === undefined) {\n    totalLength = 0\n    for (i = 0; i < list.length; i++) {\n      totalLength += list[i].length\n    }\n  }\n\n  var buf = new Buffer(totalLength)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\nBuffer.byteLength = function (str, encoding) {\n  var ret\n  str = str + ''\n  switch (encoding || 'utf8') {\n    case 'ascii':\n    case 'binary':\n    case 'raw':\n      ret = str.length\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = str.length * 2\n      break\n    case 'hex':\n      ret = str.length >>> 1\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8ToBytes(str).length\n      break\n    case 'base64':\n      ret = base64ToBytes(str).length\n      break\n    default:\n      ret = str.length\n  }\n  return ret\n}\n\n// pre-set for values that may exist in the future\nBuffer.prototype.length = undefined\nBuffer.prototype.parent = undefined\n\n// toString(encoding, start=0, end=buffer.length)\nBuffer.prototype.toString = function (encoding, start, end) {\n  var loweredCase = false\n\n  start = start >>> 0\n  end = end === undefined || end === Infinity ? this.length : end >>> 0\n\n  if (!encoding) encoding = 'utf8'\n  if (start < 0) start = 0\n  if (end > this.length) end = this.length\n  if (end <= start) return ''\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'binary':\n        return binarySlice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase)\n          throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.equals = function (b) {\n  if(!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function () {\n  var str = ''\n  var max = exports.INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max)\n      str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  return Buffer.compare(this, b)\n}\n\n// `get` will be removed in Node 0.13+\nBuffer.prototype.get = function (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` will be removed in Node 0.13+\nBuffer.prototype.set = function (v, offset) {\n  console.log('.set() is deprecated. Access using array indexes instead.')\n  return this.writeUInt8(v, offset)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new Error('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; i++) {\n    var byte = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(byte)) throw new Error('Invalid hex string')\n    buf[offset + i] = byte\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  var charsWritten = blitBuffer(utf8ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  var charsWritten = blitBuffer(asciiToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction binaryWrite (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  var charsWritten = blitBuffer(base64ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction utf16leWrite (buf, string, offset, length) {\n  var charsWritten = blitBuffer(utf16leToBytes(string), buf, offset, length, 2)\n  return charsWritten\n}\n\nBuffer.prototype.write = function (string, offset, length, encoding) {\n  // Support both (string, offset, length, encoding)\n  // and the legacy (string, encoding, offset, length)\n  if (isFinite(offset)) {\n    if (!isFinite(length)) {\n      encoding = length\n      length = undefined\n    }\n  } else {  // legacy\n    var swap = encoding\n    encoding = offset\n    offset = length\n    length = swap\n  }\n\n  offset = Number(offset) || 0\n  var remaining = this.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n  encoding = String(encoding || 'utf8').toLowerCase()\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = hexWrite(this, string, offset, length)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8Write(this, string, offset, length)\n      break\n    case 'ascii':\n      ret = asciiWrite(this, string, offset, length)\n      break\n    case 'binary':\n      ret = binaryWrite(this, string, offset, length)\n      break\n    case 'base64':\n      ret = base64Write(this, string, offset, length)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = utf16leWrite(this, string, offset, length)\n      break\n    default:\n      throw new TypeError('Unknown encoding: ' + encoding)\n  }\n  return ret\n}\n\nBuffer.prototype.toJSON = function () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  var res = ''\n  var tmp = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    if (buf[i] <= 0x7F) {\n      res += decodeUtf8Char(tmp) + String.fromCharCode(buf[i])\n      tmp = ''\n    } else {\n      tmp += '%' + buf[i].toString(16)\n    }\n  }\n\n  return res + decodeUtf8Char(tmp)\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction binarySlice (buf, start, end) {\n  return asciiSlice(buf, start, end)\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; i++) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len;\n    if (start < 0)\n      start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0)\n      end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start)\n    end = start\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    return Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    var newBuf = new Buffer(sliceLen, undefined, true)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n    return newBuf\n  }\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0)\n    throw new RangeError('offset is not uint')\n  if (offset + ext > length)\n    throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUInt8 = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n      ((this[offset + 1] << 16) |\n      (this[offset + 2] << 8) |\n      this[offset + 3])\n}\n\nBuffer.prototype.readInt8 = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80))\n    return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16) |\n      (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n      (this[offset + 1] << 16) |\n      (this[offset + 2] << 8) |\n      (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance')\n  if (value > max || value < min) throw new TypeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new TypeError('index out of range')\n}\n\nBuffer.prototype.writeUInt8 = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = value\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else objectWriteUInt16(this, value, offset, true)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else objectWriteUInt16(this, value, offset, false)\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = value\n  } else objectWriteUInt32(this, value, offset, true)\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else objectWriteUInt32(this, value, offset, false)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt8 = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = value\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else objectWriteUInt16(this, value, offset, true)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else objectWriteUInt16(this, value, offset, false)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else objectWriteUInt32(this, value, offset, true)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else objectWriteUInt32(this, value, offset, false)\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (value > max || value < min) throw new TypeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new TypeError('index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert)\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert)\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function (target, target_start, start, end) {\n  var source = this\n\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (!target_start) target_start = 0\n\n  // Copy 0 bytes; we're done\n  if (end === start) return\n  if (target.length === 0 || source.length === 0) return\n\n  // Fatal error conditions\n  if (end < start) throw new TypeError('sourceEnd < sourceStart')\n  if (target_start < 0 || target_start >= target.length)\n    throw new TypeError('targetStart out of bounds')\n  if (start < 0 || start >= source.length) throw new TypeError('sourceStart out of bounds')\n  if (end < 0 || end > source.length) throw new TypeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length)\n    end = this.length\n  if (target.length - target_start < end - start)\n    end = target.length - target_start + start\n\n  var len = end - start\n\n  if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < len; i++) {\n      target[i + target_start] = this[i + start]\n    }\n  } else {\n    target._set(this.subarray(start, start + len), target_start)\n  }\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (end < start) throw new TypeError('end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  if (start < 0 || start >= this.length) throw new TypeError('start out of bounds')\n  if (end < 0 || end > this.length) throw new TypeError('end out of bounds')\n\n  var i\n  if (typeof value === 'number') {\n    for (i = start; i < end; i++) {\n      this[i] = value\n    }\n  } else {\n    var bytes = utf8ToBytes(value.toString())\n    var len = bytes.length\n    for (i = start; i < end; i++) {\n      this[i] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n/**\n * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.\n * Added in Node 0.12. Only available in browsers that support ArrayBuffer.\n */\nBuffer.prototype.toArrayBuffer = function () {\n  if (typeof Uint8Array !== 'undefined') {\n    if (Buffer.TYPED_ARRAY_SUPPORT) {\n      return (new Buffer(this)).buffer\n    } else {\n      var buf = new Uint8Array(this.length)\n      for (var i = 0, len = buf.length; i < len; i += 1) {\n        buf[i] = this[i]\n      }\n      return buf.buffer\n    }\n  } else {\n    throw new TypeError('Buffer.toArrayBuffer not supported in this browser')\n  }\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar BP = Buffer.prototype\n\n/**\n * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods\n */\nBuffer._augment = function (arr) {\n  arr.constructor = Buffer\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array get/set methods before overwriting\n  arr._get = arr.get\n  arr._set = arr.set\n\n  // deprecated, will be removed in node 0.13+\n  arr.get = BP.get\n  arr.set = BP.set\n\n  arr.write = BP.write\n  arr.toString = BP.toString\n  arr.toLocaleString = BP.toString\n  arr.toJSON = BP.toJSON\n  arr.equals = BP.equals\n  arr.compare = BP.compare\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUInt8 = BP.readUInt8\n  arr.readUInt16LE = BP.readUInt16LE\n  arr.readUInt16BE = BP.readUInt16BE\n  arr.readUInt32LE = BP.readUInt32LE\n  arr.readUInt32BE = BP.readUInt32BE\n  arr.readInt8 = BP.readInt8\n  arr.readInt16LE = BP.readInt16LE\n  arr.readInt16BE = BP.readInt16BE\n  arr.readInt32LE = BP.readInt32LE\n  arr.readInt32BE = BP.readInt32BE\n  arr.readFloatLE = BP.readFloatLE\n  arr.readFloatBE = BP.readFloatBE\n  arr.readDoubleLE = BP.readDoubleLE\n  arr.readDoubleBE = BP.readDoubleBE\n  arr.writeUInt8 = BP.writeUInt8\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeInt8 = BP.writeInt8\n  arr.writeInt16LE = BP.writeInt16LE\n  arr.writeInt16BE = BP.writeInt16BE\n  arr.writeInt32LE = BP.writeInt32LE\n  arr.writeInt32BE = BP.writeInt32BE\n  arr.writeFloatLE = BP.writeFloatLE\n  arr.writeFloatBE = BP.writeFloatBE\n  arr.writeDoubleLE = BP.writeDoubleLE\n  arr.writeDoubleBE = BP.writeDoubleBE\n  arr.fill = BP.fill\n  arr.inspect = BP.inspect\n  arr.toArrayBuffer = BP.toArrayBuffer\n\n  return arr\n}\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-z]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction isArrayish (subject) {\n  return isArray(subject) || Buffer.isBuffer(subject) ||\n      subject && typeof subject === 'object' &&\n      typeof subject.length === 'number'\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    var b = str.charCodeAt(i)\n    if (b <= 0x7F) {\n      byteArray.push(b)\n    } else {\n      var start = i\n      if (b >= 0xD800 && b <= 0xDFFF) i++\n      var h = encodeURIComponent(str.slice(start, i+1)).substr(1).split('%')\n      for (var j = 0; j < h.length; j++) {\n        byteArray.push(parseInt(h[j], 16))\n      }\n    }\n  }\n  return byteArray\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(str)\n}\n\nfunction blitBuffer (src, dst, offset, length, unitSize) {\n  if (unitSize) length -= length % unitSize;\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length))\n      break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction decodeUtf8Char (str) {\n  try {\n    return decodeURIComponent(str)\n  } catch (err) {\n    return String.fromCharCode(0xFFFD) // UTF 8 invalid char\n  }\n}\n","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH)\n\t\t\treturn 63 // '/'\n\t\tif (code < NUMBER)\n\t\t\treturn -1 //no match\n\t\tif (code < NUMBER + 10)\n\t\t\treturn code - NUMBER + 26 + 26\n\t\tif (code < UPPER + 26)\n\t\t\treturn code - UPPER\n\t\tif (code < LOWER + 26)\n\t\t\treturn code - LOWER + 26\n\t}\n\n\tfunction b64ToByteArray (b64) {\n\t\tvar i, j, l, tmp, placeHolders, arr\n\n\t\tif (b64.length % 4 > 0) {\n\t\t\tthrow new Error('Invalid string. Length must be a multiple of 4')\n\t\t}\n\n\t\t// the number of equal signs (place holders)\n\t\t// if there are two placeholders, than the two characters before it\n\t\t// represent one byte\n\t\t// if there is only one, then the three characters before it represent 2 bytes\n\t\t// this is just a cheap hack to not do indexOf twice\n\t\tvar len = b64.length\n\t\tplaceHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0\n\n\t\t// base64 is 4/3 + up to two characters of the original data\n\t\tarr = new Arr(b64.length * 3 / 4 - placeHolders)\n\n\t\t// if there are placeholders, only get up to the last complete 4 chars\n\t\tl = placeHolders > 0 ? b64.length - 4 : b64.length\n\n\t\tvar L = 0\n\n\t\tfunction push (v) {\n\t\t\tarr[L++] = v\n\t\t}\n\n\t\tfor (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))\n\t\t\tpush((tmp & 0xFF0000) >> 16)\n\t\t\tpush((tmp & 0xFF00) >> 8)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\tif (placeHolders === 2) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)\n\t\t\tpush(tmp & 0xFF)\n\t\t} else if (placeHolders === 1) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)\n\t\t\tpush((tmp >> 8) & 0xFF)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\treturn arr\n\t}\n\n\tfunction uint8ToBase64 (uint8) {\n\t\tvar i,\n\t\t\textraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes\n\t\t\toutput = \"\",\n\t\t\ttemp, length\n\n\t\tfunction encode (num) {\n\t\t\treturn lookup.charAt(num)\n\t\t}\n\n\t\tfunction tripletToBase64 (num) {\n\t\t\treturn encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)\n\t\t}\n\n\t\t// go through the array every three bytes, we'll deal with trailing stuff later\n\t\tfor (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {\n\t\t\ttemp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t\t\toutput += tripletToBase64(temp)\n\t\t}\n\n\t\t// pad the end with zeros, but make sure to not forget the extra bytes\n\t\tswitch (extraBytes) {\n\t\t\tcase 1:\n\t\t\t\ttemp = uint8[uint8.length - 1]\n\t\t\t\toutput += encode(temp >> 2)\n\t\t\t\toutput += encode((temp << 4) & 0x3F)\n\t\t\t\toutput += '=='\n\t\t\t\tbreak\n\t\t\tcase 2:\n\t\t\t\ttemp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])\n\t\t\t\toutput += encode(temp >> 10)\n\t\t\t\toutput += encode((temp >> 4) & 0x3F)\n\t\t\t\toutput += encode((temp << 2) & 0x3F)\n\t\t\t\toutput += '='\n\t\t\t\tbreak\n\t\t}\n\n\t\treturn output\n\t}\n\n\texports.toByteArray = b64ToByteArray\n\texports.fromByteArray = uint8ToBase64\n}(typeof exports === 'undefined' ? (this.base64js = {}) : exports))\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","\n/**\n * isArray\n */\n\nvar isArray = Array.isArray;\n\n/**\n * toString\n */\n\nvar str = Object.prototype.toString;\n\n/**\n * Whether or not the given `val`\n * is an array.\n *\n * example:\n *\n *        isArray([]);\n *        // > true\n *        isArray(arguments);\n *        // > false\n *        isArray('');\n *        // > false\n *\n * @param {mixed} val\n * @return {bool}\n */\n\nmodule.exports = isArray || function (val) {\n  return !! val && '[object Array]' == str.call(val);\n};\n","// (c) Dean McNamee <dean@gmail.com>, 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n  \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n  \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n  \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n  \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n  \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n  \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n  \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n  \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n  \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n  \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n  \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n  \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n  \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n  \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n  \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n  \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n  \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n  \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n  \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n  \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n  \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n  \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n  \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n  \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n  \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n  \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n  \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n  \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n  \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n  \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n  \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n  \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n  \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n  \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n  \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n  \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n  \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n  \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n  \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n  \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n  \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n  \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n  \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n  \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n  \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n  \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n  \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n  \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n  \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n  \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n  \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n  \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n  \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n  \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n  \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n  \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n  \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n  \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n  \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n  \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n  \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n  \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n  \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n  \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n  \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n  \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n  \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n  \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n  \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n  \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n  \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n  \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n  \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n  \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) {  // Clamp to integer 0 .. 255.\n  i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n  return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) {  // Clamp to float 0.0 .. 1.0.\n  return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) {  // int or percentage.\n  if (str[str.length - 1] === '%')\n    return clamp_css_byte(parseFloat(str) / 100 * 255);\n  return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) {  // float or percentage.\n  if (str[str.length - 1] === '%')\n    return clamp_css_float(parseFloat(str) / 100);\n  return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n  if (h < 0) h += 1;\n  else if (h > 1) h -= 1;\n\n  if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n  if (h * 2 < 1) return m2;\n  if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n  return m1;\n}\n\nfunction parseCSSColor(css_str) {\n  // Remove all whitespace, not compliant, but should just be more accepting.\n  var str = css_str.replace(/ /g, '').toLowerCase();\n\n  // Color keywords (and transparent) lookup.\n  if (str in kCSSColorTable) return kCSSColorTable[str].slice();  // dup.\n\n  // #abc and #abc123 syntax.\n  if (str[0] === '#') {\n    if (str.length === 4) {\n      var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n      if (!(iv >= 0 && iv <= 0xfff)) return null;  // Covers NaN.\n      return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n              (iv & 0xf0) | ((iv & 0xf0) >> 4),\n              (iv & 0xf) | ((iv & 0xf) << 4),\n              1];\n    } else if (str.length === 7) {\n      var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n      if (!(iv >= 0 && iv <= 0xffffff)) return null;  // Covers NaN.\n      return [(iv & 0xff0000) >> 16,\n              (iv & 0xff00) >> 8,\n              iv & 0xff,\n              1];\n    }\n\n    return null;\n  }\n\n  var op = str.indexOf('('), ep = str.indexOf(')');\n  if (op !== -1 && ep + 1 === str.length) {\n    var fname = str.substr(0, op);\n    var params = str.substr(op+1, ep-(op+1)).split(',');\n    var alpha = 1;  // To allow case fallthrough.\n    switch (fname) {\n      case 'rgba':\n        if (params.length !== 4) return null;\n        alpha = parse_css_float(params.pop());\n        // Fall through.\n      case 'rgb':\n        if (params.length !== 3) return null;\n        return [parse_css_int(params[0]),\n                parse_css_int(params[1]),\n                parse_css_int(params[2]),\n                alpha];\n      case 'hsla':\n        if (params.length !== 4) return null;\n        alpha = parse_css_float(params.pop());\n        // Fall through.\n      case 'hsl':\n        if (params.length !== 3) return null;\n        var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360;  // 0 .. 1\n        // NOTE(deanm): According to the CSS spec s/l should only be\n        // percentages, but we don't bother and let float or percentage.\n        var s = parse_css_float(params[1]);\n        var l = parse_css_float(params[2]);\n        var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n        var m1 = l * 2 - m2;\n        return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n                clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n                clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n                alpha];\n      default:\n        return null;\n    }\n  }\n\n  return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","'use strict';\n\nmodule.exports = earcut;\n\nfunction earcut(points) {\n\n    var outerNode = linkedList(points[0], true),\n        node, minX, minY, maxX, maxY, x, y, size,\n        len = 0,\n        threshold = 80;\n\n    for (var i = 0; len < threshold && i < points.length; i++) len += points[i].length;\n\n    // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n    if (len >= threshold) {\n        node = outerNode.next;\n        minX = maxX = node.p[0];\n        minY = maxY = node.p[1];\n        do {\n            x = node.p[0];\n            y = node.p[1];\n            if (x < minX) minX = x;\n            if (y < minY) minY = y;\n            if (x > maxX) maxX = x;\n            if (y > maxY) maxY = y;\n            node = node.next;\n        } while (node !== outerNode);\n\n        // minX, minY and size are later used to transform coords into integers for z-order calculation\n        size = Math.max(maxX - minX, maxY - minY);\n    }\n\n    if (points.length > 1) outerNode = eliminateHoles(points, outerNode);\n\n    var triangles = [];\n    if (outerNode) earcutLinked(outerNode, triangles, minX, minY, size);\n\n    return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(points, clockwise) {\n    var sum = 0,\n        len = points.length,\n        i, j, last;\n\n    // calculate original winding order of a polygon ring\n    for (i = 0, j = len - 1; i < len; j = i++) {\n        var p1 = points[i],\n            p2 = points[j];\n        sum += (p2[0] - p1[0]) * (p1[1] + p2[1]);\n    }\n\n    // link points into circular doubly-linked list in the specified winding order\n    if (clockwise === (sum > 0)) {\n        for (i = 0; i < len; i++) last = insertNode(points[i], last);\n    } else {\n        for (i = len - 1; i >= 0; i--) last = insertNode(points[i], last);\n    }\n\n    return last;\n}\n\nfunction filterPoints(start) {\n    // eliminate colinear or duplicate points\n    var node = start,\n        again;\n    do {\n        again = false;\n\n        if (equals(node.p, node.next.p) || orient(node.prev.p, node.p, node.next.p) === 0) {\n\n            node.prev.next = node.next;\n            node.next.prev = node.prev;\n\n            if (node.prevZ) node.prevZ.nextZ = node.nextZ;\n            if (node.nextZ) node.nextZ.prevZ = node.prevZ;\n\n            node = start = node.prev;\n\n            if (node === node.next) return null;\n            again = true;\n\n        } else {\n            node = node.next;\n        }\n    } while (again || node !== start);\n\n    return start;\n}\n\nfunction earcutLinked(ear, triangles, minX, minY, size, secondPass) {\n    ear = filterPoints(ear);\n    if (!ear) return;\n\n    if (!secondPass && minX !== undefined) indexCurve(ear, minX, minY, size);\n\n    var stop = ear,\n        prev, next;\n\n    // iterate through ears, slicing them one by one\n    while (ear.prev !== ear.next) {\n        prev = ear.prev;\n        next = ear.next;\n\n        if (isEar(ear, minX, minY, size)) {\n            triangles.push(prev.p, ear.p, next.p);\n\n            next.prev = prev;\n            prev.next = next;\n\n            if (ear.prevZ) ear.prevZ.nextZ = ear.nextZ;\n            if (ear.nextZ) ear.nextZ.prevZ = ear.prevZ;\n\n            ear = next.next;\n            stop = next.next;\n\n            continue;\n        }\n\n        ear = next;\n\n        if (ear === stop) {\n            // if we can't find any more ears, try filtering points and cutting again\n            if (!secondPass) earcutLinked(ear, triangles, minX, minY, size, true);\n            // if this didn't work, try splitting the remaining polygon into two\n            else splitEarcut(ear, triangles, minX, minY, size);\n            break;\n        }\n    }\n}\n\nfunction isEar(ear, minX, minY, size) {\n\n    var a = ear.prev.p,\n        b = ear.p,\n        c = ear.next.p,\n\n        ax = a[0], bx = b[0], cx = c[0],\n        ay = a[1], by = b[1], cy = c[1],\n\n        abd = ax * by - ay * bx,\n        acd = ax * cy - ay * cx,\n        cbd = cx * by - cy * bx,\n        A = abd - acd - cbd;\n\n    if (A <= 0) return false; // reflex, can't be an ear\n\n    // now make sure we don't have other points inside the potential ear\n\n    var cay = cy - ay,\n        acx = ax - cx,\n        aby = ay - by,\n        bax = bx - ax,\n        p, px, py, s, t, k, node;\n\n    // if we use z-order curve hashing, iterate through the curve\n    if (minX !== undefined) {\n\n        // triangle bbox; min & max are calculated like this for speed\n        var minTX = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n            minTY = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n            maxTX = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n            maxTY = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy),\n\n            // z-order range for the current triangle bbox;\n            minZ = zOrder(minTX, minTY, minX, minY, size),\n            maxZ = zOrder(maxTX, maxTY, minX, minY, size);\n\n        // first look for points inside the triangle in increasing z-order\n        node = ear.nextZ;\n\n        while (node && node.z <= maxZ) {\n            p = node.p;\n            node = node.nextZ;\n            if (p === a || p === c) continue;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n\n        // then look for points in decreasing z-order\n        node = ear.prevZ;\n\n        while (node && node.z >= minZ) {\n            p = node.p;\n            node = node.prevZ;\n            if (p === a || p === c) continue;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n\n    // if we don't use z-order curve hash, simply iterate through all other points\n    } else {\n        node = ear.next.next;\n\n        while (node !== ear.prev) {\n            p = node.p;\n            node = node.next;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n    }\n\n    return true;\n}\n\nfunction splitEarcut(start, triangles, minX, minY, size) {\n    // find a valid diagonal that divides the polygon into two\n    var a = start;\n    do {\n        var b = a.next.next;\n        while (b !== a.prev) {\n            if (isValidDiagonal(a, b)) {\n                // split the polygon in two by the diagonal\n                var c = splitPolygon(a, b);\n\n                // run earcut on each half\n                earcutLinked(a, triangles, minX, minY, size);\n                earcutLinked(c, triangles, minX, minY, size);\n                return;\n            }\n            b = b.next;\n        }\n        a = a.next;\n    } while (a !== start);\n}\n\nfunction eliminateHoles(points, outerNode) {\n    var len = points.length;\n\n    var queue = [];\n    for (var i = 1; i < len; i++) {\n        var list = filterPoints(linkedList(points[i], false));\n        if (list) queue.push(getLeftmost(list));\n    }\n    queue.sort(compareX);\n\n    // process holes from left to right\n    for (i = 0; i < queue.length; i++) {\n        eliminateHole(queue[i], outerNode);\n        outerNode = filterPoints(outerNode);\n    }\n\n    return outerNode;\n}\n\nfunction eliminateHole(holeNode, outerNode) {\n    outerNode = findHoleBridge(holeNode, outerNode);\n    if (outerNode) splitPolygon(holeNode, outerNode);\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(holeNode, outerNode) {\n    var node = outerNode,\n        p = holeNode.p,\n        px = p[0],\n        py = p[1],\n        qMax = -Infinity,\n        mNode, a, b;\n\n    // find a segment intersected by a ray from the hole's leftmost point to the left;\n    // segment's endpoint with lesser x will be potential connection point\n    do {\n        a = node.p;\n        b = node.next.p;\n\n        if (py <= a[1] && py >= b[1]) {\n            var qx = a[0] + (py - a[1]) * (b[0] - a[0]) / (b[1] - a[1]);\n            if (qx <= px && qx > qMax) {\n                qMax = qx;\n                mNode = a[0] < b[0] ? node : node.next;\n            }\n        }\n        node = node.next;\n    } while (node !== outerNode);\n\n    if (!mNode) return null;\n\n    // look for points strictly inside the triangle of hole point, segment intersection and endpoint;\n    // if there are no points found, we have a valid connection;\n    // otherwise choose the point of the minimum angle with the ray as connection point\n\n    var bx = mNode.p[0],\n        by = mNode.p[1],\n        pbd = px * by - py * bx,\n        pcd = px * py - py * qMax,\n        cpy = py - py,\n        pcx = px - qMax,\n        pby = py - by,\n        bpx = bx - px,\n        A = pbd - pcd - (qMax * by - py * bx),\n        sign = A <= 0 ? -1 : 1,\n        stop = mNode,\n        tanMin = Infinity,\n        mx, my, amx, s, t, tan;\n\n    node = mNode.next;\n\n    while (node !== stop) {\n\n        mx = node.p[0];\n        my = node.p[1];\n        amx = px - mx;\n\n        if (amx >= 0 && mx >= bx) {\n            s = (cpy * mx + pcx * my - pcd) * sign;\n            if (s >= 0) {\n                t = (pby * mx + bpx * my + pbd) * sign;\n\n                if (t >= 0 && A * sign - s - t >= 0) {\n                    tan = Math.abs(py - my) / amx; // tangential\n                    if (tan < tanMin && locallyInside(node, holeNode)) {\n                        mNode = node;\n                        tanMin = tan;\n                    }\n                }\n            }\n        }\n\n        node = node.next;\n    }\n\n    return mNode;\n}\n\nfunction indexCurve(start, minX, minY, size) {\n    var node = start;\n\n    do {\n        node.z = node.z || zOrder(node.p[0], node.p[1], minX, minY, size);\n        node.prevZ = node.prev;\n        node.nextZ = node.next;\n        node = node.next;\n    } while (node !== start);\n\n    node.prevZ.nextZ = null;\n    node.prevZ = null;\n\n    sortLinked(node);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n    var i, p, q, e, tail, numMerges, pSize, qSize,\n        inSize = 1;\n\n    while (true) {\n        p = list;\n        list = null;\n        tail = null;\n        numMerges = 0;\n\n        while (p) {\n            numMerges++;\n            q = p;\n            pSize = 0;\n            for (i = 0; i < inSize; i++) {\n                pSize++;\n                q = q.nextZ;\n                if (!q) break;\n            }\n\n            qSize = inSize;\n\n            while (pSize > 0 || (qSize > 0 && q)) {\n\n                if (pSize === 0) {\n                    e = q;\n                    q = q.nextZ;\n                    qSize--;\n                } else if (qSize === 0 || !q) {\n                    e = p;\n                    p = p.nextZ;\n                    pSize--;\n                } else if (p.z <= q.z) {\n                    e = p;\n                    p = p.nextZ;\n                    pSize--;\n                } else {\n                    e = q;\n                    q = q.nextZ;\n                    qSize--;\n                }\n\n                if (tail) tail.nextZ = e;\n                else list = e;\n\n                e.prevZ = tail;\n                tail = e;\n            }\n\n            p = q;\n        }\n\n        tail.nextZ = null;\n\n        if (numMerges <= 1) return list;\n\n        inSize *= 2;\n    }\n}\n\n// z-order of a point given coords and bbox\nfunction zOrder(x, y, minX, minY, size) {\n    // coords are transformed into (0..1000) integer range\n    x = 1000 * (x - minX) / size;\n    x = (x | (x << 8)) & 0x00FF00FF;\n    x = (x | (x << 4)) & 0x0F0F0F0F;\n    x = (x | (x << 2)) & 0x33333333;\n    x = (x | (x << 1)) & 0x55555555;\n\n    y = 1000 * (y - minY) / size;\n    y = (y | (y << 8)) & 0x00FF00FF;\n    y = (y | (y << 4)) & 0x0F0F0F0F;\n    y = (y | (y << 2)) & 0x33333333;\n    y = (y | (y << 1)) & 0x55555555;\n\n    return x | (y << 1);\n}\n\nfunction getLeftmost(start) {\n    var node = start,\n        leftmost = start;\n    do {\n        if (node.p[0] < leftmost.p[0]) leftmost = node;\n        node = node.next;\n    } while (node !== start);\n\n    return leftmost;\n}\n\nfunction isValidDiagonal(a, b) {\n    return !intersectsPolygon(a, a.p, b.p) &&\n           locallyInside(a, b) && locallyInside(b, a) &&\n           middleInside(a, a.p, b.p);\n}\n\n// winding order of triangle formed by 3 given points\nfunction orient(p, q, r) {\n    var o = (q[1] - p[1]) * (r[0] - q[0]) - (q[0] - p[0]) * (r[1] - q[1]);\n    return o > 0 ? 1 :\n           o < 0 ? -1 : 0;\n}\n\nfunction equals(p1, p2) {\n    return p1[0] === p2[0] && p1[1] === p2[1];\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n    return orient(p1, q1, p2) !== orient(p1, q1, q2) &&\n           orient(p2, q2, p1) !== orient(p2, q2, q1);\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(start, a, b) {\n    var node = start;\n    do {\n        var p1 = node.p,\n            p2 = node.next.p;\n\n        if (p1 !== a && p2 !== a && p1 !== b && p2 !== b && intersects(p1, p2, a, b)) return true;\n\n        node = node.next;\n    } while (node !== start);\n\n    return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n    return orient(a.prev.p, a.p, a.next.p) === -1 ?\n        orient(a.p, b.p, a.next.p) !== -1 && orient(a.p, a.prev.p, b.p) !== -1 :\n        orient(a.p, b.p, a.prev.p) === -1 || orient(a.p, a.next.p, b.p) === -1;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(start, a, b) {\n    var node = start,\n        inside = false,\n        px = (a[0] + b[0]) / 2,\n        py = (a[1] + b[1]) / 2;\n    do {\n        var p1 = node.p,\n            p2 = node.next.p;\n\n        if (((p1[1] > py) !== (p2[1] > py)) &&\n            (px < (p2[0] - p1[0]) * (py - p1[1]) / (p2[1] - p1[1]) + p1[0])) inside = !inside;\n\n        node = node.next;\n    } while (node !== start);\n\n    return inside;\n}\n\nfunction compareX(a, b) {\n    return a.p[0] - b.p[0];\n}\n\n// split the polygon vertices circular doubly-linked linked list into two\nfunction splitPolygon(a, b) {\n    var a2 = new Node(a.p),\n        b2 = new Node(b.p),\n        an = a.next,\n        bp = b.prev;\n\n    a.next = b;\n    b.prev = a;\n\n    a2.next = an;\n    an.prev = a2;\n\n    b2.next = a2;\n    a2.prev = b2;\n\n    bp.next = b2;\n    b2.prev = bp;\n\n    return a2;\n}\n\nfunction insertNode(point, last) {\n    var node = new Node(point);\n\n    if (!last) {\n        node.prev = node;\n        node.next = node;\n\n    } else {\n        node.next = last.next;\n        node.prev = last;\n        last.next.prev = node;\n        last.next = node;\n    }\n    return node;\n}\n\nfunction Node(p) {\n    this.p = p;\n    this.prev = null;\n    this.next = null;\n\n    this.z = null;\n    this.prevZ = null;\n    this.nextZ = null;\n}\n","'use strict';\n\nmodule.exports = clip;\n\n/* clip features between two axis-parallel lines:\n *     |        |\n *  ___|___     |     /\n * /   |   \\____|____/\n *     |        |\n */\n\nfunction clip(features, scale, k1, k2, axis, intersect, minAll, maxAll) {\n\n    k1 /= scale;\n    k2 /= scale;\n\n    if (minAll >= k1 && maxAll <= k2) return features; // trivial accept\n    else if (minAll > k2 || maxAll < k1) return null; // trivial reject\n\n    var clipped = [];\n\n    for (var i = 0; i < features.length; i++) {\n\n        var feature = features[i],\n            geometry = feature.geometry,\n            type = feature.type,\n            min, max;\n\n        min = feature.min[axis];\n        max = feature.max[axis];\n\n        if (min >= k1 && max <= k2) { // trivial accept\n            clipped.push(feature);\n            continue;\n        } else if (min > k2 || max < k1) continue; // trivial reject\n\n        var slices = type === 1 ?\n                clipPoints(geometry, k1, k2, axis) :\n                clipGeometry(geometry, k1, k2, axis, intersect, type === 3);\n\n        if (slices.length) {\n            // if a feature got clipped, it will likely get clipped on the next zoom level as well,\n            // so there's no need to recalculate bboxes\n            clipped.push({\n                geometry: slices,\n                type: type,\n                tags: features[i].tags || null,\n                min: feature.min,\n                max: feature.max\n            });\n        }\n    }\n\n    return clipped.length ? clipped : null;\n}\n\nfunction clipPoints(geometry, k1, k2, axis) {\n    var slice = [];\n\n    for (var i = 0; i < geometry.length; i++) {\n        var a = geometry[i],\n            ak = a[axis];\n\n        if (ak >= k1 && ak <= k2) slice.push(a);\n    }\n    return slice;\n}\n\nfunction clipGeometry(geometry, k1, k2, axis, intersect, closed) {\n\n    var slices = [];\n\n    for (var i = 0; i < geometry.length; i++) {\n\n        var ak = 0,\n            bk = 0,\n            b = null,\n            points = geometry[i],\n            area = points.area,\n            dist = points.dist,\n            len = points.length,\n            a, j, last;\n\n        var slice = [];\n\n        for (j = 0; j < len - 1; j++) {\n            a = b || points[j];\n            b = points[j + 1];\n            ak = bk || a[axis];\n            bk = b[axis];\n\n            if (ak < k1) {\n\n                if ((bk > k2)) { // ---|-----|-->\n                    slice.push(intersect(a, b, k1), intersect(a, b, k2));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk >= k1) slice.push(intersect(a, b, k1)); // ---|-->  |\n\n            } else if (ak > k2) {\n\n                if ((bk < k1)) { // <--|-----|---\n                    slice.push(intersect(a, b, k2), intersect(a, b, k1));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk <= k2) slice.push(intersect(a, b, k2)); // |  <--|---\n\n            } else {\n\n                slice.push(a);\n\n                if (bk < k1) { // <--|---  |\n                    slice.push(intersect(a, b, k1));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk > k2) { // |  ---|-->\n                    slice.push(intersect(a, b, k2));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n                }\n                // | --> |\n            }\n        }\n\n        // add the last point\n        a = points[len - 1];\n        ak = a[axis];\n        if (ak >= k1 && ak <= k2) slice.push(a);\n\n        // close the polygon if its endpoints are not the same after clipping\n\n        last = slice[slice.length - 1];\n        if (closed && last && (slice[0][0] !== last[0] || slice[0][1] !== last[1])) slice.push(slice[0]);\n\n        // add the final slice\n        newSlice(slices, slice, area, dist);\n    }\n\n    return slices;\n}\n\nfunction newSlice(slices, slice, area, dist) {\n    if (slice.length) {\n        // we don't recalculate the area/length of the unclipped geometry because the case where it goes\n        // below the visibility threshold as a result of clipping is rare, so we avoid doing unnecessary work\n        slice.area = area;\n        slice.dist = dist;\n\n        slices.push(slice);\n    }\n    return [];\n}\n","'use strict';\n\nmodule.exports = convert;\n\nvar simplify = require('./simplify');\n\n// converts GeoJSON feature into an intermediate projected JSON vector format with simplification data\n\nfunction convert(data, tolerance) {\n    var features = [];\n\n    if (data.type === 'FeatureCollection') {\n        for (var i = 0; i < data.features.length; i++) {\n            convertFeature(features, data.features[i], tolerance);\n        }\n    } else if (data.type === 'Feature') {\n        convertFeature(features, data, tolerance);\n\n    } else {\n        // single geometry or a geometry collection\n        convertFeature(features, {geometry: data}, tolerance);\n    }\n    return features;\n}\n\nfunction convertFeature(features, feature, tolerance) {\n    var geom = feature.geometry,\n        type = geom.type,\n        coords = geom.coordinates,\n        tags = feature.properties,\n        i, j, rings;\n\n    if (type === 'Point') {\n        features.push(create(tags, 1, [projectPoint(coords)]));\n\n    } else if (type === 'MultiPoint') {\n        features.push(create(tags, 1, project(coords)));\n\n    } else if (type === 'LineString') {\n        features.push(create(tags, 2, [project(coords, tolerance)]));\n\n    } else if (type === 'MultiLineString' || type === 'Polygon') {\n        rings = [];\n        for (i = 0; i < coords.length; i++) {\n            rings.push(project(coords[i], tolerance));\n        }\n        features.push(create(tags, type === 'Polygon' ? 3 : 2, rings));\n\n    } else if (type === 'MultiPolygon') {\n        rings = [];\n        for (i = 0; i < coords.length; i++) {\n            for (j = 0; j < coords[i].length; j++) {\n                rings.push(project(coords[i][j], tolerance));\n            }\n        }\n        features.push(create(tags, 3, rings));\n\n    } else if (type === 'GeometryCollection') {\n        for (i = 0; i < geom.geometries.length; i++) {\n            convertFeature(features, {\n                geometry: geom.geometries[i],\n                properties: tags\n            }, tolerance);\n        }\n\n    } else {\n        throw new Error('Input data is not a valid GeoJSON object.');\n    }\n}\n\nfunction create(tags, type, geometry) {\n    var feature = {\n        geometry: geometry,\n        type: type,\n        tags: tags || null,\n        min: [2, 1], // initial bbox values;\n        max: [-1, 0]  // note that coords are usually in [0..1] range\n    };\n    calcBBox(feature);\n    return feature;\n}\n\nfunction project(lonlats, tolerance) {\n    var projected = [];\n    for (var i = 0; i < lonlats.length; i++) {\n        projected.push(projectPoint(lonlats[i]));\n    }\n    if (tolerance) {\n        simplify(projected, tolerance);\n        calcSize(projected);\n    }\n    return projected;\n}\n\nfunction projectPoint(p) {\n    var sin = Math.sin(p[1] * Math.PI / 180),\n        x = (p[0] / 360 + 0.5),\n        y = (0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI);\n\n    y = y < -1 ? -1 :\n        y > 1 ? 1 : y;\n\n    return [x, y, 0];\n}\n\n// calculate area and length of the poly\nfunction calcSize(points) {\n    var area = 0,\n        dist = 0;\n\n    for (var i = 0, a, b; i < points.length - 1; i++) {\n        a = b || points[i];\n        b = points[i + 1];\n\n        area += a[0] * b[1] - b[0] * a[1];\n\n        // use Manhattan distance instead of Euclidian one to avoid expensive square root computation\n        dist += Math.abs(b[0] - a[0]) + Math.abs(b[1] - a[1]);\n    }\n    points.area = Math.abs(area / 2);\n    points.dist = dist;\n}\n\n// calculate the feature bounding box for faster clipping later\nfunction calcBBox(feature) {\n    var geometry = feature.geometry,\n        min = feature.min,\n        max = feature.max;\n\n    if (feature.type === 1) calcRingBBox(min, max, geometry);\n    else for (var i = 0; i < geometry.length; i++) calcRingBBox(min, max, geometry[i]);\n\n    return feature;\n}\n\nfunction calcRingBBox(min, max, points) {\n    for (var i = 0, p; i < points.length; i++) {\n        p = points[i];\n        min[0] = Math.min(p[0], min[0]);\n        max[0] = Math.max(p[0], max[0]);\n        min[1] = Math.min(p[1], min[1]);\n        max[1] = Math.max(p[1], max[1]);\n    }\n}\n","'use strict';\n\nmodule.exports = geojsonvt;\n\nvar convert = require('./convert'), // GeoJSON conversion and preprocessing\n    clip = require('./clip'),       // stripe clipping algorithm\n    wrap = require('./wrap'),       // date line processing\n    createTile = require('./tile'); // final simplified tile generation\n\n\nfunction geojsonvt(data, options) {\n    return new GeoJSONVT(data, options);\n}\n\nfunction GeoJSONVT(data, options) {\n    options = this.options = extend(Object.create(this.options), options);\n\n    var debug = options.debug;\n\n    if (debug) console.time('preprocess data');\n\n    var z2 = 1 << options.maxZoom, // 2^z\n        features = convert(data, options.tolerance / (z2 * options.extent));\n\n    this.tiles = {};\n\n    if (debug) {\n        console.timeEnd('preprocess data');\n        console.log('index: maxZoom: %d, maxPoints: %d', options.indexMaxZoom, options.indexMaxPoints);\n        console.time('generate tiles');\n        this.stats = {};\n        this.total = 0;\n    }\n\n    features = wrap(features, options.buffer / options.extent, intersectX);\n\n    // start slicing from the top tile down\n    this.splitTile(features, 0, 0, 0);\n\n    if (debug) {\n        console.log('features: %d, points: %d', this.tiles[0].numFeatures, this.tiles[0].numPoints);\n        console.timeEnd('generate tiles');\n        console.log('tiles generated:', this.total, JSON.stringify(this.stats));\n    }\n}\n\nGeoJSONVT.prototype.options = {\n    maxZoom: 14,            // max zoom to preserve detail on\n    indexMaxZoom: 5,        // max zoom in the tile index\n    indexMaxPoints: 100000, // max number of points per tile in the tile index\n    tolerance: 3,           // simplification tolerance (higher means simpler)\n    extent: 4096,           // tile extent\n    buffer: 64,             // tile buffer on each side\n    debug: 0                // logging level (0, 1 or 2)\n};\n\nGeoJSONVT.prototype.splitTile = function (features, z, x, y, cz, cx, cy) {\n\n    var stack = [features, z, x, y],\n        options = this.options,\n        debug = options.debug,\n        extent = options.extent,\n        buffer = options.buffer;\n\n    // avoid recursion by using a processing queue\n    while (stack.length) {\n        features = stack.shift();\n        z = stack.shift();\n        x = stack.shift();\n        y = stack.shift();\n\n        var z2 = 1 << z,\n            id = toID(z, x, y),\n            tile = this.tiles[id],\n            tileTolerance = z === options.maxZoom ? 0 : options.tolerance / (z2 * extent);\n\n        if (!tile) {\n            if (debug > 1) console.time('creation');\n\n            tile = this.tiles[id] = createTile(features, z2, x, y, tileTolerance, z === options.maxZoom);\n\n            if (debug) {\n                if (debug > 1) {\n                    console.log('tile z%d-%d-%d (features: %d, points: %d, simplified: %d)',\n                        z, x, y, tile.numFeatures, tile.numPoints, tile.numSimplified);\n                    console.timeEnd('creation');\n                }\n                var key = 'z' + z;\n                this.stats[key] = (this.stats[key] || 0) + 1;\n                this.total++;\n            }\n        }\n\n        // save reference to original geometry in tile so that we can drill down later if we stop now\n        tile.source = features;\n\n        // stop tiling if the tile is degenerate\n        if (isClippedSquare(tile.features, extent, buffer)) continue;\n\n        // if it's the first-pass tiling\n        if (!cz) {\n            // stop tiling if we reached max zoom, or if the tile is too simple\n            if (z === options.indexMaxZoom || tile.numPoints <= options.indexMaxPoints) continue;\n\n        // if a drilldown to a specific tile\n        } else {\n            // stop tiling if we reached base zoom or our target tile zoom\n            if (z === options.maxZoom || z === cz) continue;\n\n            // stop tiling if it's not an ancestor of the target tile\n            var m = 1 << (cz - z);\n            if (x !== Math.floor(cx / m) && y !== Math.floor(cy / m)) continue;\n        }\n\n        // if we slice further down, no need to keep source geometry\n        tile.source = null;\n\n        if (debug > 1) console.time('clipping');\n\n        // values we'll use for clipping\n        var k1 = 0.5 * buffer / extent,\n            k2 = 0.5 - k1,\n            k3 = 0.5 + k1,\n            k4 = 1 + k1,\n            tl, bl, tr, br, left, right;\n\n        tl = bl = tr = br = null;\n\n        left  = clip(features, z2, x - k1, x + k3, 0, intersectX, tile.min[0], tile.max[0]);\n        right = clip(features, z2, x + k2, x + k4, 0, intersectX, tile.min[0], tile.max[0]);\n\n        if (left) {\n            tl = clip(left, z2, y - k1, y + k3, 1, intersectY, tile.min[1], tile.max[1]);\n            bl = clip(left, z2, y + k2, y + k4, 1, intersectY, tile.min[1], tile.max[1]);\n        }\n\n        if (right) {\n            tr = clip(right, z2, y - k1, y + k3, 1, intersectY, tile.min[1], tile.max[1]);\n            br = clip(right, z2, y + k2, y + k4, 1, intersectY, tile.min[1], tile.max[1]);\n        }\n\n        if (debug > 1) console.timeEnd('clipping');\n\n        if (tl) stack.push(tl, z + 1, x * 2,     y * 2);\n        if (bl) stack.push(bl, z + 1, x * 2,     y * 2 + 1);\n        if (tr) stack.push(tr, z + 1, x * 2 + 1, y * 2);\n        if (br) stack.push(br, z + 1, x * 2 + 1, y * 2 + 1);\n    }\n};\n\nGeoJSONVT.prototype.getTile = function (z, x, y) {\n    var options = this.options,\n        extent = options.extent,\n        debug = options.debug;\n\n    var z2 = 1 << z;\n    x = ((x % z2) + z2) % z2; // wrap tile x coordinate\n\n    var id = toID(z, x, y);\n    if (this.tiles[id]) return transformTile(this.tiles[id], extent);\n\n    if (debug > 1) console.log('drilling down to z%d-%d-%d', z, x, y);\n\n    var z0 = z,\n        x0 = x,\n        y0 = y,\n        parent;\n\n    while (!parent && z0 > 0) {\n        z0--;\n        x0 = Math.floor(x0 / 2);\n        y0 = Math.floor(y0 / 2);\n        parent = this.tiles[toID(z0, x0, y0)];\n    }\n\n    if (debug > 1) console.log('found parent tile z%d-%d-%d', z0, x0, y0);\n\n    // if we found a parent tile containing the original geometry, we can drill down from it\n    if (parent.source) {\n        if (isClippedSquare(parent.features, options.extent, options.buffer)) return transformTile(parent, extent);\n\n        if (debug > 1) console.time('drilling down');\n        this.splitTile(parent.source, z0, x0, y0, z, x, y);\n        if (debug > 1) console.timeEnd('drilling down');\n    }\n\n    return transformTile(this.tiles[id], extent);\n};\n\nfunction transformTile(tile, extent) {\n    if (!tile || tile.transformed) return tile;\n\n    var z2 = tile.z2,\n        tx = tile.x,\n        ty = tile.y,\n        i, j, k;\n\n    for (i = 0; i < tile.features.length; i++) {\n        var feature = tile.features[i],\n            geom = feature.geometry,\n            type = feature.type;\n\n        if (type === 1) {\n            for (j = 0; j < geom.length; j++) geom[j] = transformPoint(geom[j], extent, z2, tx, ty);\n\n        } else {\n            for (j = 0; j < geom.length; j++) {\n                var ring = geom[j];\n                for (k = 0; k < ring.length; k++) ring[k] = transformPoint(ring[k], extent, z2, tx, ty);\n            }\n        }\n    }\n\n    tile.transformed = true;\n\n    return tile;\n}\n\nfunction transformPoint(p, extent, z2, tx, ty) {\n    var x = Math.round(extent * (p[0] * z2 - tx)),\n        y = Math.round(extent * (p[1] * z2 - ty));\n    return [x, y];\n}\n\n// checks whether a tile is a whole-area fill after clipping; if it is, there's no sense slicing it further\nfunction isClippedSquare(features, extent, buffer) {\n    if (features.length !== 1) return false;\n\n    var feature = features[0];\n    if (feature.type !== 3 || feature.geometry.length > 1) return false;\n\n    for (var i = 0; i < feature.geometry[0].length; i++) {\n        var p = feature.geometry[0][i];\n        if ((p[0] !== -buffer && p[0] !== extent + buffer) ||\n            (p[1] !== -buffer && p[1] !== extent + buffer)) return false;\n    }\n    return true;\n}\n\nfunction toID(z, x, y) {\n    return (((1 << z) * y + x) * 32) + z;\n}\n\nfunction intersectX(a, b, x) {\n    return [x, (x - a[0]) * (b[1] - a[1]) / (b[0] - a[0]) + a[1], 1];\n}\nfunction intersectY(a, b, y) {\n    return [(y - a[1]) * (b[0] - a[0]) / (b[1] - a[1]) + a[0], y, 1];\n}\n\nfunction extend(dest, src) {\n    for (var i in src) dest[i] = src[i];\n    return dest;\n}\n","'use strict';\n\nmodule.exports = simplify;\n\n// calculate simplification data using optimized Douglas-Peucker algorithm\n\nfunction simplify(points, tolerance) {\n\n    var sqTolerance = tolerance * tolerance,\n        len = points.length,\n        first = 0,\n        last = len - 1,\n        stack = [],\n        i, maxSqDist, sqDist, index;\n\n    // always retain the endpoints (1 is the max value)\n    points[first][2] = 1;\n    points[last][2] = 1;\n\n    // avoid recursion by using a stack\n    while (last) {\n\n        maxSqDist = 0;\n\n        for (i = first + 1; i < last; i++) {\n            sqDist = getSqSegDist(points[i], points[first], points[last]);\n\n            if (sqDist > maxSqDist) {\n                index = i;\n                maxSqDist = sqDist;\n            }\n        }\n\n        if (maxSqDist > sqTolerance) {\n            points[index][2] = maxSqDist; // save the point importance in squared pixels as a z coordinate\n            stack.push(first);\n            stack.push(index);\n            first = index;\n\n        } else {\n            last = stack.pop();\n            first = stack.pop();\n        }\n    }\n}\n\n// square distance from a point to a segment\nfunction getSqSegDist(p, a, b) {\n\n    var x = a[0], y = a[1],\n        bx = b[0], by = b[1],\n        px = p[0], py = p[1],\n        dx = bx - x,\n        dy = by - y;\n\n    if (dx !== 0 || dy !== 0) {\n\n        var t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);\n\n        if (t > 1) {\n            x = bx;\n            y = by;\n\n        } else if (t > 0) {\n            x += dx * t;\n            y += dy * t;\n        }\n    }\n\n    dx = px - x;\n    dy = py - y;\n\n    return dx * dx + dy * dy;\n}\n","'use strict';\n\nmodule.exports = createTile;\n\nfunction createTile(features, z2, tx, ty, tolerance, noSimplify) {\n    var tile = {\n        features: [],\n        numPoints: 0,\n        numSimplified: 0,\n        numFeatures: 0,\n        source: null,\n        x: tx,\n        y: ty,\n        z2: z2,\n        transformed: false,\n        min: [2, 1],\n        max: [-1, 0]\n    };\n    for (var i = 0; i < features.length; i++) {\n        tile.numFeatures++;\n        addFeature(tile, features[i], tolerance, noSimplify);\n\n        var min = features[i].min,\n            max = features[i].max;\n\n        if (min[0] < tile.min[0]) tile.min[0] = min[0];\n        if (min[1] < tile.min[1]) tile.min[1] = min[1];\n        if (max[0] > tile.max[0]) tile.max[0] = max[0];\n        if (max[1] > tile.max[1]) tile.max[1] = max[1];\n    }\n    return tile;\n}\n\nfunction addFeature(tile, feature, tolerance, noSimplify) {\n\n    var geom = feature.geometry,\n        type = feature.type,\n        simplified = [],\n        sqTolerance = tolerance * tolerance,\n        i, j, ring, p;\n\n    if (type === 1) {\n        for (i = 0; i < geom.length; i++) {\n            simplified.push(geom[i]);\n            tile.numPoints++;\n            tile.numSimplified++;\n        }\n\n    } else {\n\n        // simplify and transform projected coordinates for tile geometry\n        for (i = 0; i < geom.length; i++) {\n            ring = geom[i];\n\n            // filter out tiny polylines & polygons\n            if (!noSimplify && ((type === 2 && ring.dist < tolerance) ||\n                                (type === 3 && ring.area < sqTolerance))) {\n                tile.numPoints += ring.length;\n                continue;\n            }\n\n            var simplifiedRing = [];\n\n            for (j = 0; j < ring.length; j++) {\n                p = ring[j];\n                // keep points with importance > tolerance\n                if (noSimplify || p[2] > sqTolerance) {\n                    simplifiedRing.push(p);\n                    tile.numSimplified++;\n                }\n                tile.numPoints++;\n            }\n\n            simplified.push(simplifiedRing);\n        }\n    }\n\n    if (simplified.length) {\n        tile.features.push({\n            geometry: simplified,\n            type: type,\n            tags: feature.tags || null\n        });\n    }\n}\n","'use strict';\n\nvar clip = require('./clip');\n\nmodule.exports = wrap;\n\nfunction wrap(features, buffer, intersectX) {\n    var merged = features,\n        left  = clip(features, 1, -1 - buffer, buffer,     0, intersectX, -1, 2), // left world copy\n        right = clip(features, 1,  1 - buffer, 2 + buffer, 0, intersectX, -1, 2); // right world copy\n\n    if (left || right) {\n        merged = clip(features, 1, -buffer, 1 + buffer, 0, intersectX, -1, 2); // center world copy\n\n        if (left) merged = shiftFeatureCoords(left, 1).concat(merged); // merge left into center\n        if (right) merged = merged.concat(shiftFeatureCoords(right, -1)); // merge right into center\n    }\n\n    return merged;\n}\n\nfunction shiftFeatureCoords(features, offset) {\n    var newFeatures = [];\n\n    for (var i = 0; i < features.length; i++) {\n        var feature = features[i],\n            type = feature.type;\n\n        var newGeometry;\n\n        if (type === 1) {\n            newGeometry = shiftCoords(feature.geometry, offset);\n        } else {\n            newGeometry = [];\n            for (var j = 0; j < feature.geometry.length; j++) {\n                newGeometry.push(shiftCoords(feature.geometry[j], offset));\n            }\n        }\n\n        newFeatures.push({\n            geometry: newGeometry,\n            type: type,\n            tags: feature.tags,\n            min: [feature.min[0] + offset, feature.min[1]],\n            max: [feature.max[0] + offset, feature.max[1]]\n        });\n    }\n\n    return newFeatures;\n}\n\nfunction shiftCoords(points, offset) {\n    var newPoints = [];\n    newPoints.area = points.area;\n    newPoints.dist = points.dist;\n\n    for (var i = 0; i < points.length; i++) {\n        newPoints.push([points[i][0] + offset, points[i][1], points[i][2]]);\n    }\n    return newPoints;\n}\n","/**\n * @fileoverview gl-matrix - High performance matrix and vector operations\n * @author Brandon Jones\n * @author Colin MacKenzie IV\n * @version 2.2.1\n */\n\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\n(function(_global) {\n  \"use strict\";\n\n  var shim = {};\n  if (typeof(exports) === 'undefined') {\n    if(typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n      shim.exports = {};\n      define(function() {\n        return shim.exports;\n      });\n    } else {\n      // gl-matrix lives in a browser, define its namespaces in global\n      shim.exports = typeof(window) !== 'undefined' ? window : _global;\n    }\n  }\n  else {\n    // gl-matrix lives in commonjs, define its namespaces in exports\n    shim.exports = exports;\n  }\n\n  (function(exports) {\n    /* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\nif(!GLMAT_EPSILON) {\n    var GLMAT_EPSILON = 0.000001;\n}\n\nif(!GLMAT_ARRAY_TYPE) {\n    var GLMAT_ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;\n}\n\nif(!GLMAT_RANDOM) {\n    var GLMAT_RANDOM = Math.random;\n}\n\n/**\n * @class Common utilities\n * @name glMatrix\n */\nvar glMatrix = {};\n\n/**\n * Sets the type of array used when creating new vectors and matricies\n *\n * @param {Type} type Array type, such as Float32Array or Array\n */\nglMatrix.setMatrixArrayType = function(type) {\n    GLMAT_ARRAY_TYPE = type;\n}\n\nif(typeof(exports) !== 'undefined') {\n    exports.glMatrix = glMatrix;\n}\n\nvar degree = Math.PI / 180;\n\n/**\n* Convert Degree To Radian\n*\n* @param {Number} Angle in Degrees\n*/\nglMatrix.toRadian = function(a){\n     return a * degree;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2 Dimensional Vector\n * @name vec2\n */\n\nvar vec2 = {};\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nvec2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = 0;\n    out[1] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nvec2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nvec2.fromValues = function(x, y) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nvec2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nvec2.set = function(out, x, y) {\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nvec2.sub = vec2.subtract;\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nvec2.mul = vec2.multiply;\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nvec2.div = vec2.divide;\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    return out;\n};\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nvec2.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    return out;\n};\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nvec2.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nvec2.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nvec2.dist = vec2.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec2.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nvec2.sqrDist = vec2.squaredDistance;\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec2.length = function (a) {\n    var x = a[0],\n        y = a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nvec2.len = vec2.length;\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec2.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nvec2.sqrLen = vec2.squaredLength;\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nvec2.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    return out;\n};\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nvec2.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1];\n    var len = x*x + y*y;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec2.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1];\n};\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nvec2.cross = function(out, a, b) {\n    var z = a[0] * b[1] - a[1] * b[0];\n    out[0] = out[1] = 0;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nvec2.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nvec2.random = function (out, scale) {\n    scale = scale || 1.0;\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    out[0] = Math.cos(r) * scale;\n    out[1] = Math.sin(r) * scale;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y;\n    out[1] = m[1] * x + m[3] * y;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2d = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y + m[4];\n    out[1] = m[1] * x + m[3] * y + m[5];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat3 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[3] * y + m[6];\n    out[1] = m[1] * x + m[4] * y + m[7];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat4 = function(out, a, m) {\n    var x = a[0], \n        y = a[1];\n    out[0] = m[0] * x + m[4] * y + m[12];\n    out[1] = m[1] * x + m[5] * y + m[13];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec2.forEach = (function() {\n    var vec = vec2.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 2;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec2} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec2.str = function (a) {\n    return 'vec2(' + a[0] + ', ' + a[1] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec2 = vec2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3 Dimensional Vector\n * @name vec3\n */\n\nvar vec3 = {};\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nvec3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nvec3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nvec3.fromValues = function(x, y, z) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nvec3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nvec3.set = function(out, x, y, z) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nvec3.sub = vec3.subtract;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nvec3.mul = vec3.multiply;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nvec3.div = vec3.divide;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    return out;\n};\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nvec3.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    return out;\n};\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nvec3.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nvec3.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nvec3.dist = vec3.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec3.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nvec3.sqrDist = vec3.squaredDistance;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec3.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nvec3.len = vec3.length;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec3.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nvec3.sqrLen = vec3.squaredLength;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nvec3.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    return out;\n};\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nvec3.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    var len = x*x + y*y + z*z;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec3.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n};\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.cross = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2],\n        bx = b[0], by = b[1], bz = b[2];\n\n    out[0] = ay * bz - az * by;\n    out[1] = az * bx - ax * bz;\n    out[2] = ax * by - ay * bx;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nvec3.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    var z = (GLMAT_RANDOM() * 2.0) - 1.0;\n    var zScale = Math.sqrt(1.0-z*z) * scale;\n\n    out[0] = Math.cos(r) * zScale;\n    out[1] = Math.sin(r) * zScale;\n    out[2] = z * scale;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12];\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13];\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat3 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = x * m[0] + y * m[3] + z * m[6];\n    out[1] = x * m[1] + y * m[4] + z * m[7];\n    out[2] = x * m[2] + y * m[5] + z * m[8];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nvec3.transformQuat = function(out, a, q) {\n    // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/*\n* Rotate a 3D vector around the x-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateX = function(out, a, b, c){\n   var p = [], r=[];\n\t  //Translate point to the origin\n\t  p[0] = a[0] - b[0];\n\t  p[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n\n\t  //perform rotation\n\t  r[0] = p[0];\n\t  r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c);\n\t  r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c);\n\n\t  //translate to correct position\n\t  out[0] = r[0] + b[0];\n\t  out[1] = r[1] + b[1];\n\t  out[2] = r[2] + b[2];\n\n  \treturn out;\n};\n\n/*\n* Rotate a 3D vector around the y-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateY = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c);\n  \tr[1] = p[1];\n  \tr[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c);\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/*\n* Rotate a 3D vector around the z-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateZ = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c);\n  \tr[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c);\n  \tr[2] = p[2];\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec3.forEach = (function() {\n    var vec = vec3.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 3;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec3} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec3.str = function (a) {\n    return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec3 = vec3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4 Dimensional Vector\n * @name vec4\n */\n\nvar vec4 = {};\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nvec4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nvec4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nvec4.fromValues = function(x, y, z, w) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nvec4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nvec4.set = function(out, x, y, z, w) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    out[3] = a[3] + b[3];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    out[3] = a[3] - b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\nvec4.sub = vec4.subtract;\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    out[3] = a[3] * b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\nvec4.mul = vec4.multiply;\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    out[3] = a[3] / b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\nvec4.div = vec4.divide;\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    out[3] = Math.min(a[3], b[3]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    out[3] = Math.max(a[3], b[3]);\n    return out;\n};\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nvec4.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    out[3] = a[3] * b;\n    return out;\n};\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nvec4.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    out[3] = a[3] + (b[3] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nvec4.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\nvec4.dist = vec4.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec4.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\nvec4.sqrDist = vec4.squaredDistance;\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec4.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.length}\n * @function\n */\nvec4.len = vec4.length;\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec4.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\nvec4.sqrLen = vec4.squaredLength;\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nvec4.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = -a[3];\n    return out;\n};\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nvec4.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    var len = x*x + y*y + z*z + w*w;\n    if (len > 0) {\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n        out[3] = a[3] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec4.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n};\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nvec4.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2],\n        aw = a[3];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    out[3] = aw + t * (b[3] - aw);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nvec4.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    //TODO: This is a pretty awful way of doing this. Find something better.\n    out[0] = GLMAT_RANDOM();\n    out[1] = GLMAT_RANDOM();\n    out[2] = GLMAT_RANDOM();\n    out[3] = GLMAT_RANDOM();\n    vec4.normalize(out, out);\n    vec4.scale(out, out, scale);\n    return out;\n};\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nvec4.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2], w = a[3];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n    out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n    return out;\n};\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nvec4.transformQuat = function(out, a, q) {\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec4.forEach = (function() {\n    var vec = vec4.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 4;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec4} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec4.str = function (a) {\n    return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec4 = vec4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x2 Matrix\n * @name mat2\n */\n\nvar mat2 = {};\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {mat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nmat2.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a1 = a[1];\n        out[1] = a[2];\n        out[2] = a1;\n    } else {\n        out[0] = a[0];\n        out[1] = a[2];\n        out[2] = a[1];\n        out[3] = a[3];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n\n        // Calculate the determinant\n        det = a0 * a3 - a2 * a1;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n    \n    out[0] =  a3 * det;\n    out[1] = -a1 * det;\n    out[2] = -a2 * det;\n    out[3] =  a0 * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.adjoint = function(out, a) {\n    // Caching this value is nessecary if out == a\n    var a0 = a[0];\n    out[0] =  a[3];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] =  a0;\n\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {mat2} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2.determinant = function (a) {\n    return a[0] * a[3] - a[2] * a[1];\n};\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the first operand\n * @param {mat2} b the second operand\n * @returns {mat2} out\n */\nmat2.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n    var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    return out;\n};\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nmat2.mul = mat2.multiply;\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    return out;\n};\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nmat2.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {mat2} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2.str = function (a) {\n    return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {mat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2)))\n};\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {mat2} L the lower triangular matrix \n * @param {mat2} D the diagonal matrix \n * @param {mat2} U the upper triangular matrix \n * @param {mat2} a the input matrix to factorize\n */\n\nmat2.LDU = function (L, D, U, a) { \n    L[2] = a[2]/a[0]; \n    U[0] = a[0]; \n    U[1] = a[1]; \n    U[3] = a[3] - L[2] * U[1]; \n    return [L, D, U];       \n}; \n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2 = mat2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x3 Matrix\n * @name mat2d\n * \n * @description \n * A mat2d contains six elements defined as:\n * <pre>\n * [a, c, tx,\n *  b, d, ty]\n * </pre>\n * This is a short form for the 3x3 matrix:\n * <pre>\n * [a, c, tx,\n *  b, d, ty,\n *  0, 0, 1]\n * </pre>\n * The last row is ignored so the array is shorter and operations are faster.\n */\n\nvar mat2d = {};\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {mat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\nmat2d.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.invert = function(out, a) {\n    var aa = a[0], ab = a[1], ac = a[2], ad = a[3],\n        atx = a[4], aty = a[5];\n\n    var det = aa * ad - ab * ac;\n    if(!det){\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = ad * det;\n    out[1] = -ab * det;\n    out[2] = -ac * det;\n    out[3] = aa * det;\n    out[4] = (ac * aty - ad * atx) * det;\n    out[5] = (ab * atx - aa * aty) * det;\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {mat2d} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2d.determinant = function (a) {\n    return a[0] * a[3] - a[1] * a[2];\n};\n\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the first operand\n * @param {mat2d} b the second operand\n * @returns {mat2d} out\n */\nmat2d.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    out[4] = a0 * b4 + a2 * b5 + a4;\n    out[5] = a1 * b4 + a3 * b5 + a5;\n    return out;\n};\n\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\nmat2d.mul = mat2d.multiply;\n\n\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\nmat2d.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\nmat2d.translate = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0;\n    out[1] = a1;\n    out[2] = a2;\n    out[3] = a3;\n    out[4] = a0 * v0 + a2 * v1 + a4;\n    out[5] = a1 * v0 + a3 * v1 + a5;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2d\n *\n * @param {mat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2d.str = function (a) {\n    return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {mat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2d.frob = function (a) { \n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1))\n}; \n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2d = mat2d;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3x3 Matrix\n * @name mat3\n */\n\nvar mat3 = {};\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {mat4} a   the source 4x4 matrix\n * @returns {mat3} out\n */\nmat3.fromMat4 = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[4];\n    out[4] = a[5];\n    out[5] = a[6];\n    out[6] = a[8];\n    out[7] = a[9];\n    out[8] = a[10];\n    return out;\n};\n\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {mat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nmat3.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a12 = a[5];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a01;\n        out[5] = a[7];\n        out[6] = a02;\n        out[7] = a12;\n    } else {\n        out[0] = a[0];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a[1];\n        out[4] = a[4];\n        out[5] = a[7];\n        out[6] = a[2];\n        out[7] = a[5];\n        out[8] = a[8];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b01 = a22 * a11 - a12 * a21,\n        b11 = -a22 * a10 + a12 * a20,\n        b21 = a21 * a10 - a11 * a20,\n\n        // Calculate the determinant\n        det = a00 * b01 + a01 * b11 + a02 * b21;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = b01 * det;\n    out[1] = (-a22 * a01 + a02 * a21) * det;\n    out[2] = (a12 * a01 - a02 * a11) * det;\n    out[3] = b11 * det;\n    out[4] = (a22 * a00 - a02 * a20) * det;\n    out[5] = (-a12 * a00 + a02 * a10) * det;\n    out[6] = b21 * det;\n    out[7] = (-a21 * a00 + a01 * a20) * det;\n    out[8] = (a11 * a00 - a01 * a10) * det;\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    out[0] = (a11 * a22 - a12 * a21);\n    out[1] = (a02 * a21 - a01 * a22);\n    out[2] = (a01 * a12 - a02 * a11);\n    out[3] = (a12 * a20 - a10 * a22);\n    out[4] = (a00 * a22 - a02 * a20);\n    out[5] = (a02 * a10 - a00 * a12);\n    out[6] = (a10 * a21 - a11 * a20);\n    out[7] = (a01 * a20 - a00 * a21);\n    out[8] = (a00 * a11 - a01 * a10);\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat3\n *\n * @param {mat3} a the source matrix\n * @returns {Number} determinant of a\n */\nmat3.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n};\n\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the first operand\n * @param {mat3} b the second operand\n * @returns {mat3} out\n */\nmat3.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b00 = b[0], b01 = b[1], b02 = b[2],\n        b10 = b[3], b11 = b[4], b12 = b[5],\n        b20 = b[6], b21 = b[7], b22 = b[8];\n\n    out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n    out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n    out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n    out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n    out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n    out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n    out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n    out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n    out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n    return out;\n};\n\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nmat3.mul = mat3.multiply;\n\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to translate\n * @param {vec2} v vector to translate by\n * @returns {mat3} out\n */\nmat3.translate = function(out, a, v) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n        x = v[0], y = v[1];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n\n    out[3] = a10;\n    out[4] = a11;\n    out[5] = a12;\n\n    out[6] = x * a00 + y * a10 + a20;\n    out[7] = x * a01 + y * a11 + a21;\n    out[8] = x * a02 + y * a12 + a22;\n    return out;\n};\n\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.rotate = function (out, a, rad) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n\n    out[0] = c * a00 + s * a10;\n    out[1] = c * a01 + s * a11;\n    out[2] = c * a02 + s * a12;\n\n    out[3] = c * a10 - s * a00;\n    out[4] = c * a11 - s * a01;\n    out[5] = c * a12 - s * a02;\n\n    out[6] = a20;\n    out[7] = a21;\n    out[8] = a22;\n    return out;\n};\n\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nmat3.scale = function(out, a, v) {\n    var x = v[0], y = v[1];\n\n    out[0] = x * a[0];\n    out[1] = x * a[1];\n    out[2] = x * a[2];\n\n    out[3] = y * a[3];\n    out[4] = y * a[4];\n    out[5] = y * a[5];\n\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nmat3.fromMat2d = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = 0;\n\n    out[3] = a[2];\n    out[4] = a[3];\n    out[5] = 0;\n\n    out[6] = a[4];\n    out[7] = a[5];\n    out[8] = 1;\n    return out;\n};\n\n/**\n* Calculates a 3x3 matrix from the given quaternion\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {quat} q Quaternion to create matrix from\n*\n* @returns {mat3} out\n*/\nmat3.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[3] = yx - wz;\n    out[6] = zx + wy;\n\n    out[1] = yx + wz;\n    out[4] = 1 - xx - zz;\n    out[7] = zy - wx;\n\n    out[2] = zx - wy;\n    out[5] = zy + wx;\n    out[8] = 1 - xx - yy;\n\n    return out;\n};\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {mat4} a Mat4 to derive the normal matrix from\n*\n* @returns {mat3} out\n*/\nmat3.normalFromMat4 = function (out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n\n    out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n\n    out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat3\n *\n * @param {mat3} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat3.str = function (a) {\n    return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ', ' + \n                    a[6] + ', ' + a[7] + ', ' + a[8] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {mat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat3.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2)))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat3 = mat3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4x4 Matrix\n * @name mat4\n */\n\nvar mat4 = {};\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nmat4.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a03 = a[3],\n            a12 = a[6], a13 = a[7],\n            a23 = a[11];\n\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a01;\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a02;\n        out[9] = a12;\n        out[11] = a[14];\n        out[12] = a03;\n        out[13] = a13;\n        out[14] = a23;\n    } else {\n        out[0] = a[0];\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a[1];\n        out[5] = a[5];\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a[2];\n        out[9] = a[6];\n        out[10] = a[10];\n        out[11] = a[14];\n        out[12] = a[3];\n        out[13] = a[7];\n        out[14] = a[11];\n        out[15] = a[15];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n    out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n    out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n    out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n    out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n    out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n    out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n    out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n    out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n    out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    out[0]  =  (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n    out[1]  = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n    out[2]  =  (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n    out[3]  = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n    out[4]  = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n    out[5]  =  (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n    out[6]  = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n    out[7]  =  (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n    out[8]  =  (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n    out[9]  = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n    out[10] =  (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n    out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n    out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n    out[13] =  (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n    out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n    out[15] =  (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nmat4.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32;\n\n    // Calculate the determinant\n    return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2], b3 = b[3];  \n    out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n    out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n    out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n    return out;\n};\n\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\nmat4.mul = mat4.multiply;\n\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nmat4.translate = function (out, a, v) {\n    var x = v[0], y = v[1], z = v[2],\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23;\n\n    if (a === out) {\n        out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n        out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n        out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n        out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n    } else {\n        a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n        a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n        a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n        out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n        out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n        out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n        out[12] = a00 * x + a10 * y + a20 * z + a[12];\n        out[13] = a01 * x + a11 * y + a21 * z + a[13];\n        out[14] = a02 * x + a12 * y + a22 * z + a[14];\n        out[15] = a03 * x + a13 * y + a23 * z + a[15];\n    }\n\n    return out;\n};\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nmat4.scale = function(out, a, v) {\n    var x = v[0], y = v[1], z = v[2];\n\n    out[0] = a[0] * x;\n    out[1] = a[1] * x;\n    out[2] = a[2] * x;\n    out[3] = a[3] * x;\n    out[4] = a[4] * y;\n    out[5] = a[5] * y;\n    out[6] = a[6] * y;\n    out[7] = a[7] * y;\n    out[8] = a[8] * z;\n    out[9] = a[9] * z;\n    out[10] = a[10] * z;\n    out[11] = a[11] * z;\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.rotate = function (out, a, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t,\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23,\n        b00, b01, b02,\n        b10, b11, b12,\n        b20, b21, b22;\n\n    if (Math.abs(len) < GLMAT_EPSILON) { return null; }\n    \n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n\n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n\n    a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n    a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n    a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n    // Construct the elements of the rotation matrix\n    b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n    b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n    b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n    // Perform rotation-specific matrix multiplication\n    out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n    out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n    out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n    out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n    out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n    out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n    out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n    out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n    out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n    out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n    out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n    out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateX = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[0]  = a[0];\n        out[1]  = a[1];\n        out[2]  = a[2];\n        out[3]  = a[3];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[4] = a10 * c + a20 * s;\n    out[5] = a11 * c + a21 * s;\n    out[6] = a12 * c + a22 * s;\n    out[7] = a13 * c + a23 * s;\n    out[8] = a20 * c - a10 * s;\n    out[9] = a21 * c - a11 * s;\n    out[10] = a22 * c - a12 * s;\n    out[11] = a23 * c - a13 * s;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateY = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[4]  = a[4];\n        out[5]  = a[5];\n        out[6]  = a[6];\n        out[7]  = a[7];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c - a20 * s;\n    out[1] = a01 * c - a21 * s;\n    out[2] = a02 * c - a22 * s;\n    out[3] = a03 * c - a23 * s;\n    out[8] = a00 * s + a20 * c;\n    out[9] = a01 * s + a21 * c;\n    out[10] = a02 * s + a22 * c;\n    out[11] = a03 * s + a23 * c;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateZ = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[8]  = a[8];\n        out[9]  = a[9];\n        out[10] = a[10];\n        out[11] = a[11];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c + a10 * s;\n    out[1] = a01 * c + a11 * s;\n    out[2] = a02 * c + a12 * s;\n    out[3] = a03 * c + a13 * s;\n    out[4] = a10 * c - a00 * s;\n    out[5] = a11 * c - a01 * s;\n    out[6] = a12 * c - a02 * s;\n    out[7] = a13 * c - a03 * s;\n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslation = function (out, q, v) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - (yy + zz);\n    out[1] = xy + wz;\n    out[2] = xz - wy;\n    out[3] = 0;\n    out[4] = xy - wz;\n    out[5] = 1 - (xx + zz);\n    out[6] = yz + wx;\n    out[7] = 0;\n    out[8] = xz + wy;\n    out[9] = yz - wx;\n    out[10] = 1 - (xx + yy);\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n    \n    return out;\n};\n\nmat4.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[1] = yx + wz;\n    out[2] = zx - wy;\n    out[3] = 0;\n\n    out[4] = yx - wz;\n    out[5] = 1 - xx - zz;\n    out[6] = zy + wx;\n    out[7] = 0;\n\n    out[8] = zx + wy;\n    out[9] = zy - wx;\n    out[10] = 1 - xx - yy;\n    out[11] = 0;\n\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.frustum = function (out, left, right, bottom, top, near, far) {\n    var rl = 1 / (right - left),\n        tb = 1 / (top - bottom),\n        nf = 1 / (near - far);\n    out[0] = (near * 2) * rl;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = (near * 2) * tb;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = (right + left) * rl;\n    out[9] = (top + bottom) * tb;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (far * near * 2) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspective = function (out, fovy, aspect, near, far) {\n    var f = 1.0 / Math.tan(fovy / 2),\n        nf = 1 / (near - far);\n    out[0] = f / aspect;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = f;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (2 * far * near) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.ortho = function (out, left, right, bottom, top, near, far) {\n    var lr = 1 / (left - right),\n        bt = 1 / (bottom - top),\n        nf = 1 / (near - far);\n    out[0] = -2 * lr;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = -2 * bt;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 2 * nf;\n    out[11] = 0;\n    out[12] = (left + right) * lr;\n    out[13] = (top + bottom) * bt;\n    out[14] = (far + near) * nf;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nmat4.lookAt = function (out, eye, center, up) {\n    var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n        eyex = eye[0],\n        eyey = eye[1],\n        eyez = eye[2],\n        upx = up[0],\n        upy = up[1],\n        upz = up[2],\n        centerx = center[0],\n        centery = center[1],\n        centerz = center[2];\n\n    if (Math.abs(eyex - centerx) < GLMAT_EPSILON &&\n        Math.abs(eyey - centery) < GLMAT_EPSILON &&\n        Math.abs(eyez - centerz) < GLMAT_EPSILON) {\n        return mat4.identity(out);\n    }\n\n    z0 = eyex - centerx;\n    z1 = eyey - centery;\n    z2 = eyez - centerz;\n\n    len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n    z0 *= len;\n    z1 *= len;\n    z2 *= len;\n\n    x0 = upy * z2 - upz * z1;\n    x1 = upz * z0 - upx * z2;\n    x2 = upx * z1 - upy * z0;\n    len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n    if (!len) {\n        x0 = 0;\n        x1 = 0;\n        x2 = 0;\n    } else {\n        len = 1 / len;\n        x0 *= len;\n        x1 *= len;\n        x2 *= len;\n    }\n\n    y0 = z1 * x2 - z2 * x1;\n    y1 = z2 * x0 - z0 * x2;\n    y2 = z0 * x1 - z1 * x0;\n\n    len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n    if (!len) {\n        y0 = 0;\n        y1 = 0;\n        y2 = 0;\n    } else {\n        len = 1 / len;\n        y0 *= len;\n        y1 *= len;\n        y2 *= len;\n    }\n\n    out[0] = x0;\n    out[1] = y0;\n    out[2] = z0;\n    out[3] = 0;\n    out[4] = x1;\n    out[5] = y1;\n    out[6] = z1;\n    out[7] = 0;\n    out[8] = x2;\n    out[9] = y2;\n    out[10] = z2;\n    out[11] = 0;\n    out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n    out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n    out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat4.str = function (a) {\n    return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n                    a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n                    a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' + \n                    a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {mat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat4.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) ))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat4 = mat4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class Quaternion\n * @name quat\n */\n\nvar quat = {};\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nquat.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {vec3} a the initial vector\n * @param {vec3} b the destination vector\n * @returns {quat} out\n */\nquat.rotationTo = (function() {\n    var tmpvec3 = vec3.create();\n    var xUnitVec3 = vec3.fromValues(1,0,0);\n    var yUnitVec3 = vec3.fromValues(0,1,0);\n\n    return function(out, a, b) {\n        var dot = vec3.dot(a, b);\n        if (dot < -0.999999) {\n            vec3.cross(tmpvec3, xUnitVec3, a);\n            if (vec3.length(tmpvec3) < 0.000001)\n                vec3.cross(tmpvec3, yUnitVec3, a);\n            vec3.normalize(tmpvec3, tmpvec3);\n            quat.setAxisAngle(out, tmpvec3, Math.PI);\n            return out;\n        } else if (dot > 0.999999) {\n            out[0] = 0;\n            out[1] = 0;\n            out[2] = 0;\n            out[3] = 1;\n            return out;\n        } else {\n            vec3.cross(tmpvec3, a, b);\n            out[0] = tmpvec3[0];\n            out[1] = tmpvec3[1];\n            out[2] = tmpvec3[2];\n            out[3] = 1 + dot;\n            return quat.normalize(out, out);\n        }\n    };\n})();\n\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {vec3} view  the vector representing the viewing direction\n * @param {vec3} right the vector representing the local \"right\" direction\n * @param {vec3} up    the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nquat.setAxes = (function() {\n    var matr = mat3.create();\n\n    return function(out, view, right, up) {\n        matr[0] = right[0];\n        matr[3] = right[1];\n        matr[6] = right[2];\n\n        matr[1] = up[0];\n        matr[4] = up[1];\n        matr[7] = up[2];\n\n        matr[2] = -view[0];\n        matr[5] = -view[1];\n        matr[8] = -view[2];\n\n        return quat.normalize(out, quat.fromMat3(out, matr));\n    };\n})();\n\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {quat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nquat.clone = vec4.clone;\n\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nquat.fromValues = vec4.fromValues;\n\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nquat.copy = vec4.copy;\n\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nquat.set = vec4.set;\n\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nquat.identity = function(out) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {vec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nquat.setAxisAngle = function(out, axis, rad) {\n    rad = rad * 0.5;\n    var s = Math.sin(rad);\n    out[0] = s * axis[0];\n    out[1] = s * axis[1];\n    out[2] = s * axis[2];\n    out[3] = Math.cos(rad);\n    return out;\n};\n\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n * @function\n */\nquat.add = vec4.add;\n\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n */\nquat.multiply = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    out[0] = ax * bw + aw * bx + ay * bz - az * by;\n    out[1] = ay * bw + aw * by + az * bx - ax * bz;\n    out[2] = az * bw + aw * bz + ax * by - ay * bx;\n    out[3] = aw * bw - ax * bx - ay * by - az * bz;\n    return out;\n};\n\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nquat.mul = quat.multiply;\n\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {quat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nquat.scale = vec4.scale;\n\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateX = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + aw * bx;\n    out[1] = ay * bw + az * bx;\n    out[2] = az * bw - ay * bx;\n    out[3] = aw * bw - ax * bx;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateY = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        by = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw - az * by;\n    out[1] = ay * bw + aw * by;\n    out[2] = az * bw + ax * by;\n    out[3] = aw * bw - ay * by;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateZ = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bz = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + ay * bz;\n    out[1] = ay * bw - ax * bz;\n    out[2] = az * bw + aw * bz;\n    out[3] = aw * bw - az * bz;\n    return out;\n};\n\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate W component of\n * @returns {quat} out\n */\nquat.calculateW = function (out, a) {\n    var x = a[0], y = a[1], z = a[2];\n\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = -Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n    return out;\n};\n\n/**\n * Calculates the dot product of two quat's\n *\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nquat.dot = vec4.dot;\n\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n * @function\n */\nquat.lerp = vec4.lerp;\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nquat.slerp = function (out, a, b, t) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    var        omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if ( cosom < 0.0 ) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ( (1.0 - cosom) > 0.000001 ) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    } else {        \n        // \"from\" and \"to\" quaternions are very close \n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n    \n    return out;\n};\n\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate inverse of\n * @returns {quat} out\n */\nquat.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        dot = a0*a0 + a1*a1 + a2*a2 + a3*a3,\n        invDot = dot ? 1.0/dot : 0;\n    \n    // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n    out[0] = -a0*invDot;\n    out[1] = -a1*invDot;\n    out[2] = -a2*invDot;\n    out[3] = a3*invDot;\n    return out;\n};\n\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nquat.conjugate = function (out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Calculates the length of a quat\n *\n * @param {quat} a vector to calculate length of\n * @returns {Number} length of a\n * @function\n */\nquat.length = vec4.length;\n\n/**\n * Alias for {@link quat.length}\n * @function\n */\nquat.len = quat.length;\n\n/**\n * Calculates the squared length of a quat\n *\n * @param {quat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nquat.squaredLength = vec4.squaredLength;\n\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nquat.sqrLen = quat.squaredLength;\n\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nquat.normalize = vec4.normalize;\n\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {mat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nquat.fromMat3 = function(out, m) {\n    // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n    // article \"Quaternion Calculus and Fast Animation\".\n    var fTrace = m[0] + m[4] + m[8];\n    var fRoot;\n\n    if ( fTrace > 0.0 ) {\n        // |w| > 1/2, may as well choose w > 1/2\n        fRoot = Math.sqrt(fTrace + 1.0);  // 2w\n        out[3] = 0.5 * fRoot;\n        fRoot = 0.5/fRoot;  // 1/(4w)\n        out[0] = (m[7]-m[5])*fRoot;\n        out[1] = (m[2]-m[6])*fRoot;\n        out[2] = (m[3]-m[1])*fRoot;\n    } else {\n        // |w| <= 1/2\n        var i = 0;\n        if ( m[4] > m[0] )\n          i = 1;\n        if ( m[8] > m[i*3+i] )\n          i = 2;\n        var j = (i+1)%3;\n        var k = (i+2)%3;\n        \n        fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0);\n        out[i] = 0.5 * fRoot;\n        fRoot = 0.5 / fRoot;\n        out[3] = (m[k*3+j] - m[j*3+k]) * fRoot;\n        out[j] = (m[j*3+i] + m[i*3+j]) * fRoot;\n        out[k] = (m[k*3+i] + m[i*3+k]) * fRoot;\n    }\n    \n    return out;\n};\n\n/**\n * Returns a string representation of a quatenion\n *\n * @param {quat} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nquat.str = function (a) {\n    return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.quat = quat;\n}\n;\n\n\n\n\n\n\n\n\n\n\n\n\n\n  })(shim.exports);\n})(this);\n","module.exports = parseErrors\n\nfunction parseErrors(log) {\n  log = String(log)\n\n  var logs = []\n  var result\n\n  while (result = log.match(/ERROR\\:([^\\n]+)/)) {\n    log = log.slice(result.index + 1)\n\n    var line = result[1].trim()\n    var seps = line.split(':')\n    var emsg = seps.slice(2).join(':').trim()\n    var file = parseInt(seps[0], 10)\n    var line = parseInt(seps[1], 10)\n\n    logs.push({\n        message: emsg\n      , file: file\n      , line: line\n    })\n  }\n\n  return logs\n}\n","'use strict';\n\n\nvar yaml = require('./lib/js-yaml.js');\n\n\nmodule.exports = yaml;\n","'use strict';\n\n\nvar loader = require('./js-yaml/loader');\nvar dumper = require('./js-yaml/dumper');\n\n\nfunction deprecated(name) {\n  return function () {\n    throw new Error('Function ' + name + ' is deprecated and cannot be used.');\n  };\n}\n\n\nmodule.exports.Type                = require('./js-yaml/type');\nmodule.exports.Schema              = require('./js-yaml/schema');\nmodule.exports.FAILSAFE_SCHEMA     = require('./js-yaml/schema/failsafe');\nmodule.exports.JSON_SCHEMA         = require('./js-yaml/schema/json');\nmodule.exports.CORE_SCHEMA         = require('./js-yaml/schema/core');\nmodule.exports.DEFAULT_SAFE_SCHEMA = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_FULL_SCHEMA = require('./js-yaml/schema/default_full');\nmodule.exports.load                = loader.load;\nmodule.exports.loadAll             = loader.loadAll;\nmodule.exports.safeLoad            = loader.safeLoad;\nmodule.exports.safeLoadAll         = loader.safeLoadAll;\nmodule.exports.dump                = dumper.dump;\nmodule.exports.safeDump            = dumper.safeDump;\nmodule.exports.YAMLException       = require('./js-yaml/exception');\n\n// Deprecared schema names from JS-YAML 2.0.x\nmodule.exports.MINIMAL_SCHEMA = require('./js-yaml/schema/failsafe');\nmodule.exports.SAFE_SCHEMA    = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_SCHEMA = require('./js-yaml/schema/default_full');\n\n// Deprecated functions from JS-YAML 1.x.x\nmodule.exports.scan           = deprecated('scan');\nmodule.exports.parse          = deprecated('parse');\nmodule.exports.compose        = deprecated('compose');\nmodule.exports.addConstructor = deprecated('addConstructor');\n","'use strict';\n\n\nfunction isNothing(subject) {\n  return (typeof subject === 'undefined') || (null === subject);\n}\n\n\nfunction isObject(subject) {\n  return (typeof subject === 'object') && (null !== subject);\n}\n\n\nfunction toArray(sequence) {\n  if (Array.isArray(sequence)) {\n    return sequence;\n  } else if (isNothing(sequence)) {\n    return [];\n  }\n  return [ sequence ];\n}\n\n\nfunction extend(target, source) {\n  var index, length, key, sourceKeys;\n\n  if (source) {\n    sourceKeys = Object.keys(source);\n\n    for (index = 0, length = sourceKeys.length; index < length; index += 1) {\n      key = sourceKeys[index];\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\n\nfunction repeat(string, count) {\n  var result = '', cycle;\n\n  for (cycle = 0; cycle < count; cycle += 1) {\n    result += string;\n  }\n\n  return result;\n}\n\n\nfunction isNegativeZero(number) {\n  return (0 === number) && (Number.NEGATIVE_INFINITY === 1 / number);\n}\n\n\nmodule.exports.isNothing      = isNothing;\nmodule.exports.isObject       = isObject;\nmodule.exports.toArray        = toArray;\nmodule.exports.repeat         = repeat;\nmodule.exports.isNegativeZero = isNegativeZero;\nmodule.exports.extend         = extend;\n","'use strict';\n\n/*eslint-disable no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\n\nvar _toString       = Object.prototype.toString;\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar CHAR_TAB                  = 0x09; /* Tab */\nvar CHAR_LINE_FEED            = 0x0A; /* LF */\nvar CHAR_CARRIAGE_RETURN      = 0x0D; /* CR */\nvar CHAR_SPACE                = 0x20; /* Space */\nvar CHAR_EXCLAMATION          = 0x21; /* ! */\nvar CHAR_DOUBLE_QUOTE         = 0x22; /* \" */\nvar CHAR_SHARP                = 0x23; /* # */\nvar CHAR_PERCENT              = 0x25; /* % */\nvar CHAR_AMPERSAND            = 0x26; /* & */\nvar CHAR_SINGLE_QUOTE         = 0x27; /* ' */\nvar CHAR_ASTERISK             = 0x2A; /* * */\nvar CHAR_COMMA                = 0x2C; /* , */\nvar CHAR_MINUS                = 0x2D; /* - */\nvar CHAR_COLON                = 0x3A; /* : */\nvar CHAR_GREATER_THAN         = 0x3E; /* > */\nvar CHAR_QUESTION             = 0x3F; /* ? */\nvar CHAR_COMMERCIAL_AT        = 0x40; /* @ */\nvar CHAR_LEFT_SQUARE_BRACKET  = 0x5B; /* [ */\nvar CHAR_RIGHT_SQUARE_BRACKET = 0x5D; /* ] */\nvar CHAR_GRAVE_ACCENT         = 0x60; /* ` */\nvar CHAR_LEFT_CURLY_BRACKET   = 0x7B; /* { */\nvar CHAR_VERTICAL_LINE        = 0x7C; /* | */\nvar CHAR_RIGHT_CURLY_BRACKET  = 0x7D; /* } */\n\nvar ESCAPE_SEQUENCES = {};\n\nESCAPE_SEQUENCES[0x00]   = '\\\\0';\nESCAPE_SEQUENCES[0x07]   = '\\\\a';\nESCAPE_SEQUENCES[0x08]   = '\\\\b';\nESCAPE_SEQUENCES[0x09]   = '\\\\t';\nESCAPE_SEQUENCES[0x0A]   = '\\\\n';\nESCAPE_SEQUENCES[0x0B]   = '\\\\v';\nESCAPE_SEQUENCES[0x0C]   = '\\\\f';\nESCAPE_SEQUENCES[0x0D]   = '\\\\r';\nESCAPE_SEQUENCES[0x1B]   = '\\\\e';\nESCAPE_SEQUENCES[0x22]   = '\\\\\"';\nESCAPE_SEQUENCES[0x5C]   = '\\\\\\\\';\nESCAPE_SEQUENCES[0x85]   = '\\\\N';\nESCAPE_SEQUENCES[0xA0]   = '\\\\_';\nESCAPE_SEQUENCES[0x2028] = '\\\\L';\nESCAPE_SEQUENCES[0x2029] = '\\\\P';\n\nvar DEPRECATED_BOOLEANS_SYNTAX = [\n  'y', 'Y', 'yes', 'Yes', 'YES', 'on', 'On', 'ON',\n  'n', 'N', 'no', 'No', 'NO', 'off', 'Off', 'OFF'\n];\n\nfunction compileStyleMap(schema, map) {\n  var result, keys, index, length, tag, style, type;\n\n  if (null === map) {\n    return {};\n  }\n\n  result = {};\n  keys = Object.keys(map);\n\n  for (index = 0, length = keys.length; index < length; index += 1) {\n    tag = keys[index];\n    style = String(map[tag]);\n\n    if ('!!' === tag.slice(0, 2)) {\n      tag = 'tag:yaml.org,2002:' + tag.slice(2);\n    }\n\n    type = schema.compiledTypeMap[tag];\n\n    if (type && _hasOwnProperty.call(type.styleAliases, style)) {\n      style = type.styleAliases[style];\n    }\n\n    result[tag] = style;\n  }\n\n  return result;\n}\n\nfunction encodeHex(character) {\n  var string, handle, length;\n\n  string = character.toString(16).toUpperCase();\n\n  if (character <= 0xFF) {\n    handle = 'x';\n    length = 2;\n  } else if (character <= 0xFFFF) {\n    handle = 'u';\n    length = 4;\n  } else if (character <= 0xFFFFFFFF) {\n    handle = 'U';\n    length = 8;\n  } else {\n    throw new YAMLException('code point within a string may not be greater than 0xFFFFFFFF');\n  }\n\n  return '\\\\' + handle + common.repeat('0', length - string.length) + string;\n}\n\nfunction State(options) {\n  this.schema      = options['schema'] || DEFAULT_FULL_SCHEMA;\n  this.indent      = Math.max(1, (options['indent'] || 2));\n  this.skipInvalid = options['skipInvalid'] || false;\n  this.flowLevel   = (common.isNothing(options['flowLevel']) ? -1 : options['flowLevel']);\n  this.styleMap    = compileStyleMap(this.schema, options['styles'] || null);\n  this.sortKeys    = options['sortKeys'] || false;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.explicitTypes = this.schema.compiledExplicit;\n\n  this.tag = null;\n  this.result = '';\n\n  this.duplicates = [];\n  this.usedDuplicates = null;\n}\n\nfunction indentString(string, spaces) {\n  var ind = common.repeat(' ', spaces),\n      position = 0,\n      next = -1,\n      result = '',\n      line,\n      length = string.length;\n\n  while (position < length) {\n    next = string.indexOf('\\n', position);\n    if (next === -1) {\n      line = string.slice(position);\n      position = length;\n    } else {\n      line = string.slice(position, next + 1);\n      position = next + 1;\n    }\n    if (line.length && line !== '\\n') {\n      result += ind;\n    }\n    result += line;\n  }\n\n  return result;\n}\n\nfunction generateNextLine(state, level) {\n  return '\\n' + common.repeat(' ', state.indent * level);\n}\n\nfunction testImplicitResolving(state, str) {\n  var index, length, type;\n\n  for (index = 0, length = state.implicitTypes.length; index < length; index += 1) {\n    type = state.implicitTypes[index];\n\n    if (type.resolve(str)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction StringBuilder(source) {\n  this.source = source;\n  this.result = '';\n  this.checkpoint = 0;\n}\n\nStringBuilder.prototype.takeUpTo = function (position) {\n  var er;\n\n  if (position < this.checkpoint) {\n    er = new Error('position should be > checkpoint');\n    er.position = position;\n    er.checkpoint = this.checkpoint;\n    throw er;\n  }\n\n  this.result += this.source.slice(this.checkpoint, position);\n  this.checkpoint = position;\n  return this;\n};\n\nStringBuilder.prototype.escapeChar = function () {\n  var character, esc;\n\n  character = this.source.charCodeAt(this.checkpoint);\n  esc = ESCAPE_SEQUENCES[character] || encodeHex(character);\n  this.result += esc;\n  this.checkpoint += 1;\n\n  return this;\n};\n\nStringBuilder.prototype.finish = function () {\n  if (this.source.length > this.checkpoint) {\n    this.takeUpTo(this.source.length);\n  }\n};\n\nfunction writeScalar(state, object, level) {\n  var simple, first, spaceWrap, folded, literal, single, double,\n      sawLineFeed, linePosition, longestLine, indent, max, character,\n      position, escapeSeq, hexEsc, previous, lineLength, modifier,\n      trailingLineBreaks, result;\n\n  if (0 === object.length) {\n    state.dump = \"''\";\n    return;\n  }\n\n  if (-1 !== DEPRECATED_BOOLEANS_SYNTAX.indexOf(object)) {\n    state.dump = \"'\" + object + \"'\";\n    return;\n  }\n\n  simple = true;\n  first = object.length ? object.charCodeAt(0) : 0;\n  spaceWrap = (CHAR_SPACE === first ||\n               CHAR_SPACE === object.charCodeAt(object.length - 1));\n\n  // Simplified check for restricted first characters\n  // http://www.yaml.org/spec/1.2/spec.html#ns-plain-first%28c%29\n  if (CHAR_MINUS         === first ||\n      CHAR_QUESTION      === first ||\n      CHAR_COMMERCIAL_AT === first ||\n      CHAR_GRAVE_ACCENT  === first) {\n    simple = false;\n  }\n\n  // can only use > and | if not wrapped in spaces.\n  if (spaceWrap) {\n    simple = false;\n    folded = false;\n    literal = false;\n  } else {\n    folded = true;\n    literal = true;\n  }\n\n  single = true;\n  double = new StringBuilder(object);\n\n  sawLineFeed = false;\n  linePosition = 0;\n  longestLine = 0;\n\n  indent = state.indent * level;\n  max = 80;\n  if (indent < 40) {\n    max -= indent;\n  } else {\n    max = 40;\n  }\n\n  for (position = 0; position < object.length; position++) {\n    character = object.charCodeAt(position);\n    if (simple) {\n      // Characters that can never appear in the simple scalar\n      if (!simpleChar(character)) {\n        simple = false;\n      } else {\n        // Still simple.  If we make it all the way through like\n        // this, then we can just dump the string as-is.\n        continue;\n      }\n    }\n\n    if (single && character === CHAR_SINGLE_QUOTE) {\n      single = false;\n    }\n\n    escapeSeq = ESCAPE_SEQUENCES[character];\n    hexEsc = needsHexEscape(character);\n\n    if (!escapeSeq && !hexEsc) {\n      continue;\n    }\n\n    if (character !== CHAR_LINE_FEED &&\n        character !== CHAR_DOUBLE_QUOTE &&\n        character !== CHAR_SINGLE_QUOTE) {\n      folded = false;\n      literal = false;\n    } else if (character === CHAR_LINE_FEED) {\n      sawLineFeed = true;\n      single = false;\n      if (position > 0) {\n        previous = object.charCodeAt(position - 1);\n        if (previous === CHAR_SPACE) {\n          literal = false;\n          folded = false;\n        }\n      }\n      if (folded) {\n        lineLength = position - linePosition;\n        linePosition = position;\n        if (lineLength > longestLine) {\n          longestLine = lineLength;\n        }\n      }\n    }\n\n    if (character !== CHAR_DOUBLE_QUOTE) {\n      single = false;\n    }\n\n    double.takeUpTo(position);\n    double.escapeChar();\n  }\n\n  if (simple && testImplicitResolving(state, object)) {\n    simple = false;\n  }\n\n  modifier = '';\n  if (folded || literal) {\n    trailingLineBreaks = 0;\n    if (object.charCodeAt(object.length - 1) === CHAR_LINE_FEED) {\n      trailingLineBreaks += 1;\n      if (object.charCodeAt(object.length - 2) === CHAR_LINE_FEED) {\n        trailingLineBreaks += 1;\n      }\n    }\n\n    if (trailingLineBreaks === 0) {\n      modifier = '-';\n    } else if (trailingLineBreaks === 2) {\n      modifier = '+';\n    }\n  }\n\n  if (literal && longestLine < max) {\n    folded = false;\n  }\n\n  // If it's literally one line, then don't bother with the literal.\n  // We may still want to do a fold, though, if it's a super long line.\n  if (!sawLineFeed) {\n    literal = false;\n  }\n\n  if (simple) {\n    state.dump = object;\n  } else if (single) {\n    state.dump = '\\'' + object + '\\'';\n  } else if (folded) {\n    result = fold(object, max);\n    state.dump = '>' + modifier + '\\n' + indentString(result, indent);\n  } else if (literal) {\n    if (!modifier) {\n      object = object.replace(/\\n$/, '');\n    }\n    state.dump = '|' + modifier + '\\n' + indentString(object, indent);\n  } else if (double) {\n    double.finish();\n    state.dump = '\"' + double.result + '\"';\n  } else {\n    throw new Error('Failed to dump scalar value');\n  }\n\n  return;\n}\n\n// The `trailing` var is a regexp match of any trailing `\\n` characters.\n//\n// There are three cases we care about:\n//\n// 1. One trailing `\\n` on the string.  Just use `|` or `>`.\n//    This is the assumed default. (trailing = null)\n// 2. No trailing `\\n` on the string.  Use `|-` or `>-` to \"chomp\" the end.\n// 3. More than one trailing `\\n` on the string.  Use `|+` or `>+`.\n//\n// In the case of `>+`, these line breaks are *not* doubled (like the line\n// breaks within the string), so it's important to only end with the exact\n// same number as we started.\nfunction fold(object, max) {\n  var result = '',\n      position = 0,\n      length = object.length,\n      trailing = /\\n+$/.exec(object),\n      newLine;\n\n  if (trailing) {\n    length = trailing.index + 1;\n  }\n\n  while (position < length) {\n    newLine = object.indexOf('\\n', position);\n    if (newLine > length || newLine === -1) {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, length), max);\n      position = length;\n    } else {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, newLine), max);\n      position = newLine + 1;\n    }\n  }\n  if (trailing && trailing[0] !== '\\n') {\n    result += trailing[0];\n  }\n\n  return result;\n}\n\nfunction foldLine(line, max) {\n  if (line === '') {\n    return line;\n  }\n\n  var foldRe = /[^\\s] [^\\s]/g,\n      result = '',\n      prevMatch = 0,\n      foldStart = 0,\n      match = foldRe.exec(line),\n      index,\n      foldEnd,\n      folded;\n\n  while (match) {\n    index = match.index;\n\n    // when we cross the max len, if the previous match would've\n    // been ok, use that one, and carry on.  If there was no previous\n    // match on this fold section, then just have a long line.\n    if (index - foldStart > max) {\n      if (prevMatch !== foldStart) {\n        foldEnd = prevMatch;\n      } else {\n        foldEnd = index;\n      }\n\n      if (result) {\n        result += '\\n';\n      }\n      folded = line.slice(foldStart, foldEnd);\n      result += folded;\n      foldStart = foldEnd + 1;\n    }\n    prevMatch = index + 1;\n    match = foldRe.exec(line);\n  }\n\n  if (result) {\n    result += '\\n';\n  }\n\n  // if we end up with one last word at the end, then the last bit might\n  // be slightly bigger than we wanted, because we exited out of the loop.\n  if (foldStart !== prevMatch && line.length - foldStart > max) {\n    result += line.slice(foldStart, prevMatch) + '\\n' +\n              line.slice(prevMatch + 1);\n  } else {\n    result += line.slice(foldStart);\n  }\n\n  return result;\n}\n\n// Returns true if character can be found in a simple scalar\nfunction simpleChar(character) {\n  return CHAR_TAB                  !== character &&\n         CHAR_LINE_FEED            !== character &&\n         CHAR_CARRIAGE_RETURN      !== character &&\n         CHAR_COMMA                !== character &&\n         CHAR_LEFT_SQUARE_BRACKET  !== character &&\n         CHAR_RIGHT_SQUARE_BRACKET !== character &&\n         CHAR_LEFT_CURLY_BRACKET   !== character &&\n         CHAR_RIGHT_CURLY_BRACKET  !== character &&\n         CHAR_SHARP                !== character &&\n         CHAR_AMPERSAND            !== character &&\n         CHAR_ASTERISK             !== character &&\n         CHAR_EXCLAMATION          !== character &&\n         CHAR_VERTICAL_LINE        !== character &&\n         CHAR_GREATER_THAN         !== character &&\n         CHAR_SINGLE_QUOTE         !== character &&\n         CHAR_DOUBLE_QUOTE         !== character &&\n         CHAR_PERCENT              !== character &&\n         CHAR_COLON                !== character &&\n         !ESCAPE_SEQUENCES[character]            &&\n         !needsHexEscape(character);\n}\n\n// Returns true if the character code needs to be escaped.\nfunction needsHexEscape(character) {\n  return !((0x00020 <= character && character <= 0x00007E) ||\n           (0x00085 === character)                         ||\n           (0x000A0 <= character && character <= 0x00D7FF) ||\n           (0x0E000 <= character && character <= 0x00FFFD) ||\n           (0x10000 <= character && character <= 0x10FFFF));\n}\n\nfunction writeFlowSequence(state, level, object) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level, object[index], false, false)) {\n      if (0 !== index) {\n        _result += ', ';\n      }\n      _result += state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = '[' + _result + ']';\n}\n\nfunction writeBlockSequence(state, level, object, compact) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level + 1, object[index], true, true)) {\n      if (!compact || 0 !== index) {\n        _result += generateNextLine(state, level);\n      }\n      _result += '- ' + state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '[]'; // Empty sequence if no valid values.\n}\n\nfunction writeFlowMapping(state, level, object) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      pairBuffer;\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (0 !== index) {\n      pairBuffer += ', ';\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level, objectKey, false, false)) {\n      continue; // Skip this pair because of invalid key;\n    }\n\n    if (state.dump.length > 1024) {\n      pairBuffer += '? ';\n    }\n\n    pairBuffer += state.dump + ': ';\n\n    if (!writeNode(state, level, objectValue, false, false)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = '{' + _result + '}';\n}\n\nfunction writeBlockMapping(state, level, object, compact) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      explicitPair,\n      pairBuffer;\n\n  // Allow sorting keys so that the output file is deterministic\n  if (state.sortKeys === true) {\n    // Default sorting\n    objectKeyList.sort();\n  } else if (typeof state.sortKeys === 'function') {\n    // Custom sort function\n    objectKeyList.sort(state.sortKeys);\n  } else if (state.sortKeys) {\n    // Something is wrong\n    throw new YAMLException('sortKeys must be a boolean or a function');\n  }\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (!compact || 0 !== index) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level + 1, objectKey, true, true)) {\n      continue; // Skip this pair because of invalid key.\n    }\n\n    explicitPair = (null !== state.tag && '?' !== state.tag) ||\n                   (state.dump && state.dump.length > 1024);\n\n    if (explicitPair) {\n      if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n        pairBuffer += '?';\n      } else {\n        pairBuffer += '? ';\n      }\n    }\n\n    pairBuffer += state.dump;\n\n    if (explicitPair) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    if (!writeNode(state, level + 1, objectValue, true, explicitPair)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n      pairBuffer += ':';\n    } else {\n      pairBuffer += ': ';\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '{}'; // Empty mapping if no valid pairs.\n}\n\nfunction detectType(state, object, explicit) {\n  var _result, typeList, index, length, type, style;\n\n  typeList = explicit ? state.explicitTypes : state.implicitTypes;\n\n  for (index = 0, length = typeList.length; index < length; index += 1) {\n    type = typeList[index];\n\n    if ((type.instanceOf  || type.predicate) &&\n        (!type.instanceOf || (('object' === typeof object) && (object instanceof type.instanceOf))) &&\n        (!type.predicate  || type.predicate(object))) {\n\n      state.tag = explicit ? type.tag : '?';\n\n      if (type.represent) {\n        style = state.styleMap[type.tag] || type.defaultStyle;\n\n        if ('[object Function]' === _toString.call(type.represent)) {\n          _result = type.represent(object, style);\n        } else if (_hasOwnProperty.call(type.represent, style)) {\n          _result = type.represent[style](object, style);\n        } else {\n          throw new YAMLException('!<' + type.tag + '> tag resolver accepts not \"' + style + '\" style');\n        }\n\n        state.dump = _result;\n      }\n\n      return true;\n    }\n  }\n\n  return false;\n}\n\n// Serializes `object` and writes it to global `result`.\n// Returns true on success, or false on invalid object.\n//\nfunction writeNode(state, level, object, block, compact) {\n  state.tag = null;\n  state.dump = object;\n\n  if (!detectType(state, object, false)) {\n    detectType(state, object, true);\n  }\n\n  var type = _toString.call(state.dump);\n\n  if (block) {\n    block = (0 > state.flowLevel || state.flowLevel > level);\n  }\n\n  if ((null !== state.tag && '?' !== state.tag) || (2 !== state.indent && level > 0)) {\n    compact = false;\n  }\n\n  var objectOrArray = '[object Object]' === type || '[object Array]' === type,\n      duplicateIndex,\n      duplicate;\n\n  if (objectOrArray) {\n    duplicateIndex = state.duplicates.indexOf(object);\n    duplicate = duplicateIndex !== -1;\n  }\n\n  if (duplicate && state.usedDuplicates[duplicateIndex]) {\n    state.dump = '*ref_' + duplicateIndex;\n  } else {\n    if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) {\n      state.usedDuplicates[duplicateIndex] = true;\n    }\n    if ('[object Object]' === type) {\n      if (block && (0 !== Object.keys(state.dump).length)) {\n        writeBlockMapping(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + (0 === level ? '\\n' : '') + state.dump;\n        }\n      } else {\n        writeFlowMapping(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object Array]' === type) {\n      if (block && (0 !== state.dump.length)) {\n        writeBlockSequence(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + (0 === level ? '\\n' : '') + state.dump;\n        }\n      } else {\n        writeFlowSequence(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object String]' === type) {\n      if ('?' !== state.tag) {\n        writeScalar(state, state.dump, level);\n      }\n    } else {\n      if (state.skipInvalid) {\n        return false;\n      }\n      throw new YAMLException('unacceptable kind of an object to dump ' + type);\n    }\n\n    if (null !== state.tag && '?' !== state.tag) {\n      state.dump = '!<' + state.tag + '> ' + state.dump;\n    }\n  }\n\n  return true;\n}\n\nfunction getDuplicateReferences(object, state) {\n  var objects = [],\n      duplicatesIndexes = [],\n      index,\n      length;\n\n  inspectNode(object, objects, duplicatesIndexes);\n\n  for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) {\n    state.duplicates.push(objects[duplicatesIndexes[index]]);\n  }\n  state.usedDuplicates = new Array(length);\n}\n\nfunction inspectNode(object, objects, duplicatesIndexes) {\n  var type = _toString.call(object),\n      objectKeyList,\n      index,\n      length;\n\n  if (null !== object && 'object' === typeof object) {\n    index = objects.indexOf(object);\n    if (-1 !== index) {\n      if (-1 === duplicatesIndexes.indexOf(index)) {\n        duplicatesIndexes.push(index);\n      }\n    } else {\n      objects.push(object);\n\n      if (Array.isArray(object)) {\n        for (index = 0, length = object.length; index < length; index += 1) {\n          inspectNode(object[index], objects, duplicatesIndexes);\n        }\n      } else {\n        objectKeyList = Object.keys(object);\n\n        for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n          inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes);\n        }\n      }\n    }\n  }\n}\n\nfunction dump(input, options) {\n  options = options || {};\n\n  var state = new State(options);\n\n  getDuplicateReferences(input, state);\n\n  if (writeNode(state, 0, input, true, true)) {\n    return state.dump + '\\n';\n  }\n  return '';\n}\n\nfunction safeDump(input, options) {\n  return dump(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\nmodule.exports.dump     = dump;\nmodule.exports.safeDump = safeDump;\n","'use strict';\n\n\nfunction YAMLException(reason, mark) {\n  this.name    = 'YAMLException';\n  this.reason  = reason;\n  this.mark    = mark;\n  this.message = this.toString(false);\n}\n\n\nYAMLException.prototype.toString = function toString(compact) {\n  var result;\n\n  result = 'JS-YAML: ' + (this.reason || '(unknown reason)');\n\n  if (!compact && this.mark) {\n    result += ' ' + this.mark.toString();\n  }\n\n  return result;\n};\n\n\nmodule.exports = YAMLException;\n","'use strict';\n\n/*eslint-disable max-len,no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar Mark                = require('./mark');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\n\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\n\nvar CONTEXT_FLOW_IN   = 1;\nvar CONTEXT_FLOW_OUT  = 2;\nvar CONTEXT_BLOCK_IN  = 3;\nvar CONTEXT_BLOCK_OUT = 4;\n\n\nvar CHOMPING_CLIP  = 1;\nvar CHOMPING_STRIP = 2;\nvar CHOMPING_KEEP  = 3;\n\n\nvar PATTERN_NON_PRINTABLE         = /[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7F-\\x84\\x86-\\x9F\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\nvar PATTERN_NON_ASCII_LINE_BREAKS = /[\\x85\\u2028\\u2029]/;\nvar PATTERN_FLOW_INDICATORS       = /[,\\[\\]\\{\\}]/;\nvar PATTERN_TAG_HANDLE            = /^(?:!|!!|![a-z\\-]+!)$/i;\nvar PATTERN_TAG_URI               = /^(?:!|[^,\\[\\]\\{\\}])(?:%[0-9a-f]{2}|[0-9a-z\\-#;\\/\\?:@&=\\+\\$,_\\.!~\\*'\\(\\)\\[\\]])*$/i;\n\n\nfunction is_EOL(c) {\n  return (c === 0x0A/* LF */) || (c === 0x0D/* CR */);\n}\n\nfunction is_WHITE_SPACE(c) {\n  return (c === 0x09/* Tab */) || (c === 0x20/* Space */);\n}\n\nfunction is_WS_OR_EOL(c) {\n  return (c === 0x09/* Tab */) ||\n         (c === 0x20/* Space */) ||\n         (c === 0x0A/* LF */) ||\n         (c === 0x0D/* CR */);\n}\n\nfunction is_FLOW_INDICATOR(c) {\n  return 0x2C/* , */ === c ||\n         0x5B/* [ */ === c ||\n         0x5D/* ] */ === c ||\n         0x7B/* { */ === c ||\n         0x7D/* } */ === c;\n}\n\nfunction fromHexCode(c) {\n  var lc;\n\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  /*eslint-disable no-bitwise*/\n  lc = c | 0x20;\n\n  if ((0x61/* a */ <= lc) && (lc <= 0x66/* f */)) {\n    return lc - 0x61 + 10;\n  }\n\n  return -1;\n}\n\nfunction escapedHexLen(c) {\n  if (c === 0x78/* x */) { return 2; }\n  if (c === 0x75/* u */) { return 4; }\n  if (c === 0x55/* U */) { return 8; }\n  return 0;\n}\n\nfunction fromDecimalCode(c) {\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  return -1;\n}\n\nfunction simpleEscapeSequence(c) {\n  return (c === 0x30/* 0 */) ? '\\x00' :\n        (c === 0x61/* a */) ? '\\x07' :\n        (c === 0x62/* b */) ? '\\x08' :\n        (c === 0x74/* t */) ? '\\x09' :\n        (c === 0x09/* Tab */) ? '\\x09' :\n        (c === 0x6E/* n */) ? '\\x0A' :\n        (c === 0x76/* v */) ? '\\x0B' :\n        (c === 0x66/* f */) ? '\\x0C' :\n        (c === 0x72/* r */) ? '\\x0D' :\n        (c === 0x65/* e */) ? '\\x1B' :\n        (c === 0x20/* Space */) ? ' ' :\n        (c === 0x22/* \" */) ? '\\x22' :\n        (c === 0x2F/* / */) ? '/' :\n        (c === 0x5C/* \\ */) ? '\\x5C' :\n        (c === 0x4E/* N */) ? '\\x85' :\n        (c === 0x5F/* _ */) ? '\\xA0' :\n        (c === 0x4C/* L */) ? '\\u2028' :\n        (c === 0x50/* P */) ? '\\u2029' : '';\n}\n\nfunction charFromCodepoint(c) {\n  if (c <= 0xFFFF) {\n    return String.fromCharCode(c);\n  }\n  // Encode UTF-16 surrogate pair\n  // https://en.wikipedia.org/wiki/UTF-16#Code_points_U.2B010000_to_U.2B10FFFF\n  return String.fromCharCode(((c - 0x010000) >> 10) + 0xD800,\n                             ((c - 0x010000) & 0x03FF) + 0xDC00);\n}\n\nvar simpleEscapeCheck = new Array(256); // integer, for fast access\nvar simpleEscapeMap = new Array(256);\nfor (var i = 0; i < 256; i++) {\n  simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0;\n  simpleEscapeMap[i] = simpleEscapeSequence(i);\n}\n\n\nfunction State(input, options) {\n  this.input = input;\n\n  this.filename  = options['filename']  || null;\n  this.schema    = options['schema']    || DEFAULT_FULL_SCHEMA;\n  this.onWarning = options['onWarning'] || null;\n  this.legacy    = options['legacy']    || false;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.typeMap       = this.schema.compiledTypeMap;\n\n  this.length     = input.length;\n  this.position   = 0;\n  this.line       = 0;\n  this.lineStart  = 0;\n  this.lineIndent = 0;\n\n  this.documents = [];\n\n  /*\n  this.version;\n  this.checkLineBreaks;\n  this.tagMap;\n  this.anchorMap;\n  this.tag;\n  this.anchor;\n  this.kind;\n  this.result;*/\n\n}\n\n\nfunction generateError(state, message) {\n  return new YAMLException(\n    message,\n    new Mark(state.filename, state.input, state.position, state.line, (state.position - state.lineStart)));\n}\n\nfunction throwError(state, message) {\n  throw generateError(state, message);\n}\n\nfunction throwWarning(state, message) {\n  var error = generateError(state, message);\n\n  if (state.onWarning) {\n    state.onWarning.call(null, error);\n  } else {\n    throw error;\n  }\n}\n\n\nvar directiveHandlers = {\n\n  YAML: function handleYamlDirective(state, name, args) {\n\n      var match, major, minor;\n\n      if (null !== state.version) {\n        throwError(state, 'duplication of %YAML directive');\n      }\n\n      if (1 !== args.length) {\n        throwError(state, 'YAML directive accepts exactly one argument');\n      }\n\n      match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n      if (null === match) {\n        throwError(state, 'ill-formed argument of the YAML directive');\n      }\n\n      major = parseInt(match[1], 10);\n      minor = parseInt(match[2], 10);\n\n      if (1 !== major) {\n        throwError(state, 'unacceptable YAML version of the document');\n      }\n\n      state.version = args[0];\n      state.checkLineBreaks = (minor < 2);\n\n      if (1 !== minor && 2 !== minor) {\n        throwWarning(state, 'unsupported YAML version of the document');\n      }\n    },\n\n  TAG: function handleTagDirective(state, name, args) {\n\n      var handle, prefix;\n\n      if (2 !== args.length) {\n        throwError(state, 'TAG directive accepts exactly two arguments');\n      }\n\n      handle = args[0];\n      prefix = args[1];\n\n      if (!PATTERN_TAG_HANDLE.test(handle)) {\n        throwError(state, 'ill-formed tag handle (first argument) of the TAG directive');\n      }\n\n      if (_hasOwnProperty.call(state.tagMap, handle)) {\n        throwError(state, 'there is a previously declared suffix for \"' + handle + '\" tag handle');\n      }\n\n      if (!PATTERN_TAG_URI.test(prefix)) {\n        throwError(state, 'ill-formed tag prefix (second argument) of the TAG directive');\n      }\n\n      state.tagMap[handle] = prefix;\n    }\n};\n\n\nfunction captureSegment(state, start, end, checkJson) {\n  var _position, _length, _character, _result;\n\n  if (start < end) {\n    _result = state.input.slice(start, end);\n\n    if (checkJson) {\n      for (_position = 0, _length = _result.length;\n           _position < _length;\n           _position += 1) {\n        _character = _result.charCodeAt(_position);\n        if (!(0x09 === _character ||\n              0x20 <= _character && _character <= 0x10FFFF)) {\n          throwError(state, 'expected valid JSON character');\n        }\n      }\n    }\n\n    state.result += _result;\n  }\n}\n\nfunction mergeMappings(state, destination, source) {\n  var sourceKeys, key, index, quantity;\n\n  if (!common.isObject(source)) {\n    throwError(state, 'cannot merge mappings; the provided source object is unacceptable');\n  }\n\n  sourceKeys = Object.keys(source);\n\n  for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) {\n    key = sourceKeys[index];\n\n    if (!_hasOwnProperty.call(destination, key)) {\n      destination[key] = source[key];\n    }\n  }\n}\n\nfunction storeMappingPair(state, _result, keyTag, keyNode, valueNode) {\n  var index, quantity;\n\n  keyNode = String(keyNode);\n\n  if (null === _result) {\n    _result = {};\n  }\n\n  if ('tag:yaml.org,2002:merge' === keyTag) {\n    if (Array.isArray(valueNode)) {\n      for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n        mergeMappings(state, _result, valueNode[index]);\n      }\n    } else {\n      mergeMappings(state, _result, valueNode);\n    }\n  } else {\n    _result[keyNode] = valueNode;\n  }\n\n  return _result;\n}\n\nfunction readLineBreak(state) {\n  var ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x0A/* LF */ === ch) {\n    state.position++;\n  } else if (0x0D/* CR */ === ch) {\n    state.position++;\n    if (0x0A/* LF */ === state.input.charCodeAt(state.position)) {\n      state.position++;\n    }\n  } else {\n    throwError(state, 'a line break is expected');\n  }\n\n  state.line += 1;\n  state.lineStart = state.position;\n}\n\nfunction skipSeparationSpace(state, allowComments, checkIndent) {\n  var lineBreaks = 0,\n      ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    while (is_WHITE_SPACE(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (allowComments && 0x23/* # */ === ch) {\n      do {\n        ch = state.input.charCodeAt(++state.position);\n      } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && 0 !== ch);\n    }\n\n    if (is_EOL(ch)) {\n      readLineBreak(state);\n\n      ch = state.input.charCodeAt(state.position);\n      lineBreaks++;\n      state.lineIndent = 0;\n\n      while (0x20/* Space */ === ch) {\n        state.lineIndent++;\n        ch = state.input.charCodeAt(++state.position);\n      }\n    } else {\n      break;\n    }\n  }\n\n  if (-1 !== checkIndent && 0 !== lineBreaks && state.lineIndent < checkIndent) {\n    throwWarning(state, 'deficient indentation');\n  }\n\n  return lineBreaks;\n}\n\nfunction testDocumentSeparator(state) {\n  var _position = state.position,\n      ch;\n\n  ch = state.input.charCodeAt(_position);\n\n  // Condition state.position === state.lineStart is tested\n  // in parent on each call, for efficiency. No needs to test here again.\n  if ((0x2D/* - */ === ch || 0x2E/* . */ === ch) &&\n      state.input.charCodeAt(_position + 1) === ch &&\n      state.input.charCodeAt(_position + 2) === ch) {\n\n    _position += 3;\n\n    ch = state.input.charCodeAt(_position);\n\n    if (ch === 0 || is_WS_OR_EOL(ch)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction writeFoldedLines(state, count) {\n  if (1 === count) {\n    state.result += ' ';\n  } else if (count > 1) {\n    state.result += common.repeat('\\n', count - 1);\n  }\n}\n\n\nfunction readPlainScalar(state, nodeIndent, withinFlowCollection) {\n  var preceding,\n      following,\n      captureStart,\n      captureEnd,\n      hasPendingContent,\n      _line,\n      _lineStart,\n      _lineIndent,\n      _kind = state.kind,\n      _result = state.result,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (is_WS_OR_EOL(ch)             ||\n      is_FLOW_INDICATOR(ch)        ||\n      0x23/* # */           === ch ||\n      0x26/* & */           === ch ||\n      0x2A/* * */           === ch ||\n      0x21/* ! */           === ch ||\n      0x7C/* | */           === ch ||\n      0x3E/* > */           === ch ||\n      0x27/* ' */           === ch ||\n      0x22/* \" */           === ch ||\n      0x25/* % */           === ch ||\n      0x40/* @ */           === ch ||\n      0x60/* ` */           === ch) {\n    return false;\n  }\n\n  if (0x3F/* ? */ === ch || 0x2D/* - */ === ch) {\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (is_WS_OR_EOL(following) ||\n        withinFlowCollection && is_FLOW_INDICATOR(following)) {\n      return false;\n    }\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  captureStart = captureEnd = state.position;\n  hasPendingContent = false;\n\n  while (0 !== ch) {\n    if (0x3A/* : */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following) ||\n          withinFlowCollection && is_FLOW_INDICATOR(following)) {\n        break;\n      }\n\n    } else if (0x23/* # */ === ch) {\n      preceding = state.input.charCodeAt(state.position - 1);\n\n      if (is_WS_OR_EOL(preceding)) {\n        break;\n      }\n\n    } else if ((state.position === state.lineStart && testDocumentSeparator(state)) ||\n               withinFlowCollection && is_FLOW_INDICATOR(ch)) {\n      break;\n\n    } else if (is_EOL(ch)) {\n      _line = state.line;\n      _lineStart = state.lineStart;\n      _lineIndent = state.lineIndent;\n      skipSeparationSpace(state, false, -1);\n\n      if (state.lineIndent >= nodeIndent) {\n        hasPendingContent = true;\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      } else {\n        state.position = captureEnd;\n        state.line = _line;\n        state.lineStart = _lineStart;\n        state.lineIndent = _lineIndent;\n        break;\n      }\n    }\n\n    if (hasPendingContent) {\n      captureSegment(state, captureStart, captureEnd, false);\n      writeFoldedLines(state, state.line - _line);\n      captureStart = captureEnd = state.position;\n      hasPendingContent = false;\n    }\n\n    if (!is_WHITE_SPACE(ch)) {\n      captureEnd = state.position + 1;\n    }\n\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  captureSegment(state, captureStart, captureEnd, false);\n\n  if (state.result) {\n    return true;\n  }\n\n  state.kind = _kind;\n  state.result = _result;\n  return false;\n}\n\nfunction readSingleQuotedScalar(state, nodeIndent) {\n  var ch,\n      captureStart, captureEnd;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x27/* ' */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x27/* ' */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (0x27/* ' */ === ch) {\n        captureStart = captureEnd = state.position;\n        state.position++;\n      } else {\n        return true;\n      }\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a single quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a single quoted scalar');\n}\n\nfunction readDoubleQuotedScalar(state, nodeIndent) {\n  var captureStart,\n      captureEnd,\n      hexLength,\n      hexResult,\n      tmp, tmpEsc,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x22/* \" */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x22/* \" */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      state.position++;\n      return true;\n\n    } else if (0x5C/* \\ */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (is_EOL(ch)) {\n        skipSeparationSpace(state, false, nodeIndent);\n\n        // TODO: rework to inline fn with no type cast?\n      } else if (ch < 256 && simpleEscapeCheck[ch]) {\n        state.result += simpleEscapeMap[ch];\n        state.position++;\n\n      } else if ((tmp = escapedHexLen(ch)) > 0) {\n        hexLength = tmp;\n        hexResult = 0;\n\n        for (; hexLength > 0; hexLength--) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if ((tmp = fromHexCode(ch)) >= 0) {\n            hexResult = (hexResult << 4) + tmp;\n\n          } else {\n            throwError(state, 'expected hexadecimal character');\n          }\n        }\n\n        state.result += charFromCodepoint(hexResult);\n\n        state.position++;\n\n      } else {\n        throwError(state, 'unknown escape sequence');\n      }\n\n      captureStart = captureEnd = state.position;\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a double quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a double quoted scalar');\n}\n\nfunction readFlowCollection(state, nodeIndent) {\n  var readNext = true,\n      _line,\n      _tag     = state.tag,\n      _result,\n      _anchor  = state.anchor,\n      following,\n      terminator,\n      isPair,\n      isExplicitPair,\n      isMapping,\n      keyNode,\n      keyTag,\n      valueNode,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x5B/* [ */) {\n    terminator = 0x5D;/* ] */\n    isMapping = false;\n    _result = [];\n  } else if (ch === 0x7B/* { */) {\n    terminator = 0x7D;/* } */\n    isMapping = true;\n    _result = {};\n  } else {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  while (0 !== ch) {\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (ch === terminator) {\n      state.position++;\n      state.tag = _tag;\n      state.anchor = _anchor;\n      state.kind = isMapping ? 'mapping' : 'sequence';\n      state.result = _result;\n      return true;\n    } else if (!readNext) {\n      throwError(state, 'missed comma between flow collection entries');\n    }\n\n    keyTag = keyNode = valueNode = null;\n    isPair = isExplicitPair = false;\n\n    if (0x3F/* ? */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following)) {\n        isPair = isExplicitPair = true;\n        state.position++;\n        skipSeparationSpace(state, true, nodeIndent);\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n    keyTag = state.tag;\n    keyNode = state.result;\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((isExplicitPair || state.line === _line) && 0x3A/* : */ === ch) {\n      isPair = true;\n      ch = state.input.charCodeAt(++state.position);\n      skipSeparationSpace(state, true, nodeIndent);\n      composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n      valueNode = state.result;\n    }\n\n    if (isMapping) {\n      storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n    } else if (isPair) {\n      _result.push(storeMappingPair(state, null, keyTag, keyNode, valueNode));\n    } else {\n      _result.push(keyNode);\n    }\n\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (0x2C/* , */ === ch) {\n      readNext = true;\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      readNext = false;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a flow collection');\n}\n\nfunction readBlockScalar(state, nodeIndent) {\n  var captureStart,\n      folding,\n      chomping       = CHOMPING_CLIP,\n      detectedIndent = false,\n      textIndent     = nodeIndent,\n      emptyLines     = 0,\n      atMoreIndented = false,\n      tmp,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x7C/* | */) {\n    folding = false;\n  } else if (ch === 0x3E/* > */) {\n    folding = true;\n  } else {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n\n  while (0 !== ch) {\n    ch = state.input.charCodeAt(++state.position);\n\n    if (0x2B/* + */ === ch || 0x2D/* - */ === ch) {\n      if (CHOMPING_CLIP === chomping) {\n        chomping = (0x2B/* + */ === ch) ? CHOMPING_KEEP : CHOMPING_STRIP;\n      } else {\n        throwError(state, 'repeat of a chomping mode identifier');\n      }\n\n    } else if ((tmp = fromDecimalCode(ch)) >= 0) {\n      if (tmp === 0) {\n        throwError(state, 'bad explicit indentation width of a block scalar; it cannot be less than one');\n      } else if (!detectedIndent) {\n        textIndent = nodeIndent + tmp - 1;\n        detectedIndent = true;\n      } else {\n        throwError(state, 'repeat of an indentation width identifier');\n      }\n\n    } else {\n      break;\n    }\n  }\n\n  if (is_WHITE_SPACE(ch)) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (is_WHITE_SPACE(ch));\n\n    if (0x23/* # */ === ch) {\n      do { ch = state.input.charCodeAt(++state.position); }\n      while (!is_EOL(ch) && (0 !== ch));\n    }\n  }\n\n  while (0 !== ch) {\n    readLineBreak(state);\n    state.lineIndent = 0;\n\n    ch = state.input.charCodeAt(state.position);\n\n    while ((!detectedIndent || state.lineIndent < textIndent) &&\n           (0x20/* Space */ === ch)) {\n      state.lineIndent++;\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (!detectedIndent && state.lineIndent > textIndent) {\n      textIndent = state.lineIndent;\n    }\n\n    if (is_EOL(ch)) {\n      emptyLines++;\n      continue;\n    }\n\n    // End of the scalar.\n    if (state.lineIndent < textIndent) {\n\n      // Perform the chomping.\n      if (chomping === CHOMPING_KEEP) {\n        state.result += common.repeat('\\n', emptyLines);\n      } else if (chomping === CHOMPING_CLIP) {\n        if (detectedIndent) { // i.e. only if the scalar is not empty.\n          state.result += '\\n';\n        }\n      }\n\n      // Break this `while` cycle and go to the funciton's epilogue.\n      break;\n    }\n\n    // Folded style: use fancy rules to handle line breaks.\n    if (folding) {\n\n      // Lines starting with white space characters (more-indented lines) are not folded.\n      if (is_WHITE_SPACE(ch)) {\n        atMoreIndented = true;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // End of more-indented block.\n      } else if (atMoreIndented) {\n        atMoreIndented = false;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // Just one line break - perceive as the same line.\n      } else if (0 === emptyLines) {\n        if (detectedIndent) { // i.e. only if we have already read some scalar content.\n          state.result += ' ';\n        }\n\n      // Several line breaks - perceive as different lines.\n      } else {\n        state.result += common.repeat('\\n', emptyLines);\n      }\n\n    // Literal style: just add exact number of line breaks between content lines.\n    } else if (detectedIndent) {\n      // If current line isn't the first one - count line break from the last content line.\n      state.result += common.repeat('\\n', emptyLines + 1);\n    } else {\n      // In case of the first content line - count only empty lines.\n    }\n\n    detectedIndent = true;\n    emptyLines = 0;\n    captureStart = state.position;\n\n    while (!is_EOL(ch) && (0 !== ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    captureSegment(state, captureStart, state.position, false);\n  }\n\n  return true;\n}\n\nfunction readBlockSequence(state, nodeIndent) {\n  var _line,\n      _tag      = state.tag,\n      _anchor   = state.anchor,\n      _result   = [],\n      following,\n      detected  = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n\n    if (0x2D/* - */ !== ch) {\n      break;\n    }\n\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (!is_WS_OR_EOL(following)) {\n      break;\n    }\n\n    detected = true;\n    state.position++;\n\n    if (skipSeparationSpace(state, true, -1)) {\n      if (state.lineIndent <= nodeIndent) {\n        _result.push(null);\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true);\n    _result.push(state.result);\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((state.line === _line || state.lineIndent > nodeIndent) && (0 !== ch)) {\n      throwError(state, 'bad indentation of a sequence entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'sequence';\n    state.result = _result;\n    return true;\n  }\n  return false;\n}\n\nfunction readBlockMapping(state, nodeIndent, flowIndent) {\n  var following,\n      allowCompact,\n      _line,\n      _tag          = state.tag,\n      _anchor       = state.anchor,\n      _result       = {},\n      keyTag        = null,\n      keyNode       = null,\n      valueNode     = null,\n      atExplicitKey = false,\n      detected      = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    following = state.input.charCodeAt(state.position + 1);\n    _line = state.line; // Save the current line.\n\n    //\n    // Explicit notation case. There are two separate blocks:\n    // first for the key (denoted by \"?\") and second for the value (denoted by \":\")\n    //\n    if ((0x3F/* ? */ === ch || 0x3A/* : */  === ch) && is_WS_OR_EOL(following)) {\n\n      if (0x3F/* ? */ === ch) {\n        if (atExplicitKey) {\n          storeMappingPair(state, _result, keyTag, keyNode, null);\n          keyTag = keyNode = valueNode = null;\n        }\n\n        detected = true;\n        atExplicitKey = true;\n        allowCompact = true;\n\n      } else if (atExplicitKey) {\n        // i.e. 0x3A/* : */ === character after the explicit key.\n        atExplicitKey = false;\n        allowCompact = true;\n\n      } else {\n        throwError(state, 'incomplete explicit mapping pair; a key node is missed');\n      }\n\n      state.position += 1;\n      ch = following;\n\n    //\n    // Implicit notation case. Flow-style node as the key first, then \":\", and the value.\n    //\n    } else if (composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) {\n\n      if (state.line === _line) {\n        ch = state.input.charCodeAt(state.position);\n\n        while (is_WHITE_SPACE(ch)) {\n          ch = state.input.charCodeAt(++state.position);\n        }\n\n        if (0x3A/* : */ === ch) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if (!is_WS_OR_EOL(ch)) {\n            throwError(state, 'a whitespace character is expected after the key-value separator within a block mapping');\n          }\n\n          if (atExplicitKey) {\n            storeMappingPair(state, _result, keyTag, keyNode, null);\n            keyTag = keyNode = valueNode = null;\n          }\n\n          detected = true;\n          atExplicitKey = false;\n          allowCompact = false;\n          keyTag = state.tag;\n          keyNode = state.result;\n\n        } else if (detected) {\n          throwError(state, 'can not read an implicit mapping pair; a colon is missed');\n\n        } else {\n          state.tag = _tag;\n          state.anchor = _anchor;\n          return true; // Keep the result of `composeNode`.\n        }\n\n      } else if (detected) {\n        throwError(state, 'can not read a block mapping entry; a multiline key may not be an implicit key');\n\n      } else {\n        state.tag = _tag;\n        state.anchor = _anchor;\n        return true; // Keep the result of `composeNode`.\n      }\n\n    } else {\n      break; // Reading is done. Go to the epilogue.\n    }\n\n    //\n    // Common reading code for both explicit and implicit notations.\n    //\n    if (state.line === _line || state.lineIndent > nodeIndent) {\n      if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) {\n        if (atExplicitKey) {\n          keyNode = state.result;\n        } else {\n          valueNode = state.result;\n        }\n      }\n\n      if (!atExplicitKey) {\n        storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n        keyTag = keyNode = valueNode = null;\n      }\n\n      skipSeparationSpace(state, true, -1);\n      ch = state.input.charCodeAt(state.position);\n    }\n\n    if (state.lineIndent > nodeIndent && (0 !== ch)) {\n      throwError(state, 'bad indentation of a mapping entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  //\n  // Epilogue.\n  //\n\n  // Special case: last mapping's node contains only the key in explicit notation.\n  if (atExplicitKey) {\n    storeMappingPair(state, _result, keyTag, keyNode, null);\n  }\n\n  // Expose the resulting mapping.\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'mapping';\n    state.result = _result;\n  }\n\n  return detected;\n}\n\nfunction readTagProperty(state) {\n  var _position,\n      isVerbatim = false,\n      isNamed    = false,\n      tagHandle,\n      tagName,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x21/* ! */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.tag) {\n    throwError(state, 'duplication of a tag property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  if (0x3C/* < */ === ch) {\n    isVerbatim = true;\n    ch = state.input.charCodeAt(++state.position);\n\n  } else if (0x21/* ! */ === ch) {\n    isNamed = true;\n    tagHandle = '!!';\n    ch = state.input.charCodeAt(++state.position);\n\n  } else {\n    tagHandle = '!';\n  }\n\n  _position = state.position;\n\n  if (isVerbatim) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (0 !== ch && 0x3E/* > */ !== ch);\n\n    if (state.position < state.length) {\n      tagName = state.input.slice(_position, state.position);\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      throwError(state, 'unexpected end of the stream within a verbatim tag');\n    }\n  } else {\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n\n      if (0x21/* ! */ === ch) {\n        if (!isNamed) {\n          tagHandle = state.input.slice(_position - 1, state.position + 1);\n\n          if (!PATTERN_TAG_HANDLE.test(tagHandle)) {\n            throwError(state, 'named tag handle cannot contain such characters');\n          }\n\n          isNamed = true;\n          _position = state.position + 1;\n        } else {\n          throwError(state, 'tag suffix cannot contain exclamation marks');\n        }\n      }\n\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    tagName = state.input.slice(_position, state.position);\n\n    if (PATTERN_FLOW_INDICATORS.test(tagName)) {\n      throwError(state, 'tag suffix cannot contain flow indicator characters');\n    }\n  }\n\n  if (tagName && !PATTERN_TAG_URI.test(tagName)) {\n    throwError(state, 'tag name cannot contain such characters: ' + tagName);\n  }\n\n  if (isVerbatim) {\n    state.tag = tagName;\n\n  } else if (_hasOwnProperty.call(state.tagMap, tagHandle)) {\n    state.tag = state.tagMap[tagHandle] + tagName;\n\n  } else if ('!' === tagHandle) {\n    state.tag = '!' + tagName;\n\n  } else if ('!!' === tagHandle) {\n    state.tag = 'tag:yaml.org,2002:' + tagName;\n\n  } else {\n    throwError(state, 'undeclared tag handle \"' + tagHandle + '\"');\n  }\n\n  return true;\n}\n\nfunction readAnchorProperty(state) {\n  var _position,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x26/* & */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    throwError(state, 'duplication of an anchor property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an anchor node must contain at least one character');\n  }\n\n  state.anchor = state.input.slice(_position, state.position);\n  return true;\n}\n\nfunction readAlias(state) {\n  var _position, alias,\n      len = state.length,\n      input = state.input,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x2A/* * */ !== ch) {\n    return false;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an alias node must contain at least one character');\n  }\n\n  alias = state.input.slice(_position, state.position);\n\n  if (!state.anchorMap.hasOwnProperty(alias)) {\n    throwError(state, 'unidentified alias \"' + alias + '\"');\n  }\n\n  state.result = state.anchorMap[alias];\n  skipSeparationSpace(state, true, -1);\n  return true;\n}\n\nfunction composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) {\n  var allowBlockStyles,\n      allowBlockScalars,\n      allowBlockCollections,\n      indentStatus = 1, // 1: this>parent, 0: this=parent, -1: this<parent\n      atNewLine  = false,\n      hasContent = false,\n      typeIndex,\n      typeQuantity,\n      type,\n      flowIndent,\n      blockIndent,\n      _result;\n\n  state.tag    = null;\n  state.anchor = null;\n  state.kind   = null;\n  state.result = null;\n\n  allowBlockStyles = allowBlockScalars = allowBlockCollections =\n    CONTEXT_BLOCK_OUT === nodeContext ||\n    CONTEXT_BLOCK_IN  === nodeContext;\n\n  if (allowToSeek) {\n    if (skipSeparationSpace(state, true, -1)) {\n      atNewLine = true;\n\n      if (state.lineIndent > parentIndent) {\n        indentStatus = 1;\n      } else if (state.lineIndent === parentIndent) {\n        indentStatus = 0;\n      } else if (state.lineIndent < parentIndent) {\n        indentStatus = -1;\n      }\n    }\n  }\n\n  if (1 === indentStatus) {\n    while (readTagProperty(state) || readAnchorProperty(state)) {\n      if (skipSeparationSpace(state, true, -1)) {\n        atNewLine = true;\n        allowBlockCollections = allowBlockStyles;\n\n        if (state.lineIndent > parentIndent) {\n          indentStatus = 1;\n        } else if (state.lineIndent === parentIndent) {\n          indentStatus = 0;\n        } else if (state.lineIndent < parentIndent) {\n          indentStatus = -1;\n        }\n      } else {\n        allowBlockCollections = false;\n      }\n    }\n  }\n\n  if (allowBlockCollections) {\n    allowBlockCollections = atNewLine || allowCompact;\n  }\n\n  if (1 === indentStatus || CONTEXT_BLOCK_OUT === nodeContext) {\n    if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) {\n      flowIndent = parentIndent;\n    } else {\n      flowIndent = parentIndent + 1;\n    }\n\n    blockIndent = state.position - state.lineStart;\n\n    if (1 === indentStatus) {\n      if (allowBlockCollections &&\n          (readBlockSequence(state, blockIndent) ||\n           readBlockMapping(state, blockIndent, flowIndent)) ||\n          readFlowCollection(state, flowIndent)) {\n        hasContent = true;\n      } else {\n        if ((allowBlockScalars && readBlockScalar(state, flowIndent)) ||\n            readSingleQuotedScalar(state, flowIndent) ||\n            readDoubleQuotedScalar(state, flowIndent)) {\n          hasContent = true;\n\n        } else if (readAlias(state)) {\n          hasContent = true;\n\n          if (null !== state.tag || null !== state.anchor) {\n            throwError(state, 'alias node should not have any properties');\n          }\n\n        } else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) {\n          hasContent = true;\n\n          if (null === state.tag) {\n            state.tag = '?';\n          }\n        }\n\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else if (0 === indentStatus) {\n      // Special case: block sequences are allowed to have same indentation level as the parent.\n      // http://www.yaml.org/spec/1.2/spec.html#id2799784\n      hasContent = allowBlockCollections && readBlockSequence(state, blockIndent);\n    }\n  }\n\n  if (null !== state.tag && '!' !== state.tag) {\n    if ('?' === state.tag) {\n      for (typeIndex = 0, typeQuantity = state.implicitTypes.length;\n           typeIndex < typeQuantity;\n           typeIndex += 1) {\n        type = state.implicitTypes[typeIndex];\n\n        // Implicit resolving is not allowed for non-scalar types, and '?'\n        // non-specific tag is only assigned to plain scalars. So, it isn't\n        // needed to check for 'kind' conformity.\n\n        if (type.resolve(state.result)) { // `state.result` updated in resolver if matched\n          state.result = type.construct(state.result);\n          state.tag = type.tag;\n          if (null !== state.anchor) {\n            state.anchorMap[state.anchor] = state.result;\n          }\n          break;\n        }\n      }\n    } else if (_hasOwnProperty.call(state.typeMap, state.tag)) {\n      type = state.typeMap[state.tag];\n\n      if (null !== state.result && type.kind !== state.kind) {\n        throwError(state, 'unacceptable node kind for !<' + state.tag + '> tag; it should be \"' + type.kind + '\", not \"' + state.kind + '\"');\n      }\n\n      if (!type.resolve(state.result)) { // `state.result` updated in resolver if matched\n        throwError(state, 'cannot resolve a node with !<' + state.tag + '> explicit tag');\n      } else {\n        state.result = type.construct(state.result);\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else {\n      throwWarning(state, 'unknown tag !<' + state.tag + '>');\n    }\n  }\n\n  return null !== state.tag || null !== state.anchor || hasContent;\n}\n\nfunction readDocument(state) {\n  var documentStart = state.position,\n      _position,\n      directiveName,\n      directiveArgs,\n      hasDirectives = false,\n      ch;\n\n  state.version = null;\n  state.checkLineBreaks = state.legacy;\n  state.tagMap = {};\n  state.anchorMap = {};\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (state.lineIndent > 0 || 0x25/* % */ !== ch) {\n      break;\n    }\n\n    hasDirectives = true;\n    ch = state.input.charCodeAt(++state.position);\n    _position = state.position;\n\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    directiveName = state.input.slice(_position, state.position);\n    directiveArgs = [];\n\n    if (directiveName.length < 1) {\n      throwError(state, 'directive name must not be less than one character in length');\n    }\n\n    while (0 !== ch) {\n      while (is_WHITE_SPACE(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      if (0x23/* # */ === ch) {\n        do { ch = state.input.charCodeAt(++state.position); }\n        while (0 !== ch && !is_EOL(ch));\n        break;\n      }\n\n      if (is_EOL(ch)) {\n        break;\n      }\n\n      _position = state.position;\n\n      while (0 !== ch && !is_WS_OR_EOL(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      directiveArgs.push(state.input.slice(_position, state.position));\n    }\n\n    if (0 !== ch) {\n      readLineBreak(state);\n    }\n\n    if (_hasOwnProperty.call(directiveHandlers, directiveName)) {\n      directiveHandlers[directiveName](state, directiveName, directiveArgs);\n    } else {\n      throwWarning(state, 'unknown document directive \"' + directiveName + '\"');\n    }\n  }\n\n  skipSeparationSpace(state, true, -1);\n\n  if (0 === state.lineIndent &&\n      0x2D/* - */ === state.input.charCodeAt(state.position) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 1) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 2)) {\n    state.position += 3;\n    skipSeparationSpace(state, true, -1);\n\n  } else if (hasDirectives) {\n    throwError(state, 'directives end mark is expected');\n  }\n\n  composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true);\n  skipSeparationSpace(state, true, -1);\n\n  if (state.checkLineBreaks &&\n      PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) {\n    throwWarning(state, 'non-ASCII line breaks are interpreted as content');\n  }\n\n  state.documents.push(state.result);\n\n  if (state.position === state.lineStart && testDocumentSeparator(state)) {\n\n    if (0x2E/* . */ === state.input.charCodeAt(state.position)) {\n      state.position += 3;\n      skipSeparationSpace(state, true, -1);\n    }\n    return;\n  }\n\n  if (state.position < (state.length - 1)) {\n    throwError(state, 'end of the stream or a document separator is expected');\n  } else {\n    return;\n  }\n}\n\n\nfunction loadDocuments(input, options) {\n  input = String(input);\n  options = options || {};\n\n  if (input.length !== 0) {\n\n    // Add tailing `\\n` if not exists\n    if (0x0A/* LF */ !== input.charCodeAt(input.length - 1) &&\n        0x0D/* CR */ !== input.charCodeAt(input.length - 1)) {\n      input += '\\n';\n    }\n\n    // Strip BOM\n    if (input.charCodeAt(0) === 0xFEFF) {\n      input = input.slice(1);\n    }\n  }\n\n  var state = new State(input, options);\n\n  if (PATTERN_NON_PRINTABLE.test(state.input)) {\n    throwError(state, 'the stream contains non-printable characters');\n  }\n\n  // Use 0 as string terminator. That significantly simplifies bounds check.\n  state.input += '\\0';\n\n  while (0x20/* Space */ === state.input.charCodeAt(state.position)) {\n    state.lineIndent += 1;\n    state.position += 1;\n  }\n\n  while (state.position < (state.length - 1)) {\n    readDocument(state);\n  }\n\n  return state.documents;\n}\n\n\nfunction loadAll(input, iterator, options) {\n  var documents = loadDocuments(input, options), index, length;\n\n  for (index = 0, length = documents.length; index < length; index += 1) {\n    iterator(documents[index]);\n  }\n}\n\n\nfunction load(input, options) {\n  var documents = loadDocuments(input, options), index, length;\n\n  if (0 === documents.length) {\n    /*eslint-disable no-undefined*/\n    return undefined;\n  } else if (1 === documents.length) {\n    return documents[0];\n  }\n  throw new YAMLException('expected a single document in the stream, but found more');\n}\n\n\nfunction safeLoadAll(input, output, options) {\n  loadAll(input, output, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nfunction safeLoad(input, options) {\n  return load(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nmodule.exports.loadAll     = loadAll;\nmodule.exports.load        = load;\nmodule.exports.safeLoadAll = safeLoadAll;\nmodule.exports.safeLoad    = safeLoad;\n","'use strict';\n\n\nvar common = require('./common');\n\n\nfunction Mark(name, buffer, position, line, column) {\n  this.name     = name;\n  this.buffer   = buffer;\n  this.position = position;\n  this.line     = line;\n  this.column   = column;\n}\n\n\nMark.prototype.getSnippet = function getSnippet(indent, maxLength) {\n  var head, start, tail, end, snippet;\n\n  if (!this.buffer) {\n    return null;\n  }\n\n  indent = indent || 4;\n  maxLength = maxLength || 75;\n\n  head = '';\n  start = this.position;\n\n  while (start > 0 && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(start - 1))) {\n    start -= 1;\n    if (this.position - start > (maxLength / 2 - 1)) {\n      head = ' ... ';\n      start += 5;\n      break;\n    }\n  }\n\n  tail = '';\n  end = this.position;\n\n  while (end < this.buffer.length && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(end))) {\n    end += 1;\n    if (end - this.position > (maxLength / 2 - 1)) {\n      tail = ' ... ';\n      end -= 5;\n      break;\n    }\n  }\n\n  snippet = this.buffer.slice(start, end);\n\n  return common.repeat(' ', indent) + head + snippet + tail + '\\n' +\n         common.repeat(' ', indent + this.position - start + head.length) + '^';\n};\n\n\nMark.prototype.toString = function toString(compact) {\n  var snippet, where = '';\n\n  if (this.name) {\n    where += 'in \"' + this.name + '\" ';\n  }\n\n  where += 'at line ' + (this.line + 1) + ', column ' + (this.column + 1);\n\n  if (!compact) {\n    snippet = this.getSnippet();\n\n    if (snippet) {\n      where += ':\\n' + snippet;\n    }\n  }\n\n  return where;\n};\n\n\nmodule.exports = Mark;\n","'use strict';\n\n/*eslint-disable max-len*/\n\nvar common        = require('./common');\nvar YAMLException = require('./exception');\nvar Type          = require('./type');\n\n\nfunction compileList(schema, name, result) {\n  var exclude = [];\n\n  schema.include.forEach(function (includedSchema) {\n    result = compileList(includedSchema, name, result);\n  });\n\n  schema[name].forEach(function (currentType) {\n    result.forEach(function (previousType, previousIndex) {\n      if (previousType.tag === currentType.tag) {\n        exclude.push(previousIndex);\n      }\n    });\n\n    result.push(currentType);\n  });\n\n  return result.filter(function (type, index) {\n    return -1 === exclude.indexOf(index);\n  });\n}\n\n\nfunction compileMap(/* lists... */) {\n  var result = {}, index, length;\n\n  function collectType(type) {\n    result[type.tag] = type;\n  }\n\n  for (index = 0, length = arguments.length; index < length; index += 1) {\n    arguments[index].forEach(collectType);\n  }\n\n  return result;\n}\n\n\nfunction Schema(definition) {\n  this.include  = definition.include  || [];\n  this.implicit = definition.implicit || [];\n  this.explicit = definition.explicit || [];\n\n  this.implicit.forEach(function (type) {\n    if (type.loadKind && 'scalar' !== type.loadKind) {\n      throw new YAMLException('There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.');\n    }\n  });\n\n  this.compiledImplicit = compileList(this, 'implicit', []);\n  this.compiledExplicit = compileList(this, 'explicit', []);\n  this.compiledTypeMap  = compileMap(this.compiledImplicit, this.compiledExplicit);\n}\n\n\nSchema.DEFAULT = null;\n\n\nSchema.create = function createSchema() {\n  var schemas, types;\n\n  switch (arguments.length) {\n  case 1:\n    schemas = Schema.DEFAULT;\n    types = arguments[0];\n    break;\n\n  case 2:\n    schemas = arguments[0];\n    types = arguments[1];\n    break;\n\n  default:\n    throw new YAMLException('Wrong number of arguments for Schema.create function');\n  }\n\n  schemas = common.toArray(schemas);\n  types = common.toArray(types);\n\n  if (!schemas.every(function (schema) { return schema instanceof Schema; })) {\n    throw new YAMLException('Specified list of super schemas (or a single Schema object) contains a non-Schema object.');\n  }\n\n  if (!types.every(function (type) { return type instanceof Type; })) {\n    throw new YAMLException('Specified list of YAML types (or a single Type object) contains a non-Type object.');\n  }\n\n  return new Schema({\n    include: schemas,\n    explicit: types\n  });\n};\n\n\nmodule.exports = Schema;\n","// Standard YAML's Core schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2804923\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, Core schema has no distinctions from JSON schema is JS-YAML.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./json')\n  ]\n});\n","// JS-YAML's default schema for `load` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on JS-YAML's default safe schema and includes\n// JavaScript-specific types: !!js/undefined, !!js/regexp and !!js/function.\n//\n// Also this schema is used as default base schema at `Schema.create` function.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = Schema.DEFAULT = new Schema({\n  include: [\n    require('./default_safe')\n  ],\n  explicit: [\n    require('../type/js/undefined'),\n    require('../type/js/regexp'),\n    require('../type/js/function')\n  ]\n});\n","// JS-YAML's default schema for `safeLoad` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on standard YAML's Core schema and includes most of\n// extra types described at YAML tag repository. (http://yaml.org/type/)\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./core')\n  ],\n  implicit: [\n    require('../type/timestamp'),\n    require('../type/merge')\n  ],\n  explicit: [\n    require('../type/binary'),\n    require('../type/omap'),\n    require('../type/pairs'),\n    require('../type/set')\n  ]\n});\n","// Standard YAML's Failsafe schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2802346\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  explicit: [\n    require('../type/str'),\n    require('../type/seq'),\n    require('../type/map')\n  ]\n});\n","// Standard YAML's JSON schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2803231\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, this schema is not such strict as defined in the YAML specification.\n// It allows numbers in binary notaion, use `Null` and `NULL` as `null`, etc.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./failsafe')\n  ],\n  implicit: [\n    require('../type/null'),\n    require('../type/bool'),\n    require('../type/int'),\n    require('../type/float')\n  ]\n});\n","'use strict';\n\nvar YAMLException = require('./exception');\n\nvar TYPE_CONSTRUCTOR_OPTIONS = [\n  'kind',\n  'resolve',\n  'construct',\n  'instanceOf',\n  'predicate',\n  'represent',\n  'defaultStyle',\n  'styleAliases'\n];\n\nvar YAML_NODE_KINDS = [\n  'scalar',\n  'sequence',\n  'mapping'\n];\n\nfunction compileStyleAliases(map) {\n  var result = {};\n\n  if (null !== map) {\n    Object.keys(map).forEach(function (style) {\n      map[style].forEach(function (alias) {\n        result[String(alias)] = style;\n      });\n    });\n  }\n\n  return result;\n}\n\nfunction Type(tag, options) {\n  options = options || {};\n\n  Object.keys(options).forEach(function (name) {\n    if (-1 === TYPE_CONSTRUCTOR_OPTIONS.indexOf(name)) {\n      throw new YAMLException('Unknown option \"' + name + '\" is met in definition of \"' + tag + '\" YAML type.');\n    }\n  });\n\n  // TODO: Add tag format check.\n  this.tag          = tag;\n  this.kind         = options['kind']         || null;\n  this.resolve      = options['resolve']      || function () { return true; };\n  this.construct    = options['construct']    || function (data) { return data; };\n  this.instanceOf   = options['instanceOf']   || null;\n  this.predicate    = options['predicate']    || null;\n  this.represent    = options['represent']    || null;\n  this.defaultStyle = options['defaultStyle'] || null;\n  this.styleAliases = compileStyleAliases(options['styleAliases'] || null);\n\n  if (-1 === YAML_NODE_KINDS.indexOf(this.kind)) {\n    throw new YAMLException('Unknown kind \"' + this.kind + '\" is specified for \"' + tag + '\" YAML type.');\n  }\n}\n\nmodule.exports = Type;\n","'use strict';\n\n/*eslint-disable no-bitwise*/\n\n// A trick for browserified version.\n// Since we make browserifier to ignore `buffer` module, NodeBuffer will be undefined\nvar NodeBuffer = require('buffer').Buffer;\nvar Type       = require('../type');\n\n\n// [ 64, 65, 66 ] -> [ padding, CR, LF ]\nvar BASE64_MAP = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\\n\\r';\n\n\nfunction resolveYamlBinary(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var code, idx, bitlen = 0, len = 0, max = data.length, map = BASE64_MAP;\n\n  // Convert one by one.\n  for (idx = 0; idx < max; idx++) {\n    code = map.indexOf(data.charAt(idx));\n\n    // Skip CR/LF\n    if (code > 64) { continue; }\n\n    // Fail on illegal characters\n    if (code < 0) { return false; }\n\n    bitlen += 6;\n  }\n\n  // If there are any bits left, source was corrupted\n  return (bitlen % 8) === 0;\n}\n\nfunction constructYamlBinary(data) {\n  var code, idx, tailbits,\n      input = data.replace(/[\\r\\n=]/g, ''), // remove CR/LF & padding to simplify scan\n      max = input.length,\n      map = BASE64_MAP,\n      bits = 0,\n      result = [];\n\n  // Collect by 6*4 bits (3 bytes)\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 4 === 0) && idx) {\n      result.push((bits >> 16) & 0xFF);\n      result.push((bits >> 8) & 0xFF);\n      result.push(bits & 0xFF);\n    }\n\n    bits = (bits << 6) | map.indexOf(input.charAt(idx));\n  }\n\n  // Dump tail\n\n  tailbits = (max % 4) * 6;\n\n  if (tailbits === 0) {\n    result.push((bits >> 16) & 0xFF);\n    result.push((bits >> 8) & 0xFF);\n    result.push(bits & 0xFF);\n  } else if (tailbits === 18) {\n    result.push((bits >> 10) & 0xFF);\n    result.push((bits >> 2) & 0xFF);\n  } else if (tailbits === 12) {\n    result.push((bits >> 4) & 0xFF);\n  }\n\n  // Wrap into Buffer for NodeJS and leave Array for browser\n  if (NodeBuffer) {\n    return new NodeBuffer(result);\n  }\n\n  return result;\n}\n\nfunction representYamlBinary(object /*, style*/) {\n  var result = '', bits = 0, idx, tail,\n      max = object.length,\n      map = BASE64_MAP;\n\n  // Convert every three bytes to 4 ASCII characters.\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 3 === 0) && idx) {\n      result += map[(bits >> 18) & 0x3F];\n      result += map[(bits >> 12) & 0x3F];\n      result += map[(bits >> 6) & 0x3F];\n      result += map[bits & 0x3F];\n    }\n\n    bits = (bits << 8) + object[idx];\n  }\n\n  // Dump tail\n\n  tail = max % 3;\n\n  if (tail === 0) {\n    result += map[(bits >> 18) & 0x3F];\n    result += map[(bits >> 12) & 0x3F];\n    result += map[(bits >> 6) & 0x3F];\n    result += map[bits & 0x3F];\n  } else if (tail === 2) {\n    result += map[(bits >> 10) & 0x3F];\n    result += map[(bits >> 4) & 0x3F];\n    result += map[(bits << 2) & 0x3F];\n    result += map[64];\n  } else if (tail === 1) {\n    result += map[(bits >> 2) & 0x3F];\n    result += map[(bits << 4) & 0x3F];\n    result += map[64];\n    result += map[64];\n  }\n\n  return result;\n}\n\nfunction isBinary(object) {\n  return NodeBuffer && NodeBuffer.isBuffer(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:binary', {\n  kind: 'scalar',\n  resolve: resolveYamlBinary,\n  construct: constructYamlBinary,\n  predicate: isBinary,\n  represent: representYamlBinary\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlBoolean(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length;\n\n  return (max === 4 && (data === 'true' || data === 'True' || data === 'TRUE')) ||\n         (max === 5 && (data === 'false' || data === 'False' || data === 'FALSE'));\n}\n\nfunction constructYamlBoolean(data) {\n  return data === 'true' ||\n         data === 'True' ||\n         data === 'TRUE';\n}\n\nfunction isBoolean(object) {\n  return '[object Boolean]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:bool', {\n  kind: 'scalar',\n  resolve: resolveYamlBoolean,\n  construct: constructYamlBoolean,\n  predicate: isBoolean,\n  represent: {\n    lowercase: function (object) { return object ? 'true' : 'false'; },\n    uppercase: function (object) { return object ? 'TRUE' : 'FALSE'; },\n    camelcase: function (object) { return object ? 'True' : 'False'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nvar YAML_FLOAT_PATTERN = new RegExp(\n  '^(?:[-+]?(?:[0-9][0-9_]*)\\\\.[0-9_]*(?:[eE][-+][0-9]+)?' +\n  '|\\\\.[0-9_]+(?:[eE][-+][0-9]+)?' +\n  '|[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+\\\\.[0-9_]*' +\n  '|[-+]?\\\\.(?:inf|Inf|INF)' +\n  '|\\\\.(?:nan|NaN|NAN))$');\n\nfunction resolveYamlFloat(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var value, sign, base, digits;\n\n  if (!YAML_FLOAT_PATTERN.test(data)) {\n    return false;\n  }\n  return true;\n}\n\nfunction constructYamlFloat(data) {\n  var value, sign, base, digits;\n\n  value  = data.replace(/_/g, '').toLowerCase();\n  sign   = '-' === value[0] ? -1 : 1;\n  digits = [];\n\n  if (0 <= '+-'.indexOf(value[0])) {\n    value = value.slice(1);\n  }\n\n  if ('.inf' === value) {\n    return (1 === sign) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n  } else if ('.nan' === value) {\n    return NaN;\n\n  } else if (0 <= value.indexOf(':')) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseFloat(v, 10));\n    });\n\n    value = 0.0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += d * base;\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n  return sign * parseFloat(value, 10);\n}\n\nfunction representYamlFloat(object, style) {\n  if (isNaN(object)) {\n    switch (style) {\n    case 'lowercase':\n      return '.nan';\n    case 'uppercase':\n      return '.NAN';\n    case 'camelcase':\n      return '.NaN';\n    }\n  } else if (Number.POSITIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '.inf';\n    case 'uppercase':\n      return '.INF';\n    case 'camelcase':\n      return '.Inf';\n    }\n  } else if (Number.NEGATIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '-.inf';\n    case 'uppercase':\n      return '-.INF';\n    case 'camelcase':\n      return '-.Inf';\n    }\n  } else if (common.isNegativeZero(object)) {\n    return '-0.0';\n  }\n  return object.toString(10);\n}\n\nfunction isFloat(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 !== object % 1 || common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:float', {\n  kind: 'scalar',\n  resolve: resolveYamlFloat,\n  construct: constructYamlFloat,\n  predicate: isFloat,\n  represent: representYamlFloat,\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nfunction isHexCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||\n         ((0x41/* A */ <= c) && (c <= 0x46/* F */)) ||\n         ((0x61/* a */ <= c) && (c <= 0x66/* f */));\n}\n\nfunction isOctCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x37/* 7 */));\n}\n\nfunction isDecCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */));\n}\n\nfunction resolveYamlInteger(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length,\n      index = 0,\n      hasDigits = false,\n      ch;\n\n  if (!max) { return false; }\n\n  ch = data[index];\n\n  // sign\n  if (ch === '-' || ch === '+') {\n    ch = data[++index];\n  }\n\n  if (ch === '0') {\n    // 0\n    if (index + 1 === max) { return true; }\n    ch = data[++index];\n\n    // base 2, base 8, base 16\n\n    if (ch === 'b') {\n      // base 2\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (ch !== '0' && ch !== '1') {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n\n    if (ch === 'x') {\n      // base 16\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (!isHexCode(data.charCodeAt(index))) {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n    // base 8\n    for (; index < max; index++) {\n      ch = data[index];\n      if (ch === '_') { continue; }\n      if (!isOctCode(data.charCodeAt(index))) {\n        return false;\n      }\n      hasDigits = true;\n    }\n    return hasDigits;\n  }\n\n  // base 10 (except 0) or base 60\n\n  for (; index < max; index++) {\n    ch = data[index];\n    if (ch === '_') { continue; }\n    if (ch === ':') { break; }\n    if (!isDecCode(data.charCodeAt(index))) {\n      return false;\n    }\n    hasDigits = true;\n  }\n\n  if (!hasDigits) { return false; }\n\n  // if !base60 - done;\n  if (ch !== ':') { return true; }\n\n  // base60 almost not used, no needs to optimize\n  return /^(:[0-5]?[0-9])+$/.test(data.slice(index));\n}\n\nfunction constructYamlInteger(data) {\n  var value = data, sign = 1, ch, base, digits = [];\n\n  if (value.indexOf('_') !== -1) {\n    value = value.replace(/_/g, '');\n  }\n\n  ch = value[0];\n\n  if (ch === '-' || ch === '+') {\n    if (ch === '-') { sign = -1; }\n    value = value.slice(1);\n    ch = value[0];\n  }\n\n  if ('0' === value) {\n    return 0;\n  }\n\n  if (ch === '0') {\n    if (value[1] === 'b') {\n      return sign * parseInt(value.slice(2), 2);\n    }\n    if (value[1] === 'x') {\n      return sign * parseInt(value, 16);\n    }\n    return sign * parseInt(value, 8);\n\n  }\n\n  if (value.indexOf(':') !== -1) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseInt(v, 10));\n    });\n\n    value = 0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += (d * base);\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n\n  return sign * parseInt(value, 10);\n}\n\nfunction isInteger(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 === object % 1 && !common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:int', {\n  kind: 'scalar',\n  resolve: resolveYamlInteger,\n  construct: constructYamlInteger,\n  predicate: isInteger,\n  represent: {\n    binary:      function (object) { return '0b' + object.toString(2); },\n    octal:       function (object) { return '0'  + object.toString(8); },\n    decimal:     function (object) { return        object.toString(10); },\n    hexadecimal: function (object) { return '0x' + object.toString(16).toUpperCase(); }\n  },\n  defaultStyle: 'decimal',\n  styleAliases: {\n    binary:      [ 2,  'bin' ],\n    octal:       [ 8,  'oct' ],\n    decimal:     [ 10, 'dec' ],\n    hexadecimal: [ 16, 'hex' ]\n  }\n});\n","'use strict';\n\nvar esprima;\n\n// Browserified version does not have esprima\n//\n// 1. For node.js just require module as deps\n// 2. For browser try to require mudule via external AMD system.\n//    If not found - try to fallback to window.esprima. If not\n//    found too - then fail to parse.\n//\ntry {\n  esprima = require('esprima');\n} catch (_) {\n  /*global window */\n  if (typeof window !== 'undefined') { esprima = window.esprima; }\n}\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptFunction(data) {\n  if (null === data) {\n    return false;\n  }\n\n  try {\n    var source = '(' + data + ')',\n        ast    = esprima.parse(source, { range: true }),\n        params = [],\n        body;\n\n    if ('Program'             !== ast.type         ||\n        1                     !== ast.body.length  ||\n        'ExpressionStatement' !== ast.body[0].type ||\n        'FunctionExpression'  !== ast.body[0].expression.type) {\n      return false;\n    }\n\n    return true;\n  } catch (err) {\n    return false;\n  }\n}\n\nfunction constructJavascriptFunction(data) {\n  /*jslint evil:true*/\n\n  var source = '(' + data + ')',\n      ast    = esprima.parse(source, { range: true }),\n      params = [],\n      body;\n\n  if ('Program'             !== ast.type         ||\n      1                     !== ast.body.length  ||\n      'ExpressionStatement' !== ast.body[0].type ||\n      'FunctionExpression'  !== ast.body[0].expression.type) {\n    throw new Error('Failed to resolve function');\n  }\n\n  ast.body[0].expression.params.forEach(function (param) {\n    params.push(param.name);\n  });\n\n  body = ast.body[0].expression.body.range;\n\n  // Esprima's ranges include the first '{' and the last '}' characters on\n  // function expressions. So cut them out.\n  /*eslint-disable no-new-func*/\n  return new Function(params, source.slice(body[0] + 1, body[1] - 1));\n}\n\nfunction representJavascriptFunction(object /*, style*/) {\n  return object.toString();\n}\n\nfunction isFunction(object) {\n  return '[object Function]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/function', {\n  kind: 'scalar',\n  resolve: resolveJavascriptFunction,\n  construct: constructJavascriptFunction,\n  predicate: isFunction,\n  represent: representJavascriptFunction\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptRegExp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  if (0 === data.length) {\n    return false;\n  }\n\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // if regexp starts with '/' it can have modifiers and must be properly closed\n  // `/foo/gim` - modifiers tail can be maximum 3 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n\n    if (modifiers.length > 3) { return false; }\n    // if expression starts with /, is should be properly terminated\n    if (regexp[regexp.length - modifiers.length - 1] !== '/') { return false; }\n\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  try {\n    var dummy = new RegExp(regexp, modifiers);\n    return true;\n  } catch (error) {\n    return false;\n  }\n}\n\nfunction constructJavascriptRegExp(data) {\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // `/foo/gim` - tail can be maximum 4 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  return new RegExp(regexp, modifiers);\n}\n\nfunction representJavascriptRegExp(object /*, style*/) {\n  var result = '/' + object.source + '/';\n\n  if (object.global) {\n    result += 'g';\n  }\n\n  if (object.multiline) {\n    result += 'm';\n  }\n\n  if (object.ignoreCase) {\n    result += 'i';\n  }\n\n  return result;\n}\n\nfunction isRegExp(object) {\n  return '[object RegExp]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/regexp', {\n  kind: 'scalar',\n  resolve: resolveJavascriptRegExp,\n  construct: constructJavascriptRegExp,\n  predicate: isRegExp,\n  represent: representJavascriptRegExp\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptUndefined() {\n  return true;\n}\n\nfunction constructJavascriptUndefined() {\n  /*eslint-disable no-undefined*/\n  return undefined;\n}\n\nfunction representJavascriptUndefined() {\n  return '';\n}\n\nfunction isUndefined(object) {\n  return 'undefined' === typeof object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/undefined', {\n  kind: 'scalar',\n  resolve: resolveJavascriptUndefined,\n  construct: constructJavascriptUndefined,\n  predicate: isUndefined,\n  represent: representJavascriptUndefined\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:map', {\n  kind: 'mapping',\n  construct: function (data) { return null !== data ? data : {}; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlMerge(data) {\n  return '<<' === data || null === data;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:merge', {\n  kind: 'scalar',\n  resolve: resolveYamlMerge\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlNull(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var max = data.length;\n\n  return (max === 1 && data === '~') ||\n         (max === 4 && (data === 'null' || data === 'Null' || data === 'NULL'));\n}\n\nfunction constructYamlNull() {\n  return null;\n}\n\nfunction isNull(object) {\n  return null === object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:null', {\n  kind: 'scalar',\n  resolve: resolveYamlNull,\n  construct: constructYamlNull,\n  predicate: isNull,\n  represent: {\n    canonical: function () { return '~';    },\n    lowercase: function () { return 'null'; },\n    uppercase: function () { return 'NULL'; },\n    camelcase: function () { return 'Null'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\nvar _toString       = Object.prototype.toString;\n\nfunction resolveYamlOmap(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var objectKeys = [], index, length, pair, pairKey, pairHasKey,\n      object = data;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n    pairHasKey = false;\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    for (pairKey in pair) {\n      if (_hasOwnProperty.call(pair, pairKey)) {\n        if (!pairHasKey) {\n          pairHasKey = true;\n        } else {\n          return false;\n        }\n      }\n    }\n\n    if (!pairHasKey) {\n      return false;\n    }\n\n    if (-1 === objectKeys.indexOf(pairKey)) {\n      objectKeys.push(pairKey);\n    } else {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlOmap(data) {\n  return null !== data ? data : [];\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:omap', {\n  kind: 'sequence',\n  resolve: resolveYamlOmap,\n  construct: constructYamlOmap\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _toString = Object.prototype.toString;\n\nfunction resolveYamlPairs(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    keys = Object.keys(pair);\n\n    if (1 !== keys.length) {\n      return false;\n    }\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return true;\n}\n\nfunction constructYamlPairs(data) {\n  if (null === data) {\n    return [];\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    keys = Object.keys(pair);\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return result;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:pairs', {\n  kind: 'sequence',\n  resolve: resolveYamlPairs,\n  construct: constructYamlPairs\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:seq', {\n  kind: 'sequence',\n  construct: function (data) { return null !== data ? data : []; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var key, object = data;\n\n  for (key in object) {\n    if (_hasOwnProperty.call(object, key)) {\n      if (null !== object[key]) {\n        return false;\n      }\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlSet(data) {\n  return null !== data ? data : {};\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:set', {\n  kind: 'mapping',\n  resolve: resolveYamlSet,\n  construct: constructYamlSet\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:str', {\n  kind: 'scalar',\n  construct: function (data) { return null !== data ? data : ''; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar YAML_TIMESTAMP_REGEXP = new RegExp(\n  '^([0-9][0-9][0-9][0-9])'          + // [1] year\n  '-([0-9][0-9]?)'                   + // [2] month\n  '-([0-9][0-9]?)'                   + // [3] day\n  '(?:(?:[Tt]|[ \\\\t]+)'              + // ...\n  '([0-9][0-9]?)'                    + // [4] hour\n  ':([0-9][0-9])'                    + // [5] minute\n  ':([0-9][0-9])'                    + // [6] second\n  '(?:\\\\.([0-9]*))?'                 + // [7] fraction\n  '(?:[ \\\\t]*(Z|([-+])([0-9][0-9]?)' + // [8] tz [9] tz_sign [10] tz_hour\n  '(?::([0-9][0-9]))?))?)?$');         // [11] tz_minute\n\nfunction resolveYamlTimestamp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var match, year, month, day, hour, minute, second, fraction = 0,\n      delta = null, tz_hour, tz_minute, date;\n\n  match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n  if (null === match) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction constructYamlTimestamp(data) {\n  var match, year, month, day, hour, minute, second, fraction = 0,\n      delta = null, tz_hour, tz_minute, date;\n\n  match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n  if (null === match) {\n    throw new Error('Date resolve error');\n  }\n\n  // match: [1] year [2] month [3] day\n\n  year = +(match[1]);\n  month = +(match[2]) - 1; // JS month starts with 0\n  day = +(match[3]);\n\n  if (!match[4]) { // no hour\n    return new Date(Date.UTC(year, month, day));\n  }\n\n  // match: [4] hour [5] minute [6] second [7] fraction\n\n  hour = +(match[4]);\n  minute = +(match[5]);\n  second = +(match[6]);\n\n  if (match[7]) {\n    fraction = match[7].slice(0, 3);\n    while (fraction.length < 3) { // milli-seconds\n      fraction += '0';\n    }\n    fraction = +fraction;\n  }\n\n  // match: [8] tz [9] tz_sign [10] tz_hour [11] tz_minute\n\n  if (match[9]) {\n    tz_hour = +(match[10]);\n    tz_minute = +(match[11] || 0);\n    delta = (tz_hour * 60 + tz_minute) * 60000; // delta in mili-seconds\n    if ('-' === match[9]) {\n      delta = -delta;\n    }\n  }\n\n  date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n  if (delta) {\n    date.setTime(date.getTime() - delta);\n  }\n\n  return date;\n}\n\nfunction representYamlTimestamp(object /*, style*/) {\n  return object.toISOString();\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:timestamp', {\n  kind: 'scalar',\n  resolve: resolveYamlTimestamp,\n  construct: constructYamlTimestamp,\n  instanceOf: Date,\n  represent: representYamlTimestamp\n});\n","/*\n  Copyright (C) 2013 Ariya Hidayat <ariya.hidayat@gmail.com>\n  Copyright (C) 2013 Thaddee Tyl <thaddee.tyl@gmail.com>\n  Copyright (C) 2013 Mathias Bynens <mathias@qiwi.be>\n  Copyright (C) 2012 Ariya Hidayat <ariya.hidayat@gmail.com>\n  Copyright (C) 2012 Mathias Bynens <mathias@qiwi.be>\n  Copyright (C) 2012 Joost-Wim Boekesteijn <joost-wim@boekesteijn.nl>\n  Copyright (C) 2012 Kris Kowal <kris.kowal@cixar.com>\n  Copyright (C) 2012 Yusuke Suzuki <utatane.tea@gmail.com>\n  Copyright (C) 2012 Arpad Borsos <arpad.borsos@googlemail.com>\n  Copyright (C) 2011 Ariya Hidayat <ariya.hidayat@gmail.com>\n\n  Redistribution and use in source and binary forms, with or without\n  modification, are permitted provided that the following conditions are met:\n\n    * Redistributions of source code must retain the above copyright\n      notice, this list of conditions and the following disclaimer.\n    * Redistributions in binary form must reproduce the above copyright\n      notice, this list of conditions and the following disclaimer in the\n      documentation and/or other materials provided with the distribution.\n\n  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n  ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY\n  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND\n  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF\n  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n(function (root, factory) {\n    'use strict';\n\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js,\n    // Rhino, and plain browser loading.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define(['exports'], factory);\n    } else if (typeof exports !== 'undefined') {\n        factory(exports);\n    } else {\n        factory((root.esprima = {}));\n    }\n}(this, function (exports) {\n    'use strict';\n\n    var Token,\n        TokenName,\n        FnExprTokens,\n        Syntax,\n        PlaceHolders,\n        Messages,\n        Regex,\n        source,\n        strict,\n        sourceType,\n        index,\n        lineNumber,\n        lineStart,\n        hasLineTerminator,\n        lastIndex,\n        lastLineNumber,\n        lastLineStart,\n        startIndex,\n        startLineNumber,\n        startLineStart,\n        scanning,\n        length,\n        lookahead,\n        state,\n        extra,\n        isBindingElement,\n        isAssignmentTarget,\n        firstCoverInitializedNameError;\n\n    Token = {\n        BooleanLiteral: 1,\n        EOF: 2,\n        Identifier: 3,\n        Keyword: 4,\n        NullLiteral: 5,\n        NumericLiteral: 6,\n        Punctuator: 7,\n        StringLiteral: 8,\n        RegularExpression: 9,\n        Template: 10\n    };\n\n    TokenName = {};\n    TokenName[Token.BooleanLiteral] = 'Boolean';\n    TokenName[Token.EOF] = '<end>';\n    TokenName[Token.Identifier] = 'Identifier';\n    TokenName[Token.Keyword] = 'Keyword';\n    TokenName[Token.NullLiteral] = 'Null';\n    TokenName[Token.NumericLiteral] = 'Numeric';\n    TokenName[Token.Punctuator] = 'Punctuator';\n    TokenName[Token.StringLiteral] = 'String';\n    TokenName[Token.RegularExpression] = 'RegularExpression';\n    TokenName[Token.Template] = 'Template';\n\n    // A function following one of those tokens is an expression.\n    FnExprTokens = ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new',\n                    'return', 'case', 'delete', 'throw', 'void',\n                    // assignment operators\n                    '=', '+=', '-=', '*=', '/=', '%=', '<<=', '>>=', '>>>=',\n                    '&=', '|=', '^=', ',',\n                    // binary/unary operators\n                    '+', '-', '*', '/', '%', '++', '--', '<<', '>>', '>>>', '&',\n                    '|', '^', '!', '~', '&&', '||', '?', ':', '===', '==', '>=',\n                    '<=', '<', '>', '!=', '!=='];\n\n    Syntax = {\n        AssignmentExpression: 'AssignmentExpression',\n        AssignmentPattern: 'AssignmentPattern',\n        ArrayExpression: 'ArrayExpression',\n        ArrayPattern: 'ArrayPattern',\n        ArrowFunctionExpression: 'ArrowFunctionExpression',\n        BlockStatement: 'BlockStatement',\n        BinaryExpression: 'BinaryExpression',\n        BreakStatement: 'BreakStatement',\n        CallExpression: 'CallExpression',\n        CatchClause: 'CatchClause',\n        ClassBody: 'ClassBody',\n        ClassDeclaration: 'ClassDeclaration',\n        ClassExpression: 'ClassExpression',\n        ConditionalExpression: 'ConditionalExpression',\n        ContinueStatement: 'ContinueStatement',\n        DoWhileStatement: 'DoWhileStatement',\n        DebuggerStatement: 'DebuggerStatement',\n        EmptyStatement: 'EmptyStatement',\n        ExportAllDeclaration: 'ExportAllDeclaration',\n        ExportDefaultDeclaration: 'ExportDefaultDeclaration',\n        ExportNamedDeclaration: 'ExportNamedDeclaration',\n        ExportSpecifier: 'ExportSpecifier',\n        ExpressionStatement: 'ExpressionStatement',\n        ForStatement: 'ForStatement',\n        ForInStatement: 'ForInStatement',\n        FunctionDeclaration: 'FunctionDeclaration',\n        FunctionExpression: 'FunctionExpression',\n        Identifier: 'Identifier',\n        IfStatement: 'IfStatement',\n        ImportDeclaration: 'ImportDeclaration',\n        ImportDefaultSpecifier: 'ImportDefaultSpecifier',\n        ImportNamespaceSpecifier: 'ImportNamespaceSpecifier',\n        ImportSpecifier: 'ImportSpecifier',\n        Literal: 'Literal',\n        LabeledStatement: 'LabeledStatement',\n        LogicalExpression: 'LogicalExpression',\n        MemberExpression: 'MemberExpression',\n        MethodDefinition: 'MethodDefinition',\n        NewExpression: 'NewExpression',\n        ObjectExpression: 'ObjectExpression',\n        ObjectPattern: 'ObjectPattern',\n        Program: 'Program',\n        Property: 'Property',\n        RestElement: 'RestElement',\n        ReturnStatement: 'ReturnStatement',\n        SequenceExpression: 'SequenceExpression',\n        SpreadElement: 'SpreadElement',\n        Super: 'Super',\n        SwitchCase: 'SwitchCase',\n        SwitchStatement: 'SwitchStatement',\n        TaggedTemplateExpression: 'TaggedTemplateExpression',\n        TemplateElement: 'TemplateElement',\n        TemplateLiteral: 'TemplateLiteral',\n        ThisExpression: 'ThisExpression',\n        ThrowStatement: 'ThrowStatement',\n        TryStatement: 'TryStatement',\n        UnaryExpression: 'UnaryExpression',\n        UpdateExpression: 'UpdateExpression',\n        VariableDeclaration: 'VariableDeclaration',\n        VariableDeclarator: 'VariableDeclarator',\n        WhileStatement: 'WhileStatement',\n        WithStatement: 'WithStatement'\n    };\n\n    PlaceHolders = {\n        ArrowParameterPlaceHolder: 'ArrowParameterPlaceHolder'\n    };\n\n    // Error messages should be identical to V8.\n    Messages = {\n        UnexpectedToken: 'Unexpected token %0',\n        UnexpectedNumber: 'Unexpected number',\n        UnexpectedString: 'Unexpected string',\n        UnexpectedIdentifier: 'Unexpected identifier',\n        UnexpectedReserved: 'Unexpected reserved word',\n        UnexpectedTemplate: 'Unexpected quasi %0',\n        UnexpectedEOS: 'Unexpected end of input',\n        NewlineAfterThrow: 'Illegal newline after throw',\n        InvalidRegExp: 'Invalid regular expression',\n        UnterminatedRegExp: 'Invalid regular expression: missing /',\n        InvalidLHSInAssignment: 'Invalid left-hand side in assignment',\n        InvalidLHSInForIn: 'Invalid left-hand side in for-in',\n        MultipleDefaultsInSwitch: 'More than one default clause in switch statement',\n        NoCatchOrFinally: 'Missing catch or finally after try',\n        UnknownLabel: 'Undefined label \\'%0\\'',\n        Redeclaration: '%0 \\'%1\\' has already been declared',\n        IllegalContinue: 'Illegal continue statement',\n        IllegalBreak: 'Illegal break statement',\n        IllegalReturn: 'Illegal return statement',\n        StrictModeWith: 'Strict mode code may not include a with statement',\n        StrictCatchVariable: 'Catch variable may not be eval or arguments in strict mode',\n        StrictVarName: 'Variable name may not be eval or arguments in strict mode',\n        StrictParamName: 'Parameter name eval or arguments is not allowed in strict mode',\n        StrictParamDupe: 'Strict mode function may not have duplicate parameter names',\n        StrictFunctionName: 'Function name may not be eval or arguments in strict mode',\n        StrictOctalLiteral: 'Octal literals are not allowed in strict mode.',\n        StrictDelete: 'Delete of an unqualified identifier in strict mode.',\n        StrictLHSAssignment: 'Assignment to eval or arguments is not allowed in strict mode',\n        StrictLHSPostfix: 'Postfix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictLHSPrefix: 'Prefix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictReservedWord: 'Use of future reserved word in strict mode',\n        TemplateOctalLiteral: 'Octal literals are not allowed in template strings.',\n        ParameterAfterRestParameter: 'Rest parameter must be last formal parameter',\n        DefaultRestParameter: 'Unexpected token =',\n        ObjectPatternAsRestParameter: 'Unexpected token {',\n        DuplicateProtoProperty: 'Duplicate __proto__ fields are not allowed in object literals',\n        ConstructorSpecialMethod: 'Class constructor may not be an accessor',\n        DuplicateConstructor: 'A class may only have one constructor',\n        StaticPrototype: 'Classes may not have static property named prototype',\n        MissingFromClause: 'Unexpected token',\n        NoAsAfterImportNamespace: 'Unexpected token',\n        InvalidModuleSpecifier: 'Unexpected token',\n        IllegalImportDeclaration: 'Unexpected token',\n        IllegalExportDeclaration: 'Unexpected token'\n    };\n\n    // See also tools/generate-unicode-regex.py.\n    Regex = {\n        NonAsciiIdentifierStart: new RegExp('[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0370-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u07F4\\u07F5\\u07FA\\u0800-\\u0815\\u081A\\u0824\\u0828\\u0840-\\u0858\\u08A0-\\u08B2\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0971-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58\\u0C59\\u0C60\\u0C61\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D60\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E46\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17D7\\u17DC\\u1820-\\u1877\\u1880-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19C1-\\u19C7\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1AA7\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C7D\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u1D00-\\u1DBF\\u1E00-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u2071\\u207F\\u2090-\\u209C\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CEE\\u2CF2\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2E2F\\u3005-\\u3007\\u3021-\\u3029\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA61F\\uA62A\\uA62B\\uA640-\\uA66E\\uA67F-\\uA69D\\uA6A0-\\uA6EF\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9CF\\uA9E0-\\uA9E4\\uA9E6-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEA\\uAAF2-\\uAAF4\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF21-\\uFF3A\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]'),\n        NonAsciiIdentifierPart: new RegExp('[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0300-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u0483-\\u0487\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u0591-\\u05BD\\u05BF\\u05C1\\u05C2\\u05C4\\u05C5\\u05C7\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0610-\\u061A\\u0620-\\u0669\\u066E-\\u06D3\\u06D5-\\u06DC\\u06DF-\\u06E8\\u06EA-\\u06FC\\u06FF\\u0710-\\u074A\\u074D-\\u07B1\\u07C0-\\u07F5\\u07FA\\u0800-\\u082D\\u0840-\\u085B\\u08A0-\\u08B2\\u08E4-\\u0963\\u0966-\\u096F\\u0971-\\u0983\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BC-\\u09C4\\u09C7\\u09C8\\u09CB-\\u09CE\\u09D7\\u09DC\\u09DD\\u09DF-\\u09E3\\u09E6-\\u09F1\\u0A01-\\u0A03\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A3C\\u0A3E-\\u0A42\\u0A47\\u0A48\\u0A4B-\\u0A4D\\u0A51\\u0A59-\\u0A5C\\u0A5E\\u0A66-\\u0A75\\u0A81-\\u0A83\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABC-\\u0AC5\\u0AC7-\\u0AC9\\u0ACB-\\u0ACD\\u0AD0\\u0AE0-\\u0AE3\\u0AE6-\\u0AEF\\u0B01-\\u0B03\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3C-\\u0B44\\u0B47\\u0B48\\u0B4B-\\u0B4D\\u0B56\\u0B57\\u0B5C\\u0B5D\\u0B5F-\\u0B63\\u0B66-\\u0B6F\\u0B71\\u0B82\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BBE-\\u0BC2\\u0BC6-\\u0BC8\\u0BCA-\\u0BCD\\u0BD0\\u0BD7\\u0BE6-\\u0BEF\\u0C00-\\u0C03\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D-\\u0C44\\u0C46-\\u0C48\\u0C4A-\\u0C4D\\u0C55\\u0C56\\u0C58\\u0C59\\u0C60-\\u0C63\\u0C66-\\u0C6F\\u0C81-\\u0C83\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBC-\\u0CC4\\u0CC6-\\u0CC8\\u0CCA-\\u0CCD\\u0CD5\\u0CD6\\u0CDE\\u0CE0-\\u0CE3\\u0CE6-\\u0CEF\\u0CF1\\u0CF2\\u0D01-\\u0D03\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D-\\u0D44\\u0D46-\\u0D48\\u0D4A-\\u0D4E\\u0D57\\u0D60-\\u0D63\\u0D66-\\u0D6F\\u0D7A-\\u0D7F\\u0D82\\u0D83\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0DCA\\u0DCF-\\u0DD4\\u0DD6\\u0DD8-\\u0DDF\\u0DE6-\\u0DEF\\u0DF2\\u0DF3\\u0E01-\\u0E3A\\u0E40-\\u0E4E\\u0E50-\\u0E59\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB9\\u0EBB-\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EC8-\\u0ECD\\u0ED0-\\u0ED9\\u0EDC-\\u0EDF\\u0F00\\u0F18\\u0F19\\u0F20-\\u0F29\\u0F35\\u0F37\\u0F39\\u0F3E-\\u0F47\\u0F49-\\u0F6C\\u0F71-\\u0F84\\u0F86-\\u0F97\\u0F99-\\u0FBC\\u0FC6\\u1000-\\u1049\\u1050-\\u109D\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u135D-\\u135F\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1714\\u1720-\\u1734\\u1740-\\u1753\\u1760-\\u176C\\u176E-\\u1770\\u1772\\u1773\\u1780-\\u17D3\\u17D7\\u17DC\\u17DD\\u17E0-\\u17E9\\u180B-\\u180D\\u1810-\\u1819\\u1820-\\u1877\\u1880-\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1920-\\u192B\\u1930-\\u193B\\u1946-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u19D0-\\u19D9\\u1A00-\\u1A1B\\u1A20-\\u1A5E\\u1A60-\\u1A7C\\u1A7F-\\u1A89\\u1A90-\\u1A99\\u1AA7\\u1AB0-\\u1ABD\\u1B00-\\u1B4B\\u1B50-\\u1B59\\u1B6B-\\u1B73\\u1B80-\\u1BF3\\u1C00-\\u1C37\\u1C40-\\u1C49\\u1C4D-\\u1C7D\\u1CD0-\\u1CD2\\u1CD4-\\u1CF6\\u1CF8\\u1CF9\\u1D00-\\u1DF5\\u1DFC-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u200C\\u200D\\u203F\\u2040\\u2054\\u2071\\u207F\\u2090-\\u209C\\u20D0-\\u20DC\\u20E1\\u20E5-\\u20F0\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D7F-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2DE0-\\u2DFF\\u2E2F\\u3005-\\u3007\\u3021-\\u302F\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u3099\\u309A\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA62B\\uA640-\\uA66F\\uA674-\\uA67D\\uA67F-\\uA69D\\uA69F-\\uA6F1\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA827\\uA840-\\uA873\\uA880-\\uA8C4\\uA8D0-\\uA8D9\\uA8E0-\\uA8F7\\uA8FB\\uA900-\\uA92D\\uA930-\\uA953\\uA960-\\uA97C\\uA980-\\uA9C0\\uA9CF-\\uA9D9\\uA9E0-\\uA9FE\\uAA00-\\uAA36\\uAA40-\\uAA4D\\uAA50-\\uAA59\\uAA60-\\uAA76\\uAA7A-\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEF\\uAAF2-\\uAAF6\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABEA\\uABEC\\uABED\\uABF0-\\uABF9\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE00-\\uFE0F\\uFE20-\\uFE2D\\uFE33\\uFE34\\uFE4D-\\uFE4F\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF10-\\uFF19\\uFF21-\\uFF3A\\uFF3F\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]')\n    };\n\n    // Ensure the condition is true, otherwise throw an error.\n    // This is only to have a better contract semantic, i.e. another safety net\n    // to catch a logic error. The condition shall be fulfilled in normal case.\n    // Do NOT use this to enforce a certain condition on any user input.\n\n    function assert(condition, message) {\n        /* istanbul ignore if */\n        if (!condition) {\n            throw new Error('ASSERT: ' + message);\n        }\n    }\n\n    function isDecimalDigit(ch) {\n        return (ch >= 0x30 && ch <= 0x39);   // 0..9\n    }\n\n    function isHexDigit(ch) {\n        return '0123456789abcdefABCDEF'.indexOf(ch) >= 0;\n    }\n\n    function isOctalDigit(ch) {\n        return '01234567'.indexOf(ch) >= 0;\n    }\n\n    function octalToDecimal(ch) {\n        // \\0 is not octal escape sequence\n        var octal = (ch !== '0'), code = '01234567'.indexOf(ch);\n\n        if (index < length && isOctalDigit(source[index])) {\n            octal = true;\n            code = code * 8 + '01234567'.indexOf(source[index++]);\n\n            // 3 digits are only allowed when string starts\n            // with 0, 1, 2, 3\n            if ('0123'.indexOf(ch) >= 0 &&\n                    index < length &&\n                    isOctalDigit(source[index])) {\n                code = code * 8 + '01234567'.indexOf(source[index++]);\n            }\n        }\n\n        return {\n            code: code,\n            octal: octal\n        };\n    }\n\n    // 7.2 White Space\n\n    function isWhiteSpace(ch) {\n        return (ch === 0x20) || (ch === 0x09) || (ch === 0x0B) || (ch === 0x0C) || (ch === 0xA0) ||\n            (ch >= 0x1680 && [0x1680, 0x180E, 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, 0x202F, 0x205F, 0x3000, 0xFEFF].indexOf(ch) >= 0);\n    }\n\n    // 7.3 Line Terminators\n\n    function isLineTerminator(ch) {\n        return (ch === 0x0A) || (ch === 0x0D) || (ch === 0x2028) || (ch === 0x2029);\n    }\n\n    // 7.6 Identifier Names and Identifiers\n\n    function isIdentifierStart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierStart.test(String.fromCharCode(ch)));\n    }\n\n    function isIdentifierPart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch >= 0x30 && ch <= 0x39) ||         // 0..9\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierPart.test(String.fromCharCode(ch)));\n    }\n\n    // 7.6.1.2 Future Reserved Words\n\n    function isFutureReservedWord(id) {\n        switch (id) {\n        case 'enum':\n        case 'export':\n        case 'import':\n        case 'super':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    // 11.6.2.2 Future Reserved Words\n\n    function isStrictModeReservedWord(id) {\n        switch (id) {\n        case 'implements':\n        case 'interface':\n        case 'package':\n        case 'private':\n        case 'protected':\n        case 'public':\n        case 'static':\n        case 'yield':\n        case 'let':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    function isRestrictedWord(id) {\n        return id === 'eval' || id === 'arguments';\n    }\n\n    // 7.6.1.1 Keywords\n\n    function isKeyword(id) {\n\n        // 'const' is specialized as Keyword in V8.\n        // 'yield' and 'let' are for compatibility with SpiderMonkey and ES.next.\n        // Some others are from future reserved words.\n\n        switch (id.length) {\n        case 2:\n            return (id === 'if') || (id === 'in') || (id === 'do');\n        case 3:\n            return (id === 'var') || (id === 'for') || (id === 'new') ||\n                (id === 'try') || (id === 'let');\n        case 4:\n            return (id === 'this') || (id === 'else') || (id === 'case') ||\n                (id === 'void') || (id === 'with') || (id === 'enum');\n        case 5:\n            return (id === 'while') || (id === 'break') || (id === 'catch') ||\n                (id === 'throw') || (id === 'const') || (id === 'yield') ||\n                (id === 'class') || (id === 'super');\n        case 6:\n            return (id === 'return') || (id === 'typeof') || (id === 'delete') ||\n                (id === 'switch') || (id === 'export') || (id === 'import');\n        case 7:\n            return (id === 'default') || (id === 'finally') || (id === 'extends');\n        case 8:\n            return (id === 'function') || (id === 'continue') || (id === 'debugger');\n        case 10:\n            return (id === 'instanceof');\n        default:\n            return false;\n        }\n    }\n\n    // 7.4 Comments\n\n    function addComment(type, value, start, end, loc) {\n        var comment;\n\n        assert(typeof start === 'number', 'Comment must have valid position');\n\n        state.lastCommentStart = start;\n\n        comment = {\n            type: type,\n            value: value\n        };\n        if (extra.range) {\n            comment.range = [start, end];\n        }\n        if (extra.loc) {\n            comment.loc = loc;\n        }\n        extra.comments.push(comment);\n        if (extra.attachComment) {\n            extra.leadingComments.push(comment);\n            extra.trailingComments.push(comment);\n        }\n    }\n\n    function skipSingleLineComment(offset) {\n        var start, loc, ch, comment;\n\n        start = index - offset;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart - offset\n            }\n        };\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            ++index;\n            if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                if (extra.comments) {\n                    comment = source.slice(start + offset, index - 1);\n                    loc.end = {\n                        line: lineNumber,\n                        column: index - lineStart - 1\n                    };\n                    addComment('Line', comment, start, index - 1, loc);\n                }\n                if (ch === 13 && source.charCodeAt(index) === 10) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                return;\n            }\n        }\n\n        if (extra.comments) {\n            comment = source.slice(start + offset, index);\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            addComment('Line', comment, start, index, loc);\n        }\n    }\n\n    function skipMultiLineComment() {\n        var start, loc, ch, comment;\n\n        if (extra.comments) {\n            start = index - 2;\n            loc = {\n                start: {\n                    line: lineNumber,\n                    column: index - lineStart - 2\n                }\n            };\n        }\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (isLineTerminator(ch)) {\n                if (ch === 0x0D && source.charCodeAt(index + 1) === 0x0A) {\n                    ++index;\n                }\n                hasLineTerminator = true;\n                ++lineNumber;\n                ++index;\n                lineStart = index;\n            } else if (ch === 0x2A) {\n                // Block comment ends with '*/'.\n                if (source.charCodeAt(index + 1) === 0x2F) {\n                    ++index;\n                    ++index;\n                    if (extra.comments) {\n                        comment = source.slice(start + 2, index - 2);\n                        loc.end = {\n                            line: lineNumber,\n                            column: index - lineStart\n                        };\n                        addComment('Block', comment, start, index, loc);\n                    }\n                    return;\n                }\n                ++index;\n            } else {\n                ++index;\n            }\n        }\n\n        // Ran off the end of the file - the whole thing is a comment\n        if (extra.comments) {\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            comment = source.slice(start + 2, index);\n            addComment('Block', comment, start, index, loc);\n        }\n        tolerateUnexpectedToken();\n    }\n\n    function skipComment() {\n        var ch, start;\n        hasLineTerminator = false;\n\n        start = (index === 0);\n        while (index < length) {\n            ch = source.charCodeAt(index);\n\n            if (isWhiteSpace(ch)) {\n                ++index;\n            } else if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                ++index;\n                if (ch === 0x0D && source.charCodeAt(index) === 0x0A) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                start = true;\n            } else if (ch === 0x2F) { // U+002F is '/'\n                ch = source.charCodeAt(index + 1);\n                if (ch === 0x2F) {\n                    ++index;\n                    ++index;\n                    skipSingleLineComment(2);\n                    start = true;\n                } else if (ch === 0x2A) {  // U+002A is '*'\n                    ++index;\n                    ++index;\n                    skipMultiLineComment();\n                } else {\n                    break;\n                }\n            } else if (start && ch === 0x2D) { // U+002D is '-'\n                // U+003E is '>'\n                if ((source.charCodeAt(index + 1) === 0x2D) && (source.charCodeAt(index + 2) === 0x3E)) {\n                    // '-->' is a single-line comment\n                    index += 3;\n                    skipSingleLineComment(3);\n                } else {\n                    break;\n                }\n            } else if (ch === 0x3C) { // U+003C is '<'\n                if (source.slice(index + 1, index + 4) === '!--') {\n                    ++index; // `<`\n                    ++index; // `!`\n                    ++index; // `-`\n                    ++index; // `-`\n                    skipSingleLineComment(4);\n                } else {\n                    break;\n                }\n            } else {\n                break;\n            }\n        }\n    }\n\n    function scanHexEscape(prefix) {\n        var i, len, ch, code = 0;\n\n        len = (prefix === 'u') ? 4 : 2;\n        for (i = 0; i < len; ++i) {\n            if (index < length && isHexDigit(source[index])) {\n                ch = source[index++];\n                code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n            } else {\n                return '';\n            }\n        }\n        return String.fromCharCode(code);\n    }\n\n    function scanUnicodeCodePointEscape() {\n        var ch, code, cu1, cu2;\n\n        ch = source[index];\n        code = 0;\n\n        // At least, one hex digit is required.\n        if (ch === '}') {\n            throwUnexpectedToken();\n        }\n\n        while (index < length) {\n            ch = source[index++];\n            if (!isHexDigit(ch)) {\n                break;\n            }\n            code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n        }\n\n        if (code > 0x10FFFF || ch !== '}') {\n            throwUnexpectedToken();\n        }\n\n        // UTF-16 Encoding\n        if (code <= 0xFFFF) {\n            return String.fromCharCode(code);\n        }\n        cu1 = ((code - 0x10000) >> 10) + 0xD800;\n        cu2 = ((code - 0x10000) & 1023) + 0xDC00;\n        return String.fromCharCode(cu1, cu2);\n    }\n\n    function getEscapedIdentifier() {\n        var ch, id;\n\n        ch = source.charCodeAt(index++);\n        id = String.fromCharCode(ch);\n\n        // '\\u' (U+005C, U+0075) denotes an escaped character.\n        if (ch === 0x5C) {\n            if (source.charCodeAt(index) !== 0x75) {\n                throwUnexpectedToken();\n            }\n            ++index;\n            ch = scanHexEscape('u');\n            if (!ch || ch === '\\\\' || !isIdentifierStart(ch.charCodeAt(0))) {\n                throwUnexpectedToken();\n            }\n            id = ch;\n        }\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (!isIdentifierPart(ch)) {\n                break;\n            }\n            ++index;\n            id += String.fromCharCode(ch);\n\n            // '\\u' (U+005C, U+0075) denotes an escaped character.\n            if (ch === 0x5C) {\n                id = id.substr(0, id.length - 1);\n                if (source.charCodeAt(index) !== 0x75) {\n                    throwUnexpectedToken();\n                }\n                ++index;\n                ch = scanHexEscape('u');\n                if (!ch || ch === '\\\\' || !isIdentifierPart(ch.charCodeAt(0))) {\n                    throwUnexpectedToken();\n                }\n                id += ch;\n            }\n        }\n\n        return id;\n    }\n\n    function getIdentifier() {\n        var start, ch;\n\n        start = index++;\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (ch === 0x5C) {\n                // Blackslash (U+005C) marks Unicode escape sequence.\n                index = start;\n                return getEscapedIdentifier();\n            }\n            if (isIdentifierPart(ch)) {\n                ++index;\n            } else {\n                break;\n            }\n        }\n\n        return source.slice(start, index);\n    }\n\n    function scanIdentifier() {\n        var start, id, type;\n\n        start = index;\n\n        // Backslash (U+005C) starts an escaped character.\n        id = (source.charCodeAt(index) === 0x5C) ? getEscapedIdentifier() : getIdentifier();\n\n        // There is no keyword or literal with only one character.\n        // Thus, it must be an identifier.\n        if (id.length === 1) {\n            type = Token.Identifier;\n        } else if (isKeyword(id)) {\n            type = Token.Keyword;\n        } else if (id === 'null') {\n            type = Token.NullLiteral;\n        } else if (id === 'true' || id === 'false') {\n            type = Token.BooleanLiteral;\n        } else {\n            type = Token.Identifier;\n        }\n\n        return {\n            type: type,\n            value: id,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n\n    // 7.7 Punctuators\n\n    function scanPunctuator() {\n        var token, str;\n\n        token = {\n            type: Token.Punctuator,\n            value: '',\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: index,\n            end: index\n        };\n\n        // Check for most common single-character punctuators.\n        str = source[index];\n        switch (str) {\n\n        case '(':\n            if (extra.tokenize) {\n                extra.openParenToken = extra.tokens.length;\n            }\n            ++index;\n            break;\n\n        case '{':\n            if (extra.tokenize) {\n                extra.openCurlyToken = extra.tokens.length;\n            }\n            state.curlyStack.push('{');\n            ++index;\n            break;\n\n        case '.':\n            ++index;\n            if (source[index] === '.' && source[index + 1] === '.') {\n                // Spread operator: ...\n                index += 2;\n                str = '...';\n            }\n            break;\n\n        case '}':\n            ++index;\n            state.curlyStack.pop();\n            break;\n        case ')':\n        case ';':\n        case ',':\n        case '[':\n        case ']':\n        case ':':\n        case '?':\n        case '~':\n            ++index;\n            break;\n\n        default:\n            // 4-character punctuator.\n            str = source.substr(index, 4);\n            if (str === '>>>=') {\n                index += 4;\n            } else {\n\n                // 3-character punctuators.\n                str = str.substr(0, 3);\n                if (str === '===' || str === '!==' || str === '>>>' ||\n                    str === '<<=' || str === '>>=') {\n                    index += 3;\n                } else {\n\n                    // 2-character punctuators.\n                    str = str.substr(0, 2);\n                    if (str === '&&' || str === '||' || str === '==' || str === '!=' ||\n                        str === '+=' || str === '-=' || str === '*=' || str === '/=' ||\n                        str === '++' || str === '--' || str === '<<' || str === '>>' ||\n                        str === '&=' || str === '|=' || str === '^=' || str === '%=' ||\n                        str === '<=' || str === '>=' || str === '=>') {\n                        index += 2;\n                    } else {\n\n                        // 1-character punctuators.\n                        str = source[index];\n                        if ('<>=!+-*%&|^/'.indexOf(str) >= 0) {\n                            ++index;\n                        }\n                    }\n                }\n            }\n        }\n\n        if (index === token.start) {\n            throwUnexpectedToken();\n        }\n\n        token.end = index;\n        token.value = str;\n        return token;\n    }\n\n    // 7.8.3 Numeric Literals\n\n    function scanHexLiteral(start) {\n        var number = '';\n\n        while (index < length) {\n            if (!isHexDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt('0x' + number, 16),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanBinaryLiteral(start) {\n        var ch, number;\n\n        number = '';\n\n        while (index < length) {\n            ch = source[index];\n            if (ch !== '0' && ch !== '1') {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            // only 0b or 0B\n            throwUnexpectedToken();\n        }\n\n        if (index < length) {\n            ch = source.charCodeAt(index);\n            /* istanbul ignore else */\n            if (isIdentifierStart(ch) || isDecimalDigit(ch)) {\n                throwUnexpectedToken();\n            }\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 2),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanOctalLiteral(prefix, start) {\n        var number, octal;\n\n        if (isOctalDigit(prefix)) {\n            octal = true;\n            number = '0' + source[index++];\n        } else {\n            octal = false;\n            ++index;\n            number = '';\n        }\n\n        while (index < length) {\n            if (!isOctalDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (!octal && number.length === 0) {\n            // only 0o or 0O\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index)) || isDecimalDigit(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 8),\n            octal: octal,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function isImplicitOctalLiteral() {\n        var i, ch;\n\n        // Implicit octal, unless there is a non-octal digit.\n        // (Annex B.1.1 on Numeric Literals)\n        for (i = index + 1; i < length; ++i) {\n            ch = source[i];\n            if (ch === '8' || ch === '9') {\n                return false;\n            }\n            if (!isOctalDigit(ch)) {\n                return true;\n            }\n        }\n\n        return true;\n    }\n\n    function scanNumericLiteral() {\n        var number, start, ch;\n\n        ch = source[index];\n        assert(isDecimalDigit(ch.charCodeAt(0)) || (ch === '.'),\n            'Numeric literal must start with a decimal digit or a decimal point');\n\n        start = index;\n        number = '';\n        if (ch !== '.') {\n            number = source[index++];\n            ch = source[index];\n\n            // Hex number starts with '0x'.\n            // Octal number starts with '0'.\n            // Octal number in ES6 starts with '0o'.\n            // Binary number in ES6 starts with '0b'.\n            if (number === '0') {\n                if (ch === 'x' || ch === 'X') {\n                    ++index;\n                    return scanHexLiteral(start);\n                }\n                if (ch === 'b' || ch === 'B') {\n                    ++index;\n                    return scanBinaryLiteral(start);\n                }\n                if (ch === 'o' || ch === 'O') {\n                    return scanOctalLiteral(ch, start);\n                }\n\n                if (isOctalDigit(ch)) {\n                    if (isImplicitOctalLiteral()) {\n                        return scanOctalLiteral(ch, start);\n                    }\n                }\n            }\n\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === '.') {\n            number += source[index++];\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === 'e' || ch === 'E') {\n            number += source[index++];\n\n            ch = source[index];\n            if (ch === '+' || ch === '-') {\n                number += source[index++];\n            }\n            if (isDecimalDigit(source.charCodeAt(index))) {\n                while (isDecimalDigit(source.charCodeAt(index))) {\n                    number += source[index++];\n                }\n            } else {\n                throwUnexpectedToken();\n            }\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseFloat(number),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    // 7.8.4 String Literals\n\n    function scanStringLiteral() {\n        var str = '', quote, start, ch, unescaped, octToDec, octal = false;\n\n        quote = source[index];\n        assert((quote === '\\'' || quote === '\"'),\n            'String literal must starts with a quote');\n\n        start = index;\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n\n            if (ch === quote) {\n                quote = '';\n                break;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!ch || !isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            str += scanUnicodeCodePointEscape();\n                        } else {\n                            unescaped = scanHexEscape(ch);\n                            if (!unescaped) {\n                                throw throwUnexpectedToken();\n                            }\n                            str += unescaped;\n                        }\n                        break;\n                    case 'n':\n                        str += '\\n';\n                        break;\n                    case 'r':\n                        str += '\\r';\n                        break;\n                    case 't':\n                        str += '\\t';\n                        break;\n                    case 'b':\n                        str += '\\b';\n                        break;\n                    case 'f':\n                        str += '\\f';\n                        break;\n                    case 'v':\n                        str += '\\x0B';\n                        break;\n                    case '8':\n                    case '9':\n                        throw throwUnexpectedToken();\n\n                    default:\n                        if (isOctalDigit(ch)) {\n                            octToDec = octalToDecimal(ch);\n\n                            octal = octToDec.octal || octal;\n                            str += String.fromCharCode(octToDec.code);\n                        } else {\n                            str += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                break;\n            } else {\n                str += ch;\n            }\n        }\n\n        if (quote !== '') {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.StringLiteral,\n            value: str,\n            octal: octal,\n            lineNumber: startLineNumber,\n            lineStart: startLineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanTemplate() {\n        var cooked = '', ch, start, rawOffset, terminated, head, tail, restore, unescaped;\n\n        terminated = false;\n        tail = false;\n        start = index;\n        head = (source[index] === '`');\n        rawOffset = 2;\n\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n            if (ch === '`') {\n                rawOffset = 1;\n                tail = true;\n                terminated = true;\n                break;\n            } else if (ch === '$') {\n                if (source[index] === '{') {\n                    state.curlyStack.push('${');\n                    ++index;\n                    terminated = true;\n                    break;\n                }\n                cooked += ch;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'n':\n                        cooked += '\\n';\n                        break;\n                    case 'r':\n                        cooked += '\\r';\n                        break;\n                    case 't':\n                        cooked += '\\t';\n                        break;\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            cooked += scanUnicodeCodePointEscape();\n                        } else {\n                            restore = index;\n                            unescaped = scanHexEscape(ch);\n                            if (unescaped) {\n                                cooked += unescaped;\n                            } else {\n                                index = restore;\n                                cooked += ch;\n                            }\n                        }\n                        break;\n                    case 'b':\n                        cooked += '\\b';\n                        break;\n                    case 'f':\n                        cooked += '\\f';\n                        break;\n                    case 'v':\n                        cooked += '\\v';\n                        break;\n\n                    default:\n                        if (ch === '0') {\n                            if (isDecimalDigit(source.charCodeAt(index))) {\n                                // Illegal: \\01 \\02 and so on\n                                throwError(Messages.TemplateOctalLiteral);\n                            }\n                            cooked += '\\0';\n                        } else if (isOctalDigit(ch)) {\n                            // Illegal: \\1 \\2\n                            throwError(Messages.TemplateOctalLiteral);\n                        } else {\n                            cooked += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                ++lineNumber;\n                if (ch === '\\r' && source[index] === '\\n') {\n                    ++index;\n                }\n                lineStart = index;\n                cooked += '\\n';\n            } else {\n                cooked += ch;\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken();\n        }\n\n        if (!head) {\n            state.curlyStack.pop();\n        }\n\n        return {\n            type: Token.Template,\n            value: {\n                cooked: cooked,\n                raw: source.slice(start + 1, index - rawOffset)\n            },\n            head: head,\n            tail: tail,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function testRegExp(pattern, flags) {\n        var tmp = pattern;\n\n        if (flags.indexOf('u') >= 0) {\n            // Replace each astral symbol and every Unicode escape sequence\n            // that possibly represents an astral symbol or a paired surrogate\n            // with a single ASCII symbol to avoid throwing on regular\n            // expressions that are only valid in combination with the `/u`\n            // flag.\n            // Note: replacing with the ASCII symbol `x` might cause false\n            // negatives in unlikely scenarios. For example, `[\\u{61}-b]` is a\n            // perfectly valid pattern that is equivalent to `[a-b]`, but it\n            // would be replaced by `[x-b]` which throws an error.\n            tmp = tmp\n                .replace(/\\\\u\\{([0-9a-fA-F]+)\\}/g, function ($0, $1) {\n                    if (parseInt($1, 16) <= 0x10FFFF) {\n                        return 'x';\n                    }\n                    throwUnexpectedToken(null, Messages.InvalidRegExp);\n                })\n                .replace(\n                    /\\\\u([a-fA-F0-9]{4})|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g,\n                    'x'\n                );\n        }\n\n        // First, detect invalid regular expressions.\n        try {\n            RegExp(tmp);\n        } catch (e) {\n            throwUnexpectedToken(null, Messages.InvalidRegExp);\n        }\n\n        // Return a regular expression object for this pattern-flag pair, or\n        // `null` in case the current environment doesn't support the flags it\n        // uses.\n        try {\n            return new RegExp(pattern, flags);\n        } catch (exception) {\n            return null;\n        }\n    }\n\n    function scanRegExpBody() {\n        var ch, str, classMarker, terminated, body;\n\n        ch = source[index];\n        assert(ch === '/', 'Regular expression literal must start with a slash');\n        str = source[index++];\n\n        classMarker = false;\n        terminated = false;\n        while (index < length) {\n            ch = source[index++];\n            str += ch;\n            if (ch === '\\\\') {\n                ch = source[index++];\n                // ECMA-262 7.8.5\n                if (isLineTerminator(ch.charCodeAt(0))) {\n                    throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n                }\n                str += ch;\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n            } else if (classMarker) {\n                if (ch === ']') {\n                    classMarker = false;\n                }\n            } else {\n                if (ch === '/') {\n                    terminated = true;\n                    break;\n                } else if (ch === '[') {\n                    classMarker = true;\n                }\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n        }\n\n        // Exclude leading and trailing slash.\n        body = str.substr(1, str.length - 2);\n        return {\n            value: body,\n            literal: str\n        };\n    }\n\n    function scanRegExpFlags() {\n        var ch, str, flags, restore;\n\n        str = '';\n        flags = '';\n        while (index < length) {\n            ch = source[index];\n            if (!isIdentifierPart(ch.charCodeAt(0))) {\n                break;\n            }\n\n            ++index;\n            if (ch === '\\\\' && index < length) {\n                ch = source[index];\n                if (ch === 'u') {\n                    ++index;\n                    restore = index;\n                    ch = scanHexEscape('u');\n                    if (ch) {\n                        flags += ch;\n                        for (str += '\\\\u'; restore < index; ++restore) {\n                            str += source[restore];\n                        }\n                    } else {\n                        index = restore;\n                        flags += 'u';\n                        str += '\\\\u';\n                    }\n                    tolerateUnexpectedToken();\n                } else {\n                    str += '\\\\';\n                    tolerateUnexpectedToken();\n                }\n            } else {\n                flags += ch;\n                str += ch;\n            }\n        }\n\n        return {\n            value: flags,\n            literal: str\n        };\n    }\n\n    function scanRegExp() {\n        scanning = true;\n        var start, body, flags, value;\n\n        lookahead = null;\n        skipComment();\n        start = index;\n\n        body = scanRegExpBody();\n        flags = scanRegExpFlags();\n        value = testRegExp(body.value, flags.value);\n        scanning = false;\n        if (extra.tokenize) {\n            return {\n                type: Token.RegularExpression,\n                value: value,\n                regex: {\n                    pattern: body.value,\n                    flags: flags.value\n                },\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: start,\n                end: index\n            };\n        }\n\n        return {\n            literal: body.literal + flags.literal,\n            value: value,\n            regex: {\n                pattern: body.value,\n                flags: flags.value\n            },\n            start: start,\n            end: index\n        };\n    }\n\n    function collectRegex() {\n        var pos, loc, regex, token;\n\n        skipComment();\n\n        pos = index;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        regex = scanRegExp();\n\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        /* istanbul ignore next */\n        if (!extra.tokenize) {\n            // Pop the previous token, which is likely '/' or '/='\n            if (extra.tokens.length > 0) {\n                token = extra.tokens[extra.tokens.length - 1];\n                if (token.range[0] === pos && token.type === 'Punctuator') {\n                    if (token.value === '/' || token.value === '/=') {\n                        extra.tokens.pop();\n                    }\n                }\n            }\n\n            extra.tokens.push({\n                type: 'RegularExpression',\n                value: regex.literal,\n                regex: regex.regex,\n                range: [pos, index],\n                loc: loc\n            });\n        }\n\n        return regex;\n    }\n\n    function isIdentifierName(token) {\n        return token.type === Token.Identifier ||\n            token.type === Token.Keyword ||\n            token.type === Token.BooleanLiteral ||\n            token.type === Token.NullLiteral;\n    }\n\n    function advanceSlash() {\n        var prevToken,\n            checkToken;\n        // Using the following algorithm:\n        // https://github.com/mozilla/sweet.js/wiki/design\n        prevToken = extra.tokens[extra.tokens.length - 1];\n        if (!prevToken) {\n            // Nothing before that: it cannot be a division.\n            return collectRegex();\n        }\n        if (prevToken.type === 'Punctuator') {\n            if (prevToken.value === ']') {\n                return scanPunctuator();\n            }\n            if (prevToken.value === ')') {\n                checkToken = extra.tokens[extra.openParenToken - 1];\n                if (checkToken &&\n                        checkToken.type === 'Keyword' &&\n                        (checkToken.value === 'if' ||\n                         checkToken.value === 'while' ||\n                         checkToken.value === 'for' ||\n                         checkToken.value === 'with')) {\n                    return collectRegex();\n                }\n                return scanPunctuator();\n            }\n            if (prevToken.value === '}') {\n                // Dividing a function by anything makes little sense,\n                // but we have to check for that.\n                if (extra.tokens[extra.openCurlyToken - 3] &&\n                        extra.tokens[extra.openCurlyToken - 3].type === 'Keyword') {\n                    // Anonymous function.\n                    checkToken = extra.tokens[extra.openCurlyToken - 4];\n                    if (!checkToken) {\n                        return scanPunctuator();\n                    }\n                } else if (extra.tokens[extra.openCurlyToken - 4] &&\n                        extra.tokens[extra.openCurlyToken - 4].type === 'Keyword') {\n                    // Named function.\n                    checkToken = extra.tokens[extra.openCurlyToken - 5];\n                    if (!checkToken) {\n                        return collectRegex();\n                    }\n                } else {\n                    return scanPunctuator();\n                }\n                // checkToken determines whether the function is\n                // a declaration or an expression.\n                if (FnExprTokens.indexOf(checkToken.value) >= 0) {\n                    // It is an expression.\n                    return scanPunctuator();\n                }\n                // It is a declaration.\n                return collectRegex();\n            }\n            return collectRegex();\n        }\n        if (prevToken.type === 'Keyword' && prevToken.value !== 'this') {\n            return collectRegex();\n        }\n        return scanPunctuator();\n    }\n\n    function advance() {\n        var ch, token;\n\n        if (index >= length) {\n            return {\n                type: Token.EOF,\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: index,\n                end: index\n            };\n        }\n\n        ch = source.charCodeAt(index);\n\n        if (isIdentifierStart(ch)) {\n            token = scanIdentifier();\n            if (strict && isStrictModeReservedWord(token.value)) {\n                token.type = Token.Keyword;\n            }\n            return token;\n        }\n\n        // Very common: ( and ) and ;\n        if (ch === 0x28 || ch === 0x29 || ch === 0x3B) {\n            return scanPunctuator();\n        }\n\n        // String literal starts with single quote (U+0027) or double quote (U+0022).\n        if (ch === 0x27 || ch === 0x22) {\n            return scanStringLiteral();\n        }\n\n        // Dot (.) U+002E can also start a floating-point number, hence the need\n        // to check the next character.\n        if (ch === 0x2E) {\n            if (isDecimalDigit(source.charCodeAt(index + 1))) {\n                return scanNumericLiteral();\n            }\n            return scanPunctuator();\n        }\n\n        if (isDecimalDigit(ch)) {\n            return scanNumericLiteral();\n        }\n\n        // Slash (/) U+002F can also start a regex.\n        if (extra.tokenize && ch === 0x2F) {\n            return advanceSlash();\n        }\n\n        // Template literals start with ` (U+0060) for template head\n        // or } (U+007D) for template middle or template tail.\n        if (ch === 0x60 || (ch === 0x7D && state.curlyStack[state.curlyStack.length - 1] === '${')) {\n            return scanTemplate();\n        }\n\n        return scanPunctuator();\n    }\n\n    function collectToken() {\n        var loc, token, value, entry;\n\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        token = advance();\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        if (token.type !== Token.EOF) {\n            value = source.slice(token.start, token.end);\n            entry = {\n                type: TokenName[token.type],\n                value: value,\n                range: [token.start, token.end],\n                loc: loc\n            };\n            if (token.regex) {\n                entry.regex = {\n                    pattern: token.regex.pattern,\n                    flags: token.regex.flags\n                };\n            }\n            extra.tokens.push(entry);\n        }\n\n        return token;\n    }\n\n    function lex() {\n        var token;\n        scanning = true;\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        skipComment();\n\n        token = lookahead;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n        return token;\n    }\n\n    function peek() {\n        scanning = true;\n\n        skipComment();\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n    }\n\n    function Position() {\n        this.line = startLineNumber;\n        this.column = startIndex - startLineStart;\n    }\n\n    function SourceLocation() {\n        this.start = new Position();\n        this.end = null;\n    }\n\n    function WrappingSourceLocation(startToken) {\n        this.start = {\n            line: startToken.lineNumber,\n            column: startToken.start - startToken.lineStart\n        };\n        this.end = null;\n    }\n\n    function Node() {\n        if (extra.range) {\n            this.range = [startIndex, 0];\n        }\n        if (extra.loc) {\n            this.loc = new SourceLocation();\n        }\n    }\n\n    function WrappingNode(startToken) {\n        if (extra.range) {\n            this.range = [startToken.start, 0];\n        }\n        if (extra.loc) {\n            this.loc = new WrappingSourceLocation(startToken);\n        }\n    }\n\n    WrappingNode.prototype = Node.prototype = {\n\n        processComment: function () {\n            var lastChild,\n                leadingComments,\n                trailingComments,\n                bottomRight = extra.bottomRightStack,\n                i,\n                comment,\n                last = bottomRight[bottomRight.length - 1];\n\n            if (this.type === Syntax.Program) {\n                if (this.body.length > 0) {\n                    return;\n                }\n            }\n\n            if (extra.trailingComments.length > 0) {\n                trailingComments = [];\n                for (i = extra.trailingComments.length - 1; i >= 0; --i) {\n                    comment = extra.trailingComments[i];\n                    if (comment.range[0] >= this.range[1]) {\n                        trailingComments.unshift(comment);\n                        extra.trailingComments.splice(i, 1);\n                    }\n                }\n                extra.trailingComments = [];\n            } else {\n                if (last && last.trailingComments && last.trailingComments[0].range[0] >= this.range[1]) {\n                    trailingComments = last.trailingComments;\n                    delete last.trailingComments;\n                }\n            }\n\n            // Eating the stack.\n            if (last) {\n                while (last && last.range[0] >= this.range[0]) {\n                    lastChild = last;\n                    last = bottomRight.pop();\n                }\n            }\n\n            if (lastChild) {\n                if (lastChild.leadingComments && lastChild.leadingComments[lastChild.leadingComments.length - 1].range[1] <= this.range[0]) {\n                    this.leadingComments = lastChild.leadingComments;\n                    lastChild.leadingComments = undefined;\n                }\n            } else if (extra.leadingComments.length > 0) {\n                leadingComments = [];\n                for (i = extra.leadingComments.length - 1; i >= 0; --i) {\n                    comment = extra.leadingComments[i];\n                    if (comment.range[1] <= this.range[0]) {\n                        leadingComments.unshift(comment);\n                        extra.leadingComments.splice(i, 1);\n                    }\n                }\n            }\n\n\n            if (leadingComments && leadingComments.length > 0) {\n                this.leadingComments = leadingComments;\n            }\n            if (trailingComments && trailingComments.length > 0) {\n                this.trailingComments = trailingComments;\n            }\n\n            bottomRight.push(this);\n        },\n\n        finish: function () {\n            if (extra.range) {\n                this.range[1] = lastIndex;\n            }\n            if (extra.loc) {\n                this.loc.end = {\n                    line: lastLineNumber,\n                    column: lastIndex - lastLineStart\n                };\n                if (extra.source) {\n                    this.loc.source = extra.source;\n                }\n            }\n\n            if (extra.attachComment) {\n                this.processComment();\n            }\n        },\n\n        finishArrayExpression: function (elements) {\n            this.type = Syntax.ArrayExpression;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrayPattern: function (elements) {\n            this.type = Syntax.ArrayPattern;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrowFunctionExpression: function (params, defaults, body, expression) {\n            this.type = Syntax.ArrowFunctionExpression;\n            this.id = null;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentExpression: function (operator, left, right) {\n            this.type = Syntax.AssignmentExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentPattern: function (left, right) {\n            this.type = Syntax.AssignmentPattern;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBinaryExpression: function (operator, left, right) {\n            this.type = (operator === '||' || operator === '&&') ? Syntax.LogicalExpression : Syntax.BinaryExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBlockStatement: function (body) {\n            this.type = Syntax.BlockStatement;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishBreakStatement: function (label) {\n            this.type = Syntax.BreakStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishCallExpression: function (callee, args) {\n            this.type = Syntax.CallExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishCatchClause: function (param, body) {\n            this.type = Syntax.CatchClause;\n            this.param = param;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassBody: function (body) {\n            this.type = Syntax.ClassBody;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassDeclaration: function (id, superClass, body) {\n            this.type = Syntax.ClassDeclaration;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassExpression: function (id, superClass, body) {\n            this.type = Syntax.ClassExpression;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishConditionalExpression: function (test, consequent, alternate) {\n            this.type = Syntax.ConditionalExpression;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishContinueStatement: function (label) {\n            this.type = Syntax.ContinueStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishDebuggerStatement: function () {\n            this.type = Syntax.DebuggerStatement;\n            this.finish();\n            return this;\n        },\n\n        finishDoWhileStatement: function (body, test) {\n            this.type = Syntax.DoWhileStatement;\n            this.body = body;\n            this.test = test;\n            this.finish();\n            return this;\n        },\n\n        finishEmptyStatement: function () {\n            this.type = Syntax.EmptyStatement;\n            this.finish();\n            return this;\n        },\n\n        finishExpressionStatement: function (expression) {\n            this.type = Syntax.ExpressionStatement;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishForStatement: function (init, test, update, body) {\n            this.type = Syntax.ForStatement;\n            this.init = init;\n            this.test = test;\n            this.update = update;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishForInStatement: function (left, right, body) {\n            this.type = Syntax.ForInStatement;\n            this.left = left;\n            this.right = right;\n            this.body = body;\n            this.each = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionDeclaration: function (id, params, defaults, body) {\n            this.type = Syntax.FunctionDeclaration;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionExpression: function (id, params, defaults, body) {\n            this.type = Syntax.FunctionExpression;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishIdentifier: function (name) {\n            this.type = Syntax.Identifier;\n            this.name = name;\n            this.finish();\n            return this;\n        },\n\n        finishIfStatement: function (test, consequent, alternate) {\n            this.type = Syntax.IfStatement;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishLabeledStatement: function (label, body) {\n            this.type = Syntax.LabeledStatement;\n            this.label = label;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishLiteral: function (token) {\n            this.type = Syntax.Literal;\n            this.value = token.value;\n            this.raw = source.slice(token.start, token.end);\n            if (token.regex) {\n                this.regex = token.regex;\n            }\n            this.finish();\n            return this;\n        },\n\n        finishMemberExpression: function (accessor, object, property) {\n            this.type = Syntax.MemberExpression;\n            this.computed = accessor === '[';\n            this.object = object;\n            this.property = property;\n            this.finish();\n            return this;\n        },\n\n        finishNewExpression: function (callee, args) {\n            this.type = Syntax.NewExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishObjectExpression: function (properties) {\n            this.type = Syntax.ObjectExpression;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishObjectPattern: function (properties) {\n            this.type = Syntax.ObjectPattern;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishPostfixExpression: function (operator, argument) {\n            this.type = Syntax.UpdateExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = false;\n            this.finish();\n            return this;\n        },\n\n        finishProgram: function (body) {\n            this.type = Syntax.Program;\n            this.body = body;\n            if (sourceType === 'module') {\n                // very restrictive for now\n                this.sourceType = sourceType;\n            }\n            this.finish();\n            return this;\n        },\n\n        finishProperty: function (kind, key, computed, value, method, shorthand) {\n            this.type = Syntax.Property;\n            this.key = key;\n            this.computed = computed;\n            this.value = value;\n            this.kind = kind;\n            this.method = method;\n            this.shorthand = shorthand;\n            this.finish();\n            return this;\n        },\n\n        finishRestElement: function (argument) {\n            this.type = Syntax.RestElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishReturnStatement: function (argument) {\n            this.type = Syntax.ReturnStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSequenceExpression: function (expressions) {\n            this.type = Syntax.SequenceExpression;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishSpreadElement: function (argument) {\n            this.type = Syntax.SpreadElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchCase: function (test, consequent) {\n            this.type = Syntax.SwitchCase;\n            this.test = test;\n            this.consequent = consequent;\n            this.finish();\n            return this;\n        },\n\n        finishSuper: function () {\n            this.type = Syntax.Super;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchStatement: function (discriminant, cases) {\n            this.type = Syntax.SwitchStatement;\n            this.discriminant = discriminant;\n            this.cases = cases;\n            this.finish();\n            return this;\n        },\n\n        finishTaggedTemplateExpression: function (tag, quasi) {\n            this.type = Syntax.TaggedTemplateExpression;\n            this.tag = tag;\n            this.quasi = quasi;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateElement: function (value, tail) {\n            this.type = Syntax.TemplateElement;\n            this.value = value;\n            this.tail = tail;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateLiteral: function (quasis, expressions) {\n            this.type = Syntax.TemplateLiteral;\n            this.quasis = quasis;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishThisExpression: function () {\n            this.type = Syntax.ThisExpression;\n            this.finish();\n            return this;\n        },\n\n        finishThrowStatement: function (argument) {\n            this.type = Syntax.ThrowStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishTryStatement: function (block, handler, finalizer) {\n            this.type = Syntax.TryStatement;\n            this.block = block;\n            this.guardedHandlers = [];\n            this.handlers = handler ? [ handler ] : [];\n            this.handler = handler;\n            this.finalizer = finalizer;\n            this.finish();\n            return this;\n        },\n\n        finishUnaryExpression: function (operator, argument) {\n            this.type = (operator === '++' || operator === '--') ? Syntax.UpdateExpression : Syntax.UnaryExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = true;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclaration: function (declarations) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = 'var';\n            this.finish();\n            return this;\n        },\n\n        finishLexicalDeclaration: function (declarations, kind) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = kind;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclarator: function (id, init) {\n            this.type = Syntax.VariableDeclarator;\n            this.id = id;\n            this.init = init;\n            this.finish();\n            return this;\n        },\n\n        finishWhileStatement: function (test, body) {\n            this.type = Syntax.WhileStatement;\n            this.test = test;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishWithStatement: function (object, body) {\n            this.type = Syntax.WithStatement;\n            this.object = object;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishExportSpecifier: function (local, exported) {\n            this.type = Syntax.ExportSpecifier;\n            this.exported = exported || local;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportDefaultSpecifier: function (local) {\n            this.type = Syntax.ImportDefaultSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportNamespaceSpecifier: function (local) {\n            this.type = Syntax.ImportNamespaceSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishExportNamedDeclaration: function (declaration, specifiers, src) {\n            this.type = Syntax.ExportNamedDeclaration;\n            this.declaration = declaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishExportDefaultDeclaration: function (declaration) {\n            this.type = Syntax.ExportDefaultDeclaration;\n            this.declaration = declaration;\n            this.finish();\n            return this;\n        },\n\n        finishExportAllDeclaration: function (src) {\n            this.type = Syntax.ExportAllDeclaration;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishImportSpecifier: function (local, imported) {\n            this.type = Syntax.ImportSpecifier;\n            this.local = local || imported;\n            this.imported = imported;\n            this.finish();\n            return this;\n        },\n\n        finishImportDeclaration: function (specifiers, src) {\n            this.type = Syntax.ImportDeclaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        }\n    };\n\n\n    function recordError(error) {\n        var e, existing;\n\n        for (e = 0; e < extra.errors.length; e++) {\n            existing = extra.errors[e];\n            // Prevent duplicated error.\n            /* istanbul ignore next */\n            if (existing.index === error.index && existing.message === error.message) {\n                return;\n            }\n        }\n\n        extra.errors.push(error);\n    }\n\n    function createError(line, pos, description) {\n        var error = new Error('Line ' + line + ': ' + description);\n        error.index = pos;\n        error.lineNumber = line;\n        error.column = pos - (scanning ? lineStart : lastLineStart) + 1;\n        error.description = description;\n        return error;\n    }\n\n    // Throw an exception\n\n    function throwError(messageFormat) {\n        var args, msg;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        throw createError(lastLineNumber, lastIndex, msg);\n    }\n\n    function tolerateError(messageFormat) {\n        var args, msg, error;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        /* istanbul ignore next */\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        error = createError(lineNumber, lastIndex, msg);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Throw an exception because of the token.\n\n    function unexpectedTokenError(token, message) {\n        var value, msg = message || Messages.UnexpectedToken;\n\n        if (token) {\n            if (!message) {\n                msg = (token.type === Token.EOF) ? Messages.UnexpectedEOS :\n                    (token.type === Token.Identifier) ? Messages.UnexpectedIdentifier :\n                    (token.type === Token.NumericLiteral) ? Messages.UnexpectedNumber :\n                    (token.type === Token.StringLiteral) ? Messages.UnexpectedString :\n                    (token.type === Token.Template) ? Messages.UnexpectedTemplate :\n                    Messages.UnexpectedToken;\n\n                if (token.type === Token.Keyword) {\n                    if (isFutureReservedWord(token.value)) {\n                        msg = Messages.UnexpectedReserved;\n                    } else if (strict && isStrictModeReservedWord(token.value)) {\n                        msg = Messages.StrictReservedWord;\n                    }\n                }\n            }\n\n            value = (token.type === Token.Template) ? token.value.raw : token.value;\n        } else {\n            value = 'ILLEGAL';\n        }\n\n        msg = msg.replace('%0', value);\n\n        return (token && typeof token.lineNumber === 'number') ?\n            createError(token.lineNumber, token.start, msg) :\n            createError(scanning ? lineNumber : lastLineNumber, scanning ? index : lastIndex, msg);\n    }\n\n    function throwUnexpectedToken(token, message) {\n        throw unexpectedTokenError(token, message);\n    }\n\n    function tolerateUnexpectedToken(token, message) {\n        var error = unexpectedTokenError(token, message);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Expect the next token to match the specified punctuator.\n    // If not, an exception will be thrown.\n\n    function expect(value) {\n        var token = lex();\n        if (token.type !== Token.Punctuator || token.value !== value) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    /**\n     * @name expectCommaSeparator\n     * @description Quietly expect a comma when in tolerant mode, otherwise delegates\n     * to <code>expect(value)</code>\n     * @since 2.0\n     */\n    function expectCommaSeparator() {\n        var token;\n\n        if (extra.errors) {\n            token = lookahead;\n            if (token.type === Token.Punctuator && token.value === ',') {\n                lex();\n            } else if (token.type === Token.Punctuator && token.value === ';') {\n                lex();\n                tolerateUnexpectedToken(token);\n            } else {\n                tolerateUnexpectedToken(token, Messages.UnexpectedToken);\n            }\n        } else {\n            expect(',');\n        }\n    }\n\n    // Expect the next token to match the specified keyword.\n    // If not, an exception will be thrown.\n\n    function expectKeyword(keyword) {\n        var token = lex();\n        if (token.type !== Token.Keyword || token.value !== keyword) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    // Return true if the next token matches the specified punctuator.\n\n    function match(value) {\n        return lookahead.type === Token.Punctuator && lookahead.value === value;\n    }\n\n    // Return true if the next token matches the specified keyword\n\n    function matchKeyword(keyword) {\n        return lookahead.type === Token.Keyword && lookahead.value === keyword;\n    }\n\n    // Return true if the next token matches the specified contextual keyword\n    // (where an identifier is sometimes a keyword depending on the context)\n\n    function matchContextualKeyword(keyword) {\n        return lookahead.type === Token.Identifier && lookahead.value === keyword;\n    }\n\n    // Return true if the next token is an assignment operator\n\n    function matchAssign() {\n        var op;\n\n        if (lookahead.type !== Token.Punctuator) {\n            return false;\n        }\n        op = lookahead.value;\n        return op === '=' ||\n            op === '*=' ||\n            op === '/=' ||\n            op === '%=' ||\n            op === '+=' ||\n            op === '-=' ||\n            op === '<<=' ||\n            op === '>>=' ||\n            op === '>>>=' ||\n            op === '&=' ||\n            op === '^=' ||\n            op === '|=';\n    }\n\n    function consumeSemicolon() {\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(startIndex) === 0x3B || match(';')) {\n            lex();\n            return;\n        }\n\n        if (hasLineTerminator) {\n            return;\n        }\n\n        // FIXME(ikarienator): this is seemingly an issue in the previous location info convention.\n        lastIndex = startIndex;\n        lastLineNumber = startLineNumber;\n        lastLineStart = startLineStart;\n\n        if (lookahead.type !== Token.EOF && !match('}')) {\n            throwUnexpectedToken(lookahead);\n        }\n    }\n\n    // Cover grammar support.\n    //\n    // When an assignment expression position starts with an left parenthesis, the determination of the type\n    // of the syntax is to be deferred arbitrarily long until the end of the parentheses pair (plus a lookahead)\n    // or the first comma. This situation also defers the determination of all the expressions nested in the pair.\n    //\n    // There are three productions that can be parsed in a parentheses pair that needs to be determined\n    // after the outermost pair is closed. They are:\n    //\n    //   1. AssignmentExpression\n    //   2. BindingElements\n    //   3. AssignmentTargets\n    //\n    // In order to avoid exponential backtracking, we use two flags to denote if the production can be\n    // binding element or assignment target.\n    //\n    // The three productions have the relationship:\n    //\n    //   BindingElements ⊆ AssignmentTargets ⊆ AssignmentExpression\n    //\n    // with a single exception that CoverInitializedName when used directly in an Expression, generates\n    // an early error. Therefore, we need the third state, firstCoverInitializedNameError, to track the\n    // first usage of CoverInitializedName and report it when we reached the end of the parentheses pair.\n    //\n    // isolateCoverGrammar function runs the given parser function with a new cover grammar context, and it does not\n    // effect the current flags. This means the production the parser parses is only used as an expression. Therefore\n    // the CoverInitializedName check is conducted.\n    //\n    // inheritCoverGrammar function runs the given parse function with a new cover grammar context, and it propagates\n    // the flags outside of the parser. This means the production the parser parses is used as a part of a potential\n    // pattern. The CoverInitializedName check is deferred.\n    function isolateCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        if (firstCoverInitializedNameError !== null) {\n            throwUnexpectedToken(firstCoverInitializedNameError);\n        }\n        isBindingElement = oldIsBindingElement;\n        isAssignmentTarget = oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError;\n        return result;\n    }\n\n    function inheritCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        isBindingElement = isBindingElement && oldIsBindingElement;\n        isAssignmentTarget = isAssignmentTarget && oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError || firstCoverInitializedNameError;\n        return result;\n    }\n\n    function parseArrayPattern() {\n        var node = new Node(), elements = [], rest, restNode;\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else {\n                if (match('...')) {\n                    restNode = new Node();\n                    lex();\n                    rest = parseVariableIdentifier();\n                    elements.push(restNode.finishRestElement(rest));\n                    break;\n                } else {\n                    elements.push(parsePatternWithDefault());\n                }\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n\n        }\n\n        expect(']');\n\n        return node.finishArrayPattern(elements);\n    }\n\n    function parsePropertyPattern() {\n        var node = new Node(), key, computed = match('['), init;\n        if (lookahead.type === Token.Identifier) {\n            key = parseVariableIdentifier();\n            if (match('=')) {\n                lex();\n                init = parseAssignmentExpression();\n                return node.finishProperty(\n                    'init', key, false,\n                    new WrappingNode(key).finishAssignmentPattern(key, init), false, false);\n            } else if (!match(':')) {\n                return node.finishProperty('init', key, false, key, false, true);\n            }\n        } else {\n            key = parseObjectPropertyKey();\n        }\n        expect(':');\n        init = parsePatternWithDefault();\n        return node.finishProperty('init', key, computed, init, false, false);\n    }\n\n    function parseObjectPattern() {\n        var node = new Node(), properties = [];\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parsePropertyPattern());\n            if (!match('}')) {\n                expect(',');\n            }\n        }\n\n        lex();\n\n        return node.finishObjectPattern(properties);\n    }\n\n    function parsePattern() {\n        if (lookahead.type === Token.Identifier) {\n            return parseVariableIdentifier();\n        } else if (match('[')) {\n            return parseArrayPattern();\n        } else if (match('{')) {\n            return parseObjectPattern();\n        }\n        throwUnexpectedToken(lookahead);\n    }\n\n    function parsePatternWithDefault() {\n        var startToken = lookahead, pattern, right;\n        pattern = parsePattern();\n        if (match('=')) {\n            lex();\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            pattern = new WrappingNode(startToken).finishAssignmentPattern(pattern, right);\n        }\n        return pattern;\n    }\n\n    // 11.1.4 Array Initialiser\n\n    function parseArrayInitialiser() {\n        var elements = [], node = new Node(), restSpread;\n\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else if (match('...')) {\n                restSpread = new Node();\n                lex();\n                restSpread.finishSpreadElement(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    isAssignmentTarget = isBindingElement = false;\n                    expect(',');\n                }\n                elements.push(restSpread);\n            } else {\n                elements.push(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n        }\n\n        lex();\n\n        return node.finishArrayExpression(elements);\n    }\n\n    // 11.1.5 Object Initialiser\n\n    function parsePropertyFunction(node, paramInfo) {\n        var previousStrict, body;\n\n        isAssignmentTarget = isBindingElement = false;\n\n        previousStrict = strict;\n        body = isolateCoverGrammar(parseFunctionSourceElements);\n\n        if (strict && paramInfo.firstRestricted) {\n            tolerateUnexpectedToken(paramInfo.firstRestricted, paramInfo.message);\n        }\n        if (strict && paramInfo.stricted) {\n            tolerateUnexpectedToken(paramInfo.stricted, paramInfo.message);\n        }\n\n        strict = previousStrict;\n        return node.finishFunctionExpression(null, paramInfo.params, paramInfo.defaults, body);\n    }\n\n    function parsePropertyMethodFunction() {\n        var params, method, node = new Node();\n\n        params = parseParams();\n        method = parsePropertyFunction(node, params);\n\n        return method;\n    }\n\n    function parseObjectPropertyKey() {\n        var token, node = new Node(), expr;\n\n        token = lex();\n\n        // Note: This function is called only from parseObjectProperty(), where\n        // EOF and Punctuator tokens are already filtered out.\n\n        switch (token.type) {\n        case Token.StringLiteral:\n        case Token.NumericLiteral:\n            if (strict && token.octal) {\n                tolerateUnexpectedToken(token, Messages.StrictOctalLiteral);\n            }\n            return node.finishLiteral(token);\n        case Token.Identifier:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.Keyword:\n            return node.finishIdentifier(token.value);\n        case Token.Punctuator:\n            if (token.value === '[') {\n                expr = isolateCoverGrammar(parseAssignmentExpression);\n                expect(']');\n                return expr;\n            }\n            break;\n        }\n        throwUnexpectedToken(token);\n    }\n\n    function lookaheadPropertyName() {\n        switch (lookahead.type) {\n        case Token.Identifier:\n        case Token.StringLiteral:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.NumericLiteral:\n        case Token.Keyword:\n            return true;\n        case Token.Punctuator:\n            return lookahead.value === '[';\n        }\n        return false;\n    }\n\n    // This function is to try to parse a MethodDefinition as defined in 14.3. But in the case of object literals,\n    // it might be called at a position where there is in fact a short hand identifier pattern or a data property.\n    // This can only be determined after we consumed up to the left parentheses.\n    //\n    // In order to avoid back tracking, it returns `null` if the position is not a MethodDefinition and the caller\n    // is responsible to visit other options.\n    function tryParseMethodDefinition(token, key, computed, node) {\n        var value, options, methodNode;\n\n        if (token.type === Token.Identifier) {\n            // check for `get` and `set`;\n\n            if (token.value === 'get' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n                expect(')');\n                value = parsePropertyFunction(methodNode, {\n                    params: [],\n                    defaults: [],\n                    stricted: null,\n                    firstRestricted: null,\n                    message: null\n                });\n                return node.finishProperty('get', key, computed, value, false, false);\n            } else if (token.value === 'set' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n\n                options = {\n                    params: [],\n                    defaultCount: 0,\n                    defaults: [],\n                    firstRestricted: null,\n                    paramSet: {}\n                };\n                if (match(')')) {\n                    tolerateUnexpectedToken(lookahead);\n                } else {\n                    parseParam(options);\n                    if (options.defaultCount === 0) {\n                        options.defaults = [];\n                    }\n                }\n                expect(')');\n\n                value = parsePropertyFunction(methodNode, options);\n                return node.finishProperty('set', key, computed, value, false, false);\n            }\n        }\n\n        if (match('(')) {\n            value = parsePropertyMethodFunction();\n            return node.finishProperty('init', key, computed, value, true, false);\n        }\n\n        // Not a MethodDefinition.\n        return null;\n    }\n\n    function checkProto(key, computed, hasProto) {\n        if (computed === false && (key.type === Syntax.Identifier && key.name === '__proto__' ||\n            key.type === Syntax.Literal && key.value === '__proto__')) {\n            if (hasProto.value) {\n                tolerateError(Messages.DuplicateProtoProperty);\n            } else {\n                hasProto.value = true;\n            }\n        }\n    }\n\n    function parseObjectProperty(hasProto) {\n        var token = lookahead, node = new Node(), computed, key, maybeMethod, value;\n\n        computed = match('[');\n        key = parseObjectPropertyKey();\n        maybeMethod = tryParseMethodDefinition(token, key, computed, node);\n\n        if (maybeMethod) {\n            checkProto(maybeMethod.key, maybeMethod.computed, hasProto);\n            // finished\n            return maybeMethod;\n        }\n\n        // init property or short hand property.\n        checkProto(key, computed, hasProto);\n\n        if (match(':')) {\n            lex();\n            value = inheritCoverGrammar(parseAssignmentExpression);\n            return node.finishProperty('init', key, computed, value, false, false);\n        }\n\n        if (token.type === Token.Identifier) {\n            if (match('=')) {\n                firstCoverInitializedNameError = lookahead;\n                lex();\n                value = isolateCoverGrammar(parseAssignmentExpression);\n                return node.finishProperty('init', key, computed,\n                    new WrappingNode(token).finishAssignmentPattern(key, value), false, true);\n            }\n            return node.finishProperty('init', key, computed, key, false, true);\n        }\n\n        throwUnexpectedToken(lookahead);\n    }\n\n    function parseObjectInitialiser() {\n        var properties = [], hasProto = {value: false}, node = new Node();\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parseObjectProperty(hasProto));\n\n            if (!match('}')) {\n                expectCommaSeparator();\n            }\n        }\n\n        expect('}');\n\n        return node.finishObjectExpression(properties);\n    }\n\n    function reinterpretExpressionAsPattern(expr) {\n        var i;\n        switch (expr.type) {\n        case Syntax.Identifier:\n        case Syntax.MemberExpression:\n        case Syntax.RestElement:\n        case Syntax.AssignmentPattern:\n            break;\n        case Syntax.SpreadElement:\n            expr.type = Syntax.RestElement;\n            reinterpretExpressionAsPattern(expr.argument);\n            break;\n        case Syntax.ArrayExpression:\n            expr.type = Syntax.ArrayPattern;\n            for (i = 0; i < expr.elements.length; i++) {\n                if (expr.elements[i] !== null) {\n                    reinterpretExpressionAsPattern(expr.elements[i]);\n                }\n            }\n            break;\n        case Syntax.ObjectExpression:\n            expr.type = Syntax.ObjectPattern;\n            for (i = 0; i < expr.properties.length; i++) {\n                reinterpretExpressionAsPattern(expr.properties[i].value);\n            }\n            break;\n        case Syntax.AssignmentExpression:\n            expr.type = Syntax.AssignmentPattern;\n            reinterpretExpressionAsPattern(expr.left);\n            break;\n        default:\n            // Allow other node type for tolerant parsing.\n            break;\n        }\n    }\n\n    function parseTemplateElement(option) {\n        var node, token;\n\n        if (lookahead.type !== Token.Template || (option.head && !lookahead.head)) {\n            throwUnexpectedToken();\n        }\n\n        node = new Node();\n        token = lex();\n\n        return node.finishTemplateElement({ raw: token.value.raw, cooked: token.value.cooked }, token.tail);\n    }\n\n    function parseTemplateLiteral() {\n        var quasi, quasis, expressions, node = new Node();\n\n        quasi = parseTemplateElement({ head: true });\n        quasis = [ quasi ];\n        expressions = [];\n\n        while (!quasi.tail) {\n            expressions.push(parseExpression());\n            quasi = parseTemplateElement({ head: false });\n            quasis.push(quasi);\n        }\n\n        return node.finishTemplateLiteral(quasis, expressions);\n    }\n\n    // 11.1.6 The Grouping Operator\n\n    function parseGroupExpression() {\n        var expr, expressions, startToken, i;\n\n        expect('(');\n\n        if (match(')')) {\n            lex();\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: []\n            };\n        }\n\n        startToken = lookahead;\n        if (match('...')) {\n            expr = parseRestElement();\n            expect(')');\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: [expr]\n            };\n        }\n\n        isBindingElement = true;\n        expr = inheritCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            isAssignmentTarget = false;\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n\n                if (match('...')) {\n                    if (!isBindingElement) {\n                        throwUnexpectedToken(lookahead);\n                    }\n                    expressions.push(parseRestElement());\n                    expect(')');\n                    if (!match('=>')) {\n                        expect('=>');\n                    }\n                    isBindingElement = false;\n                    for (i = 0; i < expressions.length; i++) {\n                        reinterpretExpressionAsPattern(expressions[i]);\n                    }\n                    return {\n                        type: PlaceHolders.ArrowParameterPlaceHolder,\n                        params: expressions\n                    };\n                }\n\n                expressions.push(inheritCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n\n        expect(')');\n\n        if (match('=>')) {\n            if (!isBindingElement) {\n                throwUnexpectedToken(lookahead);\n            }\n\n            if (expr.type === Syntax.SequenceExpression) {\n                for (i = 0; i < expr.expressions.length; i++) {\n                    reinterpretExpressionAsPattern(expr.expressions[i]);\n                }\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            expr = {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: expr.type === Syntax.SequenceExpression ? expr.expressions : [expr]\n            };\n        }\n        isBindingElement = false;\n        return expr;\n    }\n\n\n    // 11.1 Primary Expressions\n\n    function parsePrimaryExpression() {\n        var type, token, expr, node;\n\n        if (match('(')) {\n            isBindingElement = false;\n            return inheritCoverGrammar(parseGroupExpression);\n        }\n\n        if (match('[')) {\n            return inheritCoverGrammar(parseArrayInitialiser);\n        }\n\n        if (match('{')) {\n            return inheritCoverGrammar(parseObjectInitialiser);\n        }\n\n        type = lookahead.type;\n        node = new Node();\n\n        if (type === Token.Identifier) {\n            expr = node.finishIdentifier(lex().value);\n        } else if (type === Token.StringLiteral || type === Token.NumericLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            if (strict && lookahead.octal) {\n                tolerateUnexpectedToken(lookahead, Messages.StrictOctalLiteral);\n            }\n            expr = node.finishLiteral(lex());\n        } else if (type === Token.Keyword) {\n            isAssignmentTarget = isBindingElement = false;\n            if (matchKeyword('function')) {\n                return parseFunctionExpression();\n            }\n            if (matchKeyword('this')) {\n                lex();\n                return node.finishThisExpression();\n            }\n            if (matchKeyword('class')) {\n                return parseClassExpression();\n            }\n            throwUnexpectedToken(lex());\n        } else if (type === Token.BooleanLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = (token.value === 'true');\n            expr = node.finishLiteral(token);\n        } else if (type === Token.NullLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = null;\n            expr = node.finishLiteral(token);\n        } else if (match('/') || match('/=')) {\n            isAssignmentTarget = isBindingElement = false;\n            index = startIndex;\n\n            if (typeof extra.tokens !== 'undefined') {\n                token = collectRegex();\n            } else {\n                token = scanRegExp();\n            }\n            lex();\n            expr = node.finishLiteral(token);\n        } else if (type === Token.Template) {\n            expr = parseTemplateLiteral();\n        } else {\n            throwUnexpectedToken(lex());\n        }\n\n        return expr;\n    }\n\n    // 11.2 Left-Hand-Side Expressions\n\n    function parseArguments() {\n        var args = [];\n\n        expect('(');\n\n        if (!match(')')) {\n            while (startIndex < length) {\n                args.push(isolateCoverGrammar(parseAssignmentExpression));\n                if (match(')')) {\n                    break;\n                }\n                expectCommaSeparator();\n            }\n        }\n\n        expect(')');\n\n        return args;\n    }\n\n    function parseNonComputedProperty() {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (!isIdentifierName(token)) {\n            throwUnexpectedToken(token);\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseNonComputedMember() {\n        expect('.');\n\n        return parseNonComputedProperty();\n    }\n\n    function parseComputedMember() {\n        var expr;\n\n        expect('[');\n\n        expr = isolateCoverGrammar(parseExpression);\n\n        expect(']');\n\n        return expr;\n    }\n\n    function parseNewExpression() {\n        var callee, args, node = new Node();\n\n        expectKeyword('new');\n        callee = isolateCoverGrammar(parseLeftHandSideExpression);\n        args = match('(') ? parseArguments() : [];\n\n        isAssignmentTarget = isBindingElement = false;\n\n        return node.finishNewExpression(callee, args);\n    }\n\n    function parseLeftHandSideExpressionAllowCall() {\n        var quasi, expr, args, property, startToken, previousAllowIn = state.allowIn;\n\n        startToken = lookahead;\n        state.allowIn = true;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('(') && !match('.') && !match('[')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (match('(')) {\n                isBindingElement = false;\n                isAssignmentTarget = false;\n                args = parseArguments();\n                expr = new WrappingNode(startToken).finishCallExpression(expr, args);\n            } else if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        state.allowIn = previousAllowIn;\n\n        return expr;\n    }\n\n    function parseLeftHandSideExpression() {\n        var quasi, expr, property, startToken;\n        assert(state.allowIn, 'callee of new expression always allow in keyword.');\n\n        startToken = lookahead;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('[') && !match('.')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        return expr;\n    }\n\n    // 11.3 Postfix Expressions\n\n    function parsePostfixExpression() {\n        var expr, token, startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseLeftHandSideExpressionAllowCall);\n\n        if (!hasLineTerminator && lookahead.type === Token.Punctuator) {\n            if (match('++') || match('--')) {\n                // 11.3.1, 11.3.2\n                if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                    tolerateError(Messages.StrictLHSPostfix);\n                }\n\n                if (!isAssignmentTarget) {\n                    tolerateError(Messages.InvalidLHSInAssignment);\n                }\n\n                isAssignmentTarget = isBindingElement = false;\n\n                token = lex();\n                expr = new WrappingNode(startToken).finishPostfixExpression(token.value, expr);\n            }\n        }\n\n        return expr;\n    }\n\n    // 11.4 Unary Operators\n\n    function parseUnaryExpression() {\n        var token, expr, startToken;\n\n        if (lookahead.type !== Token.Punctuator && lookahead.type !== Token.Keyword) {\n            expr = parsePostfixExpression();\n        } else if (match('++') || match('--')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            // 11.4.4, 11.4.5\n            if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                tolerateError(Messages.StrictLHSPrefix);\n            }\n\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (match('+') || match('-') || match('~') || match('!')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (matchKeyword('delete') || matchKeyword('void') || matchKeyword('typeof')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            if (strict && expr.operator === 'delete' && expr.argument.type === Syntax.Identifier) {\n                tolerateError(Messages.StrictDelete);\n            }\n            isAssignmentTarget = isBindingElement = false;\n        } else {\n            expr = parsePostfixExpression();\n        }\n\n        return expr;\n    }\n\n    function binaryPrecedence(token, allowIn) {\n        var prec = 0;\n\n        if (token.type !== Token.Punctuator && token.type !== Token.Keyword) {\n            return 0;\n        }\n\n        switch (token.value) {\n        case '||':\n            prec = 1;\n            break;\n\n        case '&&':\n            prec = 2;\n            break;\n\n        case '|':\n            prec = 3;\n            break;\n\n        case '^':\n            prec = 4;\n            break;\n\n        case '&':\n            prec = 5;\n            break;\n\n        case '==':\n        case '!=':\n        case '===':\n        case '!==':\n            prec = 6;\n            break;\n\n        case '<':\n        case '>':\n        case '<=':\n        case '>=':\n        case 'instanceof':\n            prec = 7;\n            break;\n\n        case 'in':\n            prec = allowIn ? 7 : 0;\n            break;\n\n        case '<<':\n        case '>>':\n        case '>>>':\n            prec = 8;\n            break;\n\n        case '+':\n        case '-':\n            prec = 9;\n            break;\n\n        case '*':\n        case '/':\n        case '%':\n            prec = 11;\n            break;\n\n        default:\n            break;\n        }\n\n        return prec;\n    }\n\n    // 11.5 Multiplicative Operators\n    // 11.6 Additive Operators\n    // 11.7 Bitwise Shift Operators\n    // 11.8 Relational Operators\n    // 11.9 Equality Operators\n    // 11.10 Binary Bitwise Operators\n    // 11.11 Binary Logical Operators\n\n    function parseBinaryExpression() {\n        var marker, markers, expr, token, prec, stack, right, operator, left, i;\n\n        marker = lookahead;\n        left = inheritCoverGrammar(parseUnaryExpression);\n\n        token = lookahead;\n        prec = binaryPrecedence(token, state.allowIn);\n        if (prec === 0) {\n            return left;\n        }\n        isAssignmentTarget = isBindingElement = false;\n        token.prec = prec;\n        lex();\n\n        markers = [marker, lookahead];\n        right = isolateCoverGrammar(parseUnaryExpression);\n\n        stack = [left, token, right];\n\n        while ((prec = binaryPrecedence(lookahead, state.allowIn)) > 0) {\n\n            // Reduce: make a binary expression from the three topmost entries.\n            while ((stack.length > 2) && (prec <= stack[stack.length - 2].prec)) {\n                right = stack.pop();\n                operator = stack.pop().value;\n                left = stack.pop();\n                markers.pop();\n                expr = new WrappingNode(markers[markers.length - 1]).finishBinaryExpression(operator, left, right);\n                stack.push(expr);\n            }\n\n            // Shift.\n            token = lex();\n            token.prec = prec;\n            stack.push(token);\n            markers.push(lookahead);\n            expr = isolateCoverGrammar(parseUnaryExpression);\n            stack.push(expr);\n        }\n\n        // Final reduce to clean-up the stack.\n        i = stack.length - 1;\n        expr = stack[i];\n        markers.pop();\n        while (i > 1) {\n            expr = new WrappingNode(markers.pop()).finishBinaryExpression(stack[i - 1].value, stack[i - 2], expr);\n            i -= 2;\n        }\n\n        return expr;\n    }\n\n\n    // 11.12 Conditional Operator\n\n    function parseConditionalExpression() {\n        var expr, previousAllowIn, consequent, alternate, startToken;\n\n        startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseBinaryExpression);\n        if (match('?')) {\n            lex();\n            previousAllowIn = state.allowIn;\n            state.allowIn = true;\n            consequent = isolateCoverGrammar(parseAssignmentExpression);\n            state.allowIn = previousAllowIn;\n            expect(':');\n            alternate = isolateCoverGrammar(parseAssignmentExpression);\n\n            expr = new WrappingNode(startToken).finishConditionalExpression(expr, consequent, alternate);\n            isAssignmentTarget = isBindingElement = false;\n        }\n\n        return expr;\n    }\n\n    // [ES6] 14.2 Arrow Function\n\n    function parseConciseBody() {\n        if (match('{')) {\n            return parseFunctionSourceElements();\n        }\n        return isolateCoverGrammar(parseAssignmentExpression);\n    }\n\n    function checkPatternParam(options, param) {\n        var i;\n        switch (param.type) {\n        case Syntax.Identifier:\n            validateParam(options, param, param.name);\n            break;\n        case Syntax.RestElement:\n            checkPatternParam(options, param.argument);\n            break;\n        case Syntax.AssignmentPattern:\n            checkPatternParam(options, param.left);\n            break;\n        case Syntax.ArrayPattern:\n            for (i = 0; i < param.elements.length; i++) {\n                if (param.elements[i] !== null) {\n                    checkPatternParam(options, param.elements[i]);\n                }\n            }\n            break;\n        default:\n            assert(param.type === Syntax.ObjectPattern, 'Invalid type');\n            for (i = 0; i < param.properties.length; i++) {\n                checkPatternParam(options, param.properties[i].value);\n            }\n            break;\n        }\n    }\n    function reinterpretAsCoverFormalsList(expr) {\n        var i, len, param, params, defaults, defaultCount, options, token;\n\n        defaults = [];\n        defaultCount = 0;\n        params = [expr];\n\n        switch (expr.type) {\n        case Syntax.Identifier:\n            break;\n        case PlaceHolders.ArrowParameterPlaceHolder:\n            params = expr.params;\n            break;\n        default:\n            return null;\n        }\n\n        options = {\n            paramSet: {}\n        };\n\n        for (i = 0, len = params.length; i < len; i += 1) {\n            param = params[i];\n            switch (param.type) {\n            case Syntax.AssignmentPattern:\n                params[i] = param.left;\n                defaults.push(param.right);\n                ++defaultCount;\n                checkPatternParam(options, param.left);\n                break;\n            default:\n                checkPatternParam(options, param);\n                params[i] = param;\n                defaults.push(null);\n                break;\n            }\n        }\n\n        if (options.message === Messages.StrictParamDupe) {\n            token = strict ? options.stricted : options.firstRestricted;\n            throwUnexpectedToken(token, options.message);\n        }\n\n        if (defaultCount === 0) {\n            defaults = [];\n        }\n\n        return {\n            params: params,\n            defaults: defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseArrowFunctionExpression(options, node) {\n        var previousStrict, body;\n\n        if (hasLineTerminator) {\n            tolerateUnexpectedToken(lookahead);\n        }\n        expect('=>');\n        previousStrict = strict;\n\n        body = parseConciseBody();\n\n        if (strict && options.firstRestricted) {\n            throwUnexpectedToken(options.firstRestricted, options.message);\n        }\n        if (strict && options.stricted) {\n            tolerateUnexpectedToken(options.stricted, options.message);\n        }\n\n        strict = previousStrict;\n\n        return node.finishArrowFunctionExpression(options.params, options.defaults, body, body.type !== Syntax.BlockStatement);\n    }\n\n    // 11.13 Assignment Operators\n\n    function parseAssignmentExpression() {\n        var token, expr, right, list, startToken;\n\n        startToken = lookahead;\n        token = lookahead;\n\n        expr = parseConditionalExpression();\n\n        if (expr.type === PlaceHolders.ArrowParameterPlaceHolder || match('=>')) {\n            isAssignmentTarget = isBindingElement = false;\n            list = reinterpretAsCoverFormalsList(expr);\n\n            if (list) {\n                firstCoverInitializedNameError = null;\n                return parseArrowFunctionExpression(list, new WrappingNode(startToken));\n            }\n\n            return expr;\n        }\n\n        if (matchAssign()) {\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n\n            // 11.13.1\n            if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                tolerateUnexpectedToken(token, Messages.StrictLHSAssignment);\n            }\n\n            if (!match('=')) {\n                isAssignmentTarget = isBindingElement = false;\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            token = lex();\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            expr = new WrappingNode(startToken).finishAssignmentExpression(token.value, expr, right);\n            firstCoverInitializedNameError = null;\n        }\n\n        return expr;\n    }\n\n    // 11.14 Comma Operator\n\n    function parseExpression() {\n        var expr, startToken = lookahead, expressions;\n\n        expr = isolateCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n                expressions.push(isolateCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n        return expr;\n    }\n\n    // 12.1 Block\n\n    function parseStatementListItem() {\n        if (lookahead.type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'export':\n                if (sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalExportDeclaration);\n                }\n                return parseExportDeclaration();\n            case 'import':\n                if (sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalImportDeclaration);\n                }\n                return parseImportDeclaration();\n            case 'const':\n            case 'let':\n                return parseLexicalDeclaration({inFor: false});\n            case 'function':\n                return parseFunctionDeclaration(new Node());\n            case 'class':\n                return parseClassDeclaration();\n            }\n        }\n\n        return parseStatement();\n    }\n\n    function parseStatementList() {\n        var list = [];\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            list.push(parseStatementListItem());\n        }\n\n        return list;\n    }\n\n    function parseBlock() {\n        var block, node = new Node();\n\n        expect('{');\n\n        block = parseStatementList();\n\n        expect('}');\n\n        return node.finishBlockStatement(block);\n    }\n\n    // 12.2 Variable Statement\n\n    function parseVariableIdentifier() {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (token.type !== Token.Identifier) {\n            if (strict && token.type === Token.Keyword && isStrictModeReservedWord(token.value)) {\n                tolerateUnexpectedToken(token, Messages.StrictReservedWord);\n            } else {\n                throwUnexpectedToken(token);\n            }\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseVariableDeclaration() {\n        var init = null, id, node = new Node();\n\n        id = parsePattern();\n\n        // 12.2.1\n        if (strict && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (match('=')) {\n            lex();\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        } else if (id.type !== Syntax.Identifier) {\n            expect('=');\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseVariableDeclarationList() {\n        var list = [];\n\n        do {\n            list.push(parseVariableDeclaration());\n            if (!match(',')) {\n                break;\n            }\n            lex();\n        } while (startIndex < length);\n\n        return list;\n    }\n\n    function parseVariableStatement(node) {\n        var declarations;\n\n        expectKeyword('var');\n\n        declarations = parseVariableDeclarationList();\n\n        consumeSemicolon();\n\n        return node.finishVariableDeclaration(declarations);\n    }\n\n    function parseLexicalBinding(kind, options) {\n        var init = null, id, node = new Node();\n\n        id = parsePattern();\n\n        // 12.2.1\n        if (strict && id.type === Syntax.Identifier && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (kind === 'const') {\n            if (!matchKeyword('in')) {\n                expect('=');\n                init = isolateCoverGrammar(parseAssignmentExpression);\n            }\n        } else if ((!options.inFor && id.type !== Syntax.Identifier) || match('=')) {\n            expect('=');\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseBindingList(kind, options) {\n        var list = [];\n\n        do {\n            list.push(parseLexicalBinding(kind, options));\n            if (!match(',')) {\n                break;\n            }\n            lex();\n        } while (startIndex < length);\n\n        return list;\n    }\n\n    function parseLexicalDeclaration(options) {\n        var kind, declarations, node = new Node();\n\n        kind = lex().value;\n        assert(kind === 'let' || kind === 'const', 'Lexical declaration must be either let or const');\n\n        declarations = parseBindingList(kind, options);\n\n        consumeSemicolon();\n\n        return node.finishLexicalDeclaration(declarations, kind);\n    }\n\n    function parseRestElement() {\n        var param, node = new Node();\n\n        lex();\n\n        if (match('{')) {\n            throwError(Messages.ObjectPatternAsRestParameter);\n        }\n\n        param = parseVariableIdentifier();\n\n        if (match('=')) {\n            throwError(Messages.DefaultRestParameter);\n        }\n\n        if (!match(')')) {\n            throwError(Messages.ParameterAfterRestParameter);\n        }\n\n        return node.finishRestElement(param);\n    }\n\n    // 12.3 Empty Statement\n\n    function parseEmptyStatement(node) {\n        expect(';');\n        return node.finishEmptyStatement();\n    }\n\n    // 12.4 Expression Statement\n\n    function parseExpressionStatement(node) {\n        var expr = parseExpression();\n        consumeSemicolon();\n        return node.finishExpressionStatement(expr);\n    }\n\n    // 12.5 If statement\n\n    function parseIfStatement(node) {\n        var test, consequent, alternate;\n\n        expectKeyword('if');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        consequent = parseStatement();\n\n        if (matchKeyword('else')) {\n            lex();\n            alternate = parseStatement();\n        } else {\n            alternate = null;\n        }\n\n        return node.finishIfStatement(test, consequent, alternate);\n    }\n\n    // 12.6 Iteration Statements\n\n    function parseDoWhileStatement(node) {\n        var body, test, oldInIteration;\n\n        expectKeyword('do');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        if (match(';')) {\n            lex();\n        }\n\n        return node.finishDoWhileStatement(body, test);\n    }\n\n    function parseWhileStatement(node) {\n        var test, body, oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        return node.finishWhileStatement(test, body);\n    }\n\n    function parseForStatement(node) {\n        var init, initSeq, initStartToken, test, update, left, right, kind, declarations,\n            body, oldInIteration, previousAllowIn = state.allowIn;\n\n        init = test = update = null;\n\n        expectKeyword('for');\n\n        expect('(');\n\n        if (match(';')) {\n            lex();\n        } else {\n            if (matchKeyword('var')) {\n                init = new Node();\n                lex();\n\n                state.allowIn = false;\n                init = init.finishVariableDeclaration(parseVariableDeclarationList());\n                state.allowIn = previousAllowIn;\n\n                if (init.declarations.length === 1 && matchKeyword('in')) {\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    expect(';');\n                }\n            } else if (matchKeyword('const') || matchKeyword('let')) {\n                init = new Node();\n                kind = lex().value;\n\n                state.allowIn = false;\n                declarations = parseBindingList(kind, {inFor: true});\n                state.allowIn = previousAllowIn;\n\n                if (declarations.length === 1 && declarations[0].init === null && matchKeyword('in')) {\n                    init = init.finishLexicalDeclaration(declarations, kind);\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    consumeSemicolon();\n                    init = init.finishLexicalDeclaration(declarations, kind);\n                }\n            } else {\n                initStartToken = lookahead;\n                state.allowIn = false;\n                init = inheritCoverGrammar(parseAssignmentExpression);\n                state.allowIn = previousAllowIn;\n\n                if (matchKeyword('in')) {\n                    if (!isAssignmentTarget) {\n                        tolerateError(Messages.InvalidLHSInForIn);\n                    }\n\n                    lex();\n                    reinterpretExpressionAsPattern(init);\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    if (match(',')) {\n                        initSeq = [init];\n                        while (match(',')) {\n                            lex();\n                            initSeq.push(isolateCoverGrammar(parseAssignmentExpression));\n                        }\n                        init = new WrappingNode(initStartToken).finishSequenceExpression(initSeq);\n                    }\n                    expect(';');\n                }\n            }\n        }\n\n        if (typeof left === 'undefined') {\n\n            if (!match(';')) {\n                test = parseExpression();\n            }\n            expect(';');\n\n            if (!match(')')) {\n                update = parseExpression();\n            }\n        }\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = isolateCoverGrammar(parseStatement);\n\n        state.inIteration = oldInIteration;\n\n        return (typeof left === 'undefined') ?\n                node.finishForStatement(init, test, update, body) :\n                node.finishForInStatement(left, right, body);\n    }\n\n    // 12.7 The continue statement\n\n    function parseContinueStatement(node) {\n        var label = null, key;\n\n        expectKeyword('continue');\n\n        // Optimize the most common form: 'continue;'.\n        if (source.charCodeAt(startIndex) === 0x3B) {\n            lex();\n\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !state.inIteration) {\n            throwError(Messages.IllegalContinue);\n        }\n\n        return node.finishContinueStatement(label);\n    }\n\n    // 12.8 The break statement\n\n    function parseBreakStatement(node) {\n        var label = null, key;\n\n        expectKeyword('break');\n\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(lastIndex) === 0x3B) {\n            lex();\n\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n\n            return node.finishBreakStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n\n            return node.finishBreakStatement(null);\n        }\n\n        if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !(state.inIteration || state.inSwitch)) {\n            throwError(Messages.IllegalBreak);\n        }\n\n        return node.finishBreakStatement(label);\n    }\n\n    // 12.9 The return statement\n\n    function parseReturnStatement(node) {\n        var argument = null;\n\n        expectKeyword('return');\n\n        if (!state.inFunctionBody) {\n            tolerateError(Messages.IllegalReturn);\n        }\n\n        // 'return' followed by a space and an identifier is very common.\n        if (source.charCodeAt(lastIndex) === 0x20) {\n            if (isIdentifierStart(source.charCodeAt(lastIndex + 1))) {\n                argument = parseExpression();\n                consumeSemicolon();\n                return node.finishReturnStatement(argument);\n            }\n        }\n\n        if (hasLineTerminator) {\n            // HACK\n            return node.finishReturnStatement(null);\n        }\n\n        if (!match(';')) {\n            if (!match('}') && lookahead.type !== Token.EOF) {\n                argument = parseExpression();\n            }\n        }\n\n        consumeSemicolon();\n\n        return node.finishReturnStatement(argument);\n    }\n\n    // 12.10 The with statement\n\n    function parseWithStatement(node) {\n        var object, body;\n\n        if (strict) {\n            tolerateError(Messages.StrictModeWith);\n        }\n\n        expectKeyword('with');\n\n        expect('(');\n\n        object = parseExpression();\n\n        expect(')');\n\n        body = parseStatement();\n\n        return node.finishWithStatement(object, body);\n    }\n\n    // 12.10 The swith statement\n\n    function parseSwitchCase() {\n        var test, consequent = [], statement, node = new Node();\n\n        if (matchKeyword('default')) {\n            lex();\n            test = null;\n        } else {\n            expectKeyword('case');\n            test = parseExpression();\n        }\n        expect(':');\n\n        while (startIndex < length) {\n            if (match('}') || matchKeyword('default') || matchKeyword('case')) {\n                break;\n            }\n            statement = parseStatementListItem();\n            consequent.push(statement);\n        }\n\n        return node.finishSwitchCase(test, consequent);\n    }\n\n    function parseSwitchStatement(node) {\n        var discriminant, cases, clause, oldInSwitch, defaultFound;\n\n        expectKeyword('switch');\n\n        expect('(');\n\n        discriminant = parseExpression();\n\n        expect(')');\n\n        expect('{');\n\n        cases = [];\n\n        if (match('}')) {\n            lex();\n            return node.finishSwitchStatement(discriminant, cases);\n        }\n\n        oldInSwitch = state.inSwitch;\n        state.inSwitch = true;\n        defaultFound = false;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            clause = parseSwitchCase();\n            if (clause.test === null) {\n                if (defaultFound) {\n                    throwError(Messages.MultipleDefaultsInSwitch);\n                }\n                defaultFound = true;\n            }\n            cases.push(clause);\n        }\n\n        state.inSwitch = oldInSwitch;\n\n        expect('}');\n\n        return node.finishSwitchStatement(discriminant, cases);\n    }\n\n    // 12.13 The throw statement\n\n    function parseThrowStatement(node) {\n        var argument;\n\n        expectKeyword('throw');\n\n        if (hasLineTerminator) {\n            throwError(Messages.NewlineAfterThrow);\n        }\n\n        argument = parseExpression();\n\n        consumeSemicolon();\n\n        return node.finishThrowStatement(argument);\n    }\n\n    // 12.14 The try statement\n\n    function parseCatchClause() {\n        var param, body, node = new Node();\n\n        expectKeyword('catch');\n\n        expect('(');\n        if (match(')')) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        param = parsePattern();\n\n        // 12.14.1\n        if (strict && isRestrictedWord(param.name)) {\n            tolerateError(Messages.StrictCatchVariable);\n        }\n\n        expect(')');\n        body = parseBlock();\n        return node.finishCatchClause(param, body);\n    }\n\n    function parseTryStatement(node) {\n        var block, handler = null, finalizer = null;\n\n        expectKeyword('try');\n\n        block = parseBlock();\n\n        if (matchKeyword('catch')) {\n            handler = parseCatchClause();\n        }\n\n        if (matchKeyword('finally')) {\n            lex();\n            finalizer = parseBlock();\n        }\n\n        if (!handler && !finalizer) {\n            throwError(Messages.NoCatchOrFinally);\n        }\n\n        return node.finishTryStatement(block, handler, finalizer);\n    }\n\n    // 12.15 The debugger statement\n\n    function parseDebuggerStatement(node) {\n        expectKeyword('debugger');\n\n        consumeSemicolon();\n\n        return node.finishDebuggerStatement();\n    }\n\n    // 12 Statements\n\n    function parseStatement() {\n        var type = lookahead.type,\n            expr,\n            labeledBody,\n            key,\n            node;\n\n        if (type === Token.EOF) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        if (type === Token.Punctuator && lookahead.value === '{') {\n            return parseBlock();\n        }\n        isAssignmentTarget = isBindingElement = true;\n        node = new Node();\n\n        if (type === Token.Punctuator) {\n            switch (lookahead.value) {\n            case ';':\n                return parseEmptyStatement(node);\n            case '(':\n                return parseExpressionStatement(node);\n            default:\n                break;\n            }\n        } else if (type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'break':\n                return parseBreakStatement(node);\n            case 'continue':\n                return parseContinueStatement(node);\n            case 'debugger':\n                return parseDebuggerStatement(node);\n            case 'do':\n                return parseDoWhileStatement(node);\n            case 'for':\n                return parseForStatement(node);\n            case 'function':\n                return parseFunctionDeclaration(node);\n            case 'if':\n                return parseIfStatement(node);\n            case 'return':\n                return parseReturnStatement(node);\n            case 'switch':\n                return parseSwitchStatement(node);\n            case 'throw':\n                return parseThrowStatement(node);\n            case 'try':\n                return parseTryStatement(node);\n            case 'var':\n                return parseVariableStatement(node);\n            case 'while':\n                return parseWhileStatement(node);\n            case 'with':\n                return parseWithStatement(node);\n            default:\n                break;\n            }\n        }\n\n        expr = parseExpression();\n\n        // 12.12 Labelled Statements\n        if ((expr.type === Syntax.Identifier) && match(':')) {\n            lex();\n\n            key = '$' + expr.name;\n            if (Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.Redeclaration, 'Label', expr.name);\n            }\n\n            state.labelSet[key] = true;\n            labeledBody = parseStatement();\n            delete state.labelSet[key];\n            return node.finishLabeledStatement(expr, labeledBody);\n        }\n\n        consumeSemicolon();\n\n        return node.finishExpressionStatement(expr);\n    }\n\n    // 13 Function Definition\n\n    function parseFunctionSourceElements() {\n        var statement, body = [], token, directive, firstRestricted,\n            oldLabelSet, oldInIteration, oldInSwitch, oldInFunctionBody, oldParenthesisCount,\n            node = new Node();\n\n        expect('{');\n\n        while (startIndex < length) {\n            if (lookahead.type !== Token.StringLiteral) {\n                break;\n            }\n            token = lookahead;\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        oldLabelSet = state.labelSet;\n        oldInIteration = state.inIteration;\n        oldInSwitch = state.inSwitch;\n        oldInFunctionBody = state.inFunctionBody;\n        oldParenthesisCount = state.parenthesizedCount;\n\n        state.labelSet = {};\n        state.inIteration = false;\n        state.inSwitch = false;\n        state.inFunctionBody = true;\n        state.parenthesizedCount = 0;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            body.push(parseStatementListItem());\n        }\n\n        expect('}');\n\n        state.labelSet = oldLabelSet;\n        state.inIteration = oldInIteration;\n        state.inSwitch = oldInSwitch;\n        state.inFunctionBody = oldInFunctionBody;\n        state.parenthesizedCount = oldParenthesisCount;\n\n        return node.finishBlockStatement(body);\n    }\n\n    function validateParam(options, param, name) {\n        var key = '$' + name;\n        if (strict) {\n            if (isRestrictedWord(name)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamName;\n            }\n            if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        } else if (!options.firstRestricted) {\n            if (isRestrictedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictParamName;\n            } else if (isStrictModeReservedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictReservedWord;\n            } else if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        }\n        options.paramSet[key] = true;\n    }\n\n    function parseParam(options) {\n        var token, param, def;\n\n        token = lookahead;\n        if (token.value === '...') {\n            param = parseRestElement();\n            validateParam(options, param.argument, param.argument.name);\n            options.params.push(param);\n            options.defaults.push(null);\n            return false;\n        }\n\n        param = parsePatternWithDefault();\n        validateParam(options, token, token.value);\n\n        if (param.type === Syntax.AssignmentPattern) {\n            def = param.right;\n            param = param.left;\n            ++options.defaultCount;\n        }\n\n        options.params.push(param);\n        options.defaults.push(def);\n\n        return !match(')');\n    }\n\n    function parseParams(firstRestricted) {\n        var options;\n\n        options = {\n            params: [],\n            defaultCount: 0,\n            defaults: [],\n            firstRestricted: firstRestricted\n        };\n\n        expect('(');\n\n        if (!match(')')) {\n            options.paramSet = {};\n            while (startIndex < length) {\n                if (!parseParam(options)) {\n                    break;\n                }\n                expect(',');\n            }\n        }\n\n        expect(')');\n\n        if (options.defaultCount === 0) {\n            options.defaults = [];\n        }\n\n        return {\n            params: options.params,\n            defaults: options.defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseFunctionDeclaration(node, identifierIsOptional) {\n        var id = null, params = [], defaults = [], body, token, stricted, tmp, firstRestricted, message, previousStrict;\n\n        expectKeyword('function');\n        if (!identifierIsOptional || !match('(')) {\n            token = lookahead;\n            id = parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n        strict = previousStrict;\n\n        return node.finishFunctionDeclaration(id, params, defaults, body);\n    }\n\n    function parseFunctionExpression() {\n        var token, id = null, stricted, firstRestricted, message, tmp,\n            params = [], defaults = [], body, previousStrict, node = new Node();\n\n        expectKeyword('function');\n\n        if (!match('(')) {\n            token = lookahead;\n            id = parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n        strict = previousStrict;\n\n        return node.finishFunctionExpression(id, params, defaults, body);\n    }\n\n\n    function parseClassBody() {\n        var classBody, token, isStatic, hasConstructor = false, body, method, computed, key;\n\n        classBody = new Node();\n\n        expect('{');\n        body = [];\n        while (!match('}')) {\n            if (match(';')) {\n                lex();\n            } else {\n                method = new Node();\n                token = lookahead;\n                isStatic = false;\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                if (key.name === 'static' && lookaheadPropertyName()) {\n                    token = lookahead;\n                    isStatic = true;\n                    computed = match('[');\n                    key = parseObjectPropertyKey();\n                }\n                method = tryParseMethodDefinition(token, key, computed, method);\n                if (method) {\n                    method['static'] = isStatic;\n                    if (method.kind === 'init') {\n                        method.kind = 'method';\n                    }\n                    if (!isStatic) {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'constructor') {\n                            if (method.kind !== 'method' || !method.method || method.value.generator) {\n                                throwUnexpectedToken(token, Messages.ConstructorSpecialMethod);\n                            }\n                            if (hasConstructor) {\n                                throwUnexpectedToken(token, Messages.DuplicateConstructor);\n                            } else {\n                                hasConstructor = true;\n                            }\n                            method.kind = 'constructor';\n                        }\n                    } else {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'prototype') {\n                            throwUnexpectedToken(token, Messages.StaticPrototype);\n                        }\n                    }\n                    method.type = Syntax.MethodDefinition;\n                    delete method.method;\n                    delete method.shorthand;\n                    body.push(method);\n                } else {\n                    throwUnexpectedToken(lookahead);\n                }\n            }\n        }\n        lex();\n        return classBody.finishClassBody(body);\n    }\n\n    function parseClassDeclaration(identifierIsOptional) {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (!identifierIsOptional || lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassDeclaration(id, superClass, classBody);\n    }\n\n    function parseClassExpression() {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassExpression(id, superClass, classBody);\n    }\n\n    // Modules grammar from:\n    // people.mozilla.org/~jorendorff/es6-draft.html\n\n    function parseModuleSpecifier() {\n        var node = new Node();\n\n        if (lookahead.type !== Token.StringLiteral) {\n            throwError(Messages.InvalidModuleSpecifier);\n        }\n        return node.finishLiteral(lex());\n    }\n\n    function parseExportSpecifier() {\n        var exported, local, node = new Node(), def;\n        if (matchKeyword('default')) {\n            // export {default} from 'something';\n            def = new Node();\n            lex();\n            local = def.finishIdentifier('default');\n        } else {\n            local = parseVariableIdentifier();\n        }\n        if (matchContextualKeyword('as')) {\n            lex();\n            exported = parseNonComputedProperty();\n        }\n        return node.finishExportSpecifier(local, exported);\n    }\n\n    function parseExportNamedDeclaration(node) {\n        var declaration = null,\n            isExportFromIdentifier,\n            src = null, specifiers = [];\n\n        // non-default export\n        if (lookahead.type === Token.Keyword) {\n            // covers:\n            // export var f = 1;\n            switch (lookahead.value) {\n                case 'let':\n                case 'const':\n                case 'var':\n                case 'class':\n                case 'function':\n                    declaration = parseStatementListItem();\n                    return node.finishExportNamedDeclaration(declaration, specifiers, null);\n            }\n        }\n\n        expect('{');\n        if (!match('}')) {\n            do {\n                isExportFromIdentifier = isExportFromIdentifier || matchKeyword('default');\n                specifiers.push(parseExportSpecifier());\n            } while (match(',') && lex());\n        }\n        expect('}');\n\n        if (matchContextualKeyword('from')) {\n            // covering:\n            // export {default} from 'foo';\n            // export {foo} from 'foo';\n            lex();\n            src = parseModuleSpecifier();\n            consumeSemicolon();\n        } else if (isExportFromIdentifier) {\n            // covering:\n            // export {default}; // missing fromClause\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        } else {\n            // cover\n            // export {foo};\n            consumeSemicolon();\n        }\n        return node.finishExportNamedDeclaration(declaration, specifiers, src);\n    }\n\n    function parseExportDefaultDeclaration(node) {\n        var declaration = null,\n            expression = null;\n\n        // covers:\n        // export default ...\n        expectKeyword('default');\n\n        if (matchKeyword('function')) {\n            // covers:\n            // export default function foo () {}\n            // export default function () {}\n            declaration = parseFunctionDeclaration(new Node(), true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n        if (matchKeyword('class')) {\n            declaration = parseClassDeclaration(true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n\n        if (matchContextualKeyword('from')) {\n            throwError(Messages.UnexpectedToken, lookahead.value);\n        }\n\n        // covers:\n        // export default {};\n        // export default [];\n        // export default (1 + 2);\n        if (match('{')) {\n            expression = parseObjectInitialiser();\n        } else if (match('[')) {\n            expression = parseArrayInitialiser();\n        } else {\n            expression = parseAssignmentExpression();\n        }\n        consumeSemicolon();\n        return node.finishExportDefaultDeclaration(expression);\n    }\n\n    function parseExportAllDeclaration(node) {\n        var src;\n\n        // covers:\n        // export * from 'foo';\n        expect('*');\n        if (!matchContextualKeyword('from')) {\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        }\n        lex();\n        src = parseModuleSpecifier();\n        consumeSemicolon();\n\n        return node.finishExportAllDeclaration(src);\n    }\n\n    function parseExportDeclaration() {\n        var node = new Node();\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalExportDeclaration);\n        }\n\n        expectKeyword('export');\n\n        if (matchKeyword('default')) {\n            return parseExportDefaultDeclaration(node);\n        }\n        if (match('*')) {\n            return parseExportAllDeclaration(node);\n        }\n        return parseExportNamedDeclaration(node);\n    }\n\n    function parseImportSpecifier() {\n        // import {<foo as bar>} ...;\n        var local, imported, node = new Node();\n\n        imported = parseNonComputedProperty();\n        if (matchContextualKeyword('as')) {\n            lex();\n            local = parseVariableIdentifier();\n        }\n\n        return node.finishImportSpecifier(local, imported);\n    }\n\n    function parseNamedImports() {\n        var specifiers = [];\n        // {foo, bar as bas}\n        expect('{');\n        if (!match('}')) {\n            do {\n                specifiers.push(parseImportSpecifier());\n            } while (match(',') && lex());\n        }\n        expect('}');\n        return specifiers;\n    }\n\n    function parseImportDefaultSpecifier() {\n        // import <foo> ...;\n        var local, node = new Node();\n\n        local = parseNonComputedProperty();\n\n        return node.finishImportDefaultSpecifier(local);\n    }\n\n    function parseImportNamespaceSpecifier() {\n        // import <* as foo> ...;\n        var local, node = new Node();\n\n        expect('*');\n        if (!matchContextualKeyword('as')) {\n            throwError(Messages.NoAsAfterImportNamespace);\n        }\n        lex();\n        local = parseNonComputedProperty();\n\n        return node.finishImportNamespaceSpecifier(local);\n    }\n\n    function parseImportDeclaration() {\n        var specifiers, src, node = new Node();\n\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalImportDeclaration);\n        }\n\n        expectKeyword('import');\n        specifiers = [];\n\n        if (lookahead.type === Token.StringLiteral) {\n            // covers:\n            // import 'foo';\n            src = parseModuleSpecifier();\n            consumeSemicolon();\n            return node.finishImportDeclaration(specifiers, src);\n        }\n\n        if (!matchKeyword('default') && isIdentifierName(lookahead)) {\n            // covers:\n            // import foo\n            // import foo, ...\n            specifiers.push(parseImportDefaultSpecifier());\n            if (match(',')) {\n                lex();\n            }\n        }\n        if (match('*')) {\n            // covers:\n            // import foo, * as foo\n            // import * as foo\n            specifiers.push(parseImportNamespaceSpecifier());\n        } else if (match('{')) {\n            // covers:\n            // import foo, {bar}\n            // import {bar}\n            specifiers = specifiers.concat(parseNamedImports());\n        }\n\n        if (!matchContextualKeyword('from')) {\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        }\n        lex();\n        src = parseModuleSpecifier();\n        consumeSemicolon();\n\n        return node.finishImportDeclaration(specifiers, src);\n    }\n\n    // 14 Program\n\n    function parseScriptBody() {\n        var statement, body = [], token, directive, firstRestricted;\n\n        while (startIndex < length) {\n            token = lookahead;\n            if (token.type !== Token.StringLiteral) {\n                break;\n            }\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        while (startIndex < length) {\n            statement = parseStatementListItem();\n            /* istanbul ignore if */\n            if (typeof statement === 'undefined') {\n                break;\n            }\n            body.push(statement);\n        }\n        return body;\n    }\n\n    function parseProgram() {\n        var body, node;\n\n        peek();\n        node = new Node();\n\n        body = parseScriptBody();\n        return node.finishProgram(body);\n    }\n\n    function filterTokenLocation() {\n        var i, entry, token, tokens = [];\n\n        for (i = 0; i < extra.tokens.length; ++i) {\n            entry = extra.tokens[i];\n            token = {\n                type: entry.type,\n                value: entry.value\n            };\n            if (entry.regex) {\n                token.regex = {\n                    pattern: entry.regex.pattern,\n                    flags: entry.regex.flags\n                };\n            }\n            if (extra.range) {\n                token.range = entry.range;\n            }\n            if (extra.loc) {\n                token.loc = entry.loc;\n            }\n            tokens.push(token);\n        }\n\n        extra.tokens = tokens;\n    }\n\n    function tokenize(code, options) {\n        var toString,\n            tokens;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: []\n        };\n\n        extra = {};\n\n        // Options matching.\n        options = options || {};\n\n        // Of course we collect tokens here.\n        options.tokens = true;\n        extra.tokens = [];\n        extra.tokenize = true;\n        // The following two fields are necessary to compute the Regex tokens.\n        extra.openParenToken = -1;\n        extra.openCurlyToken = -1;\n\n        extra.range = (typeof options.range === 'boolean') && options.range;\n        extra.loc = (typeof options.loc === 'boolean') && options.loc;\n\n        if (typeof options.comment === 'boolean' && options.comment) {\n            extra.comments = [];\n        }\n        if (typeof options.tolerant === 'boolean' && options.tolerant) {\n            extra.errors = [];\n        }\n\n        try {\n            peek();\n            if (lookahead.type === Token.EOF) {\n                return extra.tokens;\n            }\n\n            lex();\n            while (lookahead.type !== Token.EOF) {\n                try {\n                    lex();\n                } catch (lexError) {\n                    if (extra.errors) {\n                        recordError(lexError);\n                        // We have to break on the first error\n                        // to avoid infinite loops.\n                        break;\n                    } else {\n                        throw lexError;\n                    }\n                }\n            }\n\n            filterTokenLocation();\n            tokens = extra.tokens;\n            if (typeof extra.comments !== 'undefined') {\n                tokens.comments = extra.comments;\n            }\n            if (typeof extra.errors !== 'undefined') {\n                tokens.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n        return tokens;\n    }\n\n    function parse(code, options) {\n        var program, toString;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: []\n        };\n        sourceType = 'script';\n        strict = false;\n\n        extra = {};\n        if (typeof options !== 'undefined') {\n            extra.range = (typeof options.range === 'boolean') && options.range;\n            extra.loc = (typeof options.loc === 'boolean') && options.loc;\n            extra.attachComment = (typeof options.attachComment === 'boolean') && options.attachComment;\n\n            if (extra.loc && options.source !== null && options.source !== undefined) {\n                extra.source = toString(options.source);\n            }\n\n            if (typeof options.tokens === 'boolean' && options.tokens) {\n                extra.tokens = [];\n            }\n            if (typeof options.comment === 'boolean' && options.comment) {\n                extra.comments = [];\n            }\n            if (typeof options.tolerant === 'boolean' && options.tolerant) {\n                extra.errors = [];\n            }\n            if (extra.attachComment) {\n                extra.range = true;\n                extra.comments = [];\n                extra.bottomRightStack = [];\n                extra.trailingComments = [];\n                extra.leadingComments = [];\n            }\n            if (options.sourceType === 'module') {\n                // very restrictive condition for now\n                sourceType = options.sourceType;\n                strict = true;\n            }\n        }\n\n        try {\n            program = parseProgram();\n            if (typeof extra.comments !== 'undefined') {\n                program.comments = extra.comments;\n            }\n            if (typeof extra.tokens !== 'undefined') {\n                filterTokenLocation();\n                program.tokens = extra.tokens;\n            }\n            if (typeof extra.errors !== 'undefined') {\n                program.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n\n        return program;\n    }\n\n    // Sync with *.json manifests.\n    exports.version = '2.2.0';\n\n    exports.tokenize = tokenize;\n\n    exports.parse = parse;\n\n    // Deep copy.\n    /* istanbul ignore next */\n    exports.Syntax = (function () {\n        var name, types = {};\n\n        if (typeof Object.create === 'function') {\n            types = Object.create(null);\n        }\n\n        for (name in Syntax) {\n            if (Syntax.hasOwnProperty(name)) {\n                types[name] = Syntax[name];\n            }\n        }\n\n        if (typeof Object.freeze === 'function') {\n            Object.freeze(types);\n        }\n\n        return types;\n    }());\n\n}));\n/* vim: set sw=4 ts=4 et tw=80 : */\n","/*\r\n* loglevel - https://github.com/pimterry/loglevel\r\n*\r\n* Copyright (c) 2013 Tim Perry\r\n* Licensed under the MIT license.\r\n*/\r\n(function (root, definition) {\r\n    if (typeof module === 'object' && module.exports && typeof require === 'function') {\r\n        module.exports = definition();\r\n    } else if (typeof define === 'function' && typeof define.amd === 'object') {\r\n        define(definition);\r\n    } else {\r\n        root.log = definition();\r\n    }\r\n}(this, function () {\r\n    var self = {};\r\n    var noop = function() {};\r\n    var undefinedType = \"undefined\";\r\n\r\n    function realMethod(methodName) {\r\n        if (typeof console === undefinedType) {\r\n            return false; // We can't build a real method without a console to log to\r\n        } else if (console[methodName] !== undefined) {\r\n            return bindMethod(console, methodName);\r\n        } else if (console.log !== undefined) {\r\n            return bindMethod(console, 'log');\r\n        } else {\r\n            return noop;\r\n        }\r\n    }\r\n\r\n    function bindMethod(obj, methodName) {\r\n        var method = obj[methodName];\r\n        if (typeof method.bind === 'function') {\r\n            return method.bind(obj);\r\n        } else {\r\n            try {\r\n                return Function.prototype.bind.call(method, obj);\r\n            } catch (e) {\r\n                // Missing bind shim or IE8 + Modernizr, fallback to wrapping\r\n                return function() {\r\n                    return Function.prototype.apply.apply(method, [obj, arguments]);\r\n                };\r\n            }\r\n        }\r\n    }\r\n\r\n    function enableLoggingWhenConsoleArrives(methodName, level) {\r\n        return function () {\r\n            if (typeof console !== undefinedType) {\r\n                replaceLoggingMethods(level);\r\n                self[methodName].apply(self, arguments);\r\n            }\r\n        };\r\n    }\r\n\r\n    var logMethods = [\r\n        \"trace\",\r\n        \"debug\",\r\n        \"info\",\r\n        \"warn\",\r\n        \"error\"\r\n    ];\r\n\r\n    function replaceLoggingMethods(level) {\r\n        for (var i = 0; i < logMethods.length; i++) {\r\n            var methodName = logMethods[i];\r\n            self[methodName] = (i < level) ? noop : self.methodFactory(methodName, level);\r\n        }\r\n    }\r\n\r\n    function persistLevelIfPossible(levelNum) {\r\n        var levelName = (logMethods[levelNum] || 'silent').toUpperCase();\r\n\r\n        // Use localStorage if available\r\n        try {\r\n            window.localStorage['loglevel'] = levelName;\r\n            return;\r\n        } catch (ignore) {}\r\n\r\n        // Use session cookie as fallback\r\n        try {\r\n            window.document.cookie = \"loglevel=\" + levelName + \";\";\r\n        } catch (ignore) {}\r\n    }\r\n\r\n    function loadPersistedLevel() {\r\n        var storedLevel;\r\n\r\n        try {\r\n            storedLevel = window.localStorage['loglevel'];\r\n        } catch (ignore) {}\r\n\r\n        if (typeof storedLevel === undefinedType) {\r\n            try {\r\n                storedLevel = /loglevel=([^;]+)/.exec(window.document.cookie)[1];\r\n            } catch (ignore) {}\r\n        }\r\n        \r\n        if (self.levels[storedLevel] === undefined) {\r\n            storedLevel = \"WARN\";\r\n        }\r\n\r\n        self.setLevel(self.levels[storedLevel]);\r\n    }\r\n\r\n    /*\r\n     *\r\n     * Public API\r\n     *\r\n     */\r\n\r\n    self.levels = { \"TRACE\": 0, \"DEBUG\": 1, \"INFO\": 2, \"WARN\": 3,\r\n        \"ERROR\": 4, \"SILENT\": 5};\r\n\r\n    self.methodFactory = function (methodName, level) {\r\n        return realMethod(methodName) ||\r\n               enableLoggingWhenConsoleArrives(methodName, level);\r\n    };\r\n\r\n    self.setLevel = function (level) {\r\n        if (typeof level === \"string\" && self.levels[level.toUpperCase()] !== undefined) {\r\n            level = self.levels[level.toUpperCase()];\r\n        }\r\n        if (typeof level === \"number\" && level >= 0 && level <= self.levels.SILENT) {\r\n            persistLevelIfPossible(level);\r\n            replaceLoggingMethods(level);\r\n            if (typeof console === undefinedType && level < self.levels.SILENT) {\r\n                return \"No console available for logging\";\r\n            }\r\n        } else {\r\n            throw \"log.setLevel() called with invalid level: \" + level;\r\n        }\r\n    };\r\n\r\n    self.enableAll = function() {\r\n        self.setLevel(self.levels.TRACE);\r\n    };\r\n\r\n    self.disableAll = function() {\r\n        self.setLevel(self.levels.SILENT);\r\n    };\r\n\r\n    // Grab the current global log variable in case of overwrite\r\n    var _log = (typeof window !== undefinedType) ? window.log : undefined;\r\n    self.noConflict = function() {\r\n        if (typeof window !== undefinedType &&\r\n               window.log === self) {\r\n            window.log = _log;\r\n        }\r\n\r\n        return self;\r\n    };\r\n\r\n    loadPersistedLevel();\r\n    return self;\r\n}));\r\n","'use strict';\n\nvar whiteList = ['not', 'any', 'all', 'none'];\n\n\nfunction notNull(x)  { return x != null; }\nfunction toString(x) { return x.toString(); }\nfunction wrap(x)     { return '(' + x + ')';}\n\nfunction maybeQuote(value) {\n    if (typeof value === 'string') {\n        return '\"' + value + '\"';\n    }\n    return value;\n}\n\nfunction lookUp(key) {\n    if (key.lastIndexOf('$') === 0) {\n        return 'context.' + key.substring(1);\n    }\n    return 'context.feature.properties.' + key;\n}\n\nfunction nullValue(key, value) {\n    return {\n        type: 'nullValue',\n        key: key,\n        toString: function () {\n            return ' true ';\n        }\n    };\n}\n\nfunction propertyEqual(key, value) {\n    return {\n        type: 'propertyEqual',\n        opt: '===' ,\n        key: key,\n        value: value,\n        toString: function () {\n            return wrap(maybeQuote(this.value) + ' ' + this.opt + ' ' + lookUp(key));\n        }\n    };\n}\n\nfunction propertyOr(key, values) {\n    return {\n        type: 'propertyOr',\n        key: key,\n        values: values.map(function (x) { return propertyEqual(key, x); }),\n        toString: function () {\n            return wrap(this.values.map(toString).join(' || '));\n        }\n    };\n}\n\nfunction not(key, value) {\n    return {\n        type: 'notProperty',\n        key: key,\n        value: parseFilter(value),\n        toString: function () {\n            return '!' + wrap(this.value.toString());\n        }\n    };\n}\n\nfunction none(key, values) {\n    return {\n        type: 'none',\n        values: any(null, values),\n        toString: function () {\n            return '!' + wrap(this.values.toString());\n        }\n    };\n}\n\nfunction printNested(values, joiner) {\n    return wrap(values.filter(notNull).map(function (x) {\n        return wrap(x.join(' && '));\n    }).join(' ' + joiner + ' '));\n}\n\nfunction any(_, values) {\n    return {\n        type: 'any',\n        values: values.map(parseFilter),\n        toString: function () {\n            return printNested(this.values, '||');\n        }\n    };\n}\n\nfunction all(_, values) {\n    return {\n        type: 'all',\n        values: values.filter(notNull).map(parseFilter),\n        toString: function () {\n            return printNested(this.values, '&&');\n        }\n    };\n}\n\nfunction propertyMatchesBoolean(key, value) {\n    return {\n        type: 'propertyMatchesBoolean',\n        key: key,\n        value: value,\n        toString: function () {\n            return wrap(lookUp(this.key) + (this.value ? ' != ' : ' == ')  + 'null');\n        }\n    };\n}\n\nfunction rangeMatch(key, values) {\n    return {\n        type: 'rangeMatch',\n        key: key,\n        values: values,\n        toString: function () {\n            var expressions = [];\n\n            if (this.values.max) {\n                expressions.push('' + lookUp(key) + ' < ' + this.values.max);\n            }\n\n            if (this.values.min) {\n                expressions.push('' + lookUp(key) + ' >= ' + this.values.min);\n            }\n\n            return wrap(expressions.join(' && '));\n        }\n    };\n}\n\nfunction parseFilter(filter) {\n    var filterAST = [];\n\n    // Function filter\n    if (typeof filter === 'function') {\n        filterAST.push(wrap(filter.toString() + '(context)'));\n        return filterAST;\n    }\n\n    // Object filter\n    var keys = Object.keys(filter);\n    keys.forEach(function (key, idx) {\n\n        var value = filter[key],\n            type  = typeof value;\n        if (type === 'string' || type === 'number') {\n            filterAST.push(propertyEqual(key, value));\n        } else if (type === 'boolean') {\n            filterAST.push(propertyMatchesBoolean(key, value));\n        } else if (value == null) {\n            filterAST.push(nullValue(key, value));\n        } else if (whiteList.indexOf(key) >= 0) {\n            switch (key) {\n            case 'not':\n                filterAST.push(not(key, value));\n                break;\n            case 'any':\n                filterAST.push(any(key, value));\n                break;\n            case 'all':\n                filterAST.push(all(key, value));\n                break;\n            case 'none':\n                filterAST.push(none(key, value));\n                break;\n            default:\n                throw new Error('Unhandled WhiteListed property: ' + key);\n            }\n        } else if (Array.isArray(value)) {\n            filterAST.push(propertyOr(key, value));\n        } else if (type === 'object' && value != null) {\n            if (value.max || value.min) {\n                filterAST.push(rangeMatch(key, value));\n            }\n        } else {\n            throw new Error('Unknown Query sytnax: ' + value);\n        }\n    });\n\n    return keys.length === 0 ? ['true'] : filterAST;\n}\n\nfunction filterToString(filterAST) {\n    return wrap(filterAST.join(' && '));\n}\n\nfunction match(filter) {\n    if (filter == null) { return function () { return true; }; }\n    // jshint evil: true\n    return new Function('context', 'return ' + filterToString(parseFilter(filter)) + ';');\n}\n\nmodule.exports = {\n    match: match,\n    filterToString: filterToString,\n    parseFilter: parseFilter\n};\n","'use strict';\n\n// lightweight Buffer shim for pbf browser build\n// based on code from github.com/feross/buffer (MIT-licensed)\n\nmodule.exports = Buffer;\n\nvar ieee754 = require('ieee754');\n\nvar BufferMethods;\n\nfunction Buffer(length) {\n    var arr;\n    if (length && length.length) {\n        arr = length;\n        length = arr.length;\n    }\n    var buf = new Uint8Array(length || 0);\n    if (arr) buf.set(arr);\n\n    buf.readUInt32LE = BufferMethods.readUInt32LE;\n    buf.writeUInt32LE = BufferMethods.writeUInt32LE;\n    buf.readInt32LE = BufferMethods.readInt32LE;\n    buf.writeInt32LE = BufferMethods.writeInt32LE;\n    buf.readFloatLE = BufferMethods.readFloatLE;\n    buf.writeFloatLE = BufferMethods.writeFloatLE;\n    buf.readDoubleLE = BufferMethods.readDoubleLE;\n    buf.writeDoubleLE = BufferMethods.writeDoubleLE;\n    buf.toString = BufferMethods.toString;\n    buf.write = BufferMethods.write;\n    buf.slice = BufferMethods.slice;\n    buf.copy = BufferMethods.copy;\n\n    buf._isBuffer = true;\n    return buf;\n}\n\nvar lastStr, lastStrEncoded;\n\nBufferMethods = {\n    readUInt32LE: function(pos) {\n        return ((this[pos]) |\n            (this[pos + 1] << 8) |\n            (this[pos + 2] << 16)) +\n            (this[pos + 3] * 0x1000000);\n    },\n\n    writeUInt32LE: function(val, pos) {\n        this[pos] = val;\n        this[pos + 1] = (val >>> 8);\n        this[pos + 2] = (val >>> 16);\n        this[pos + 3] = (val >>> 24);\n    },\n\n    readInt32LE: function(pos) {\n        return ((this[pos]) |\n            (this[pos + 1] << 8) |\n            (this[pos + 2] << 16)) +\n            (this[pos + 3] << 24);\n    },\n\n    readFloatLE:  function(pos) { return ieee754.read(this, pos, true, 23, 4); },\n    readDoubleLE: function(pos) { return ieee754.read(this, pos, true, 52, 8); },\n\n    writeFloatLE:  function(val, pos) { return ieee754.write(this, val, pos, true, 23, 4); },\n    writeDoubleLE: function(val, pos) { return ieee754.write(this, val, pos, true, 52, 8); },\n\n    toString: function(encoding, start, end) {\n        var str = '',\n            tmp = '';\n\n        start = start || 0;\n        end = Math.min(this.length, end || this.length);\n\n        for (var i = start; i < end; i++) {\n            var ch = this[i];\n            if (ch <= 0x7F) {\n                str += decodeURIComponent(tmp) + String.fromCharCode(ch);\n                tmp = '';\n            } else {\n                tmp += '%' + ch.toString(16);\n            }\n        }\n\n        str += decodeURIComponent(tmp);\n\n        return str;\n    },\n\n    write: function(str, pos) {\n        var bytes = str === lastStr ? lastStrEncoded : encodeString(str);\n        for (var i = 0; i < bytes.length; i++) {\n            this[pos + i] = bytes[i];\n        }\n    },\n\n    slice: function(start, end) {\n        return this.subarray(start, end);\n    },\n\n    copy: function(buf, pos) {\n        pos = pos || 0;\n        for (var i = 0; i < this.length; i++) {\n            buf[pos + i] = this[i];\n        }\n    }\n};\n\nBufferMethods.writeInt32LE = BufferMethods.writeUInt32LE;\n\nBuffer.byteLength = function(str) {\n    lastStr = str;\n    lastStrEncoded = encodeString(str);\n    return lastStrEncoded.length;\n};\n\nBuffer.isBuffer = function(buf) {\n    return !!(buf && buf._isBuffer);\n};\n\nfunction encodeString(str) {\n    var length = str.length,\n        bytes = [];\n\n    for (var i = 0, c, lead; i < length; i++) {\n        c = str.charCodeAt(i); // code point\n\n        if (c > 0xD7FF && c < 0xE000) {\n\n            if (lead) {\n                if (c < 0xDC00) {\n                    bytes.push(0xEF, 0xBF, 0xBD);\n                    lead = c;\n                    continue;\n\n                } else {\n                    c = lead - 0xD800 << 10 | c - 0xDC00 | 0x10000;\n                    lead = null;\n                }\n\n            } else {\n                if (c > 0xDBFF || (i + 1 === length)) bytes.push(0xEF, 0xBF, 0xBD);\n                else lead = c;\n\n                continue;\n            }\n\n        } else if (lead) {\n            bytes.push(0xEF, 0xBF, 0xBD);\n            lead = null;\n        }\n\n        if (c < 0x80) bytes.push(c);\n        else if (c < 0x800) bytes.push(c >> 0x6 | 0xC0, c & 0x3F | 0x80);\n        else if (c < 0x10000) bytes.push(c >> 0xC | 0xE0, c >> 0x6 & 0x3F | 0x80, c & 0x3F | 0x80);\n        else bytes.push(c >> 0x12 | 0xF0, c >> 0xC & 0x3F | 0x80, c >> 0x6 & 0x3F | 0x80, c & 0x3F | 0x80);\n    }\n    return bytes;\n}\n","(function (global){\n'use strict';\n\nmodule.exports = Pbf;\n\nvar Buffer = global.Buffer || require('./buffer');\n\nfunction Pbf(buf) {\n    this.buf = !Buffer.isBuffer(buf) ? new Buffer(buf || 0) : buf;\n    this.pos = 0;\n    this.length = this.buf.length;\n}\n\nPbf.Varint  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n    SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32,\n    POW_2_63 = Math.pow(2, 63);\n\nPbf.prototype = {\n\n    destroy: function() {\n        this.buf = null;\n    },\n\n    // === READING =================================================================\n\n    readFields: function(readField, result, end) {\n        end = end || this.length;\n\n        while (this.pos < end) {\n            var val = this.readVarint(),\n                tag = val >> 3,\n                startPos = this.pos;\n\n            readField(tag, result, this);\n\n            if (this.pos === startPos) this.skip(val);\n        }\n        return result;\n    },\n\n    readMessage: function(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    },\n\n    readFixed32: function() {\n        var val = this.buf.readUInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readSFixed32: function() {\n        var val = this.buf.readInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n    readFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readUInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readSFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readFloat: function() {\n        var val = this.buf.readFloatLE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readDouble: function() {\n        var val = this.buf.readDoubleLE(this.pos);\n        this.pos += 8;\n        return val;\n    },\n\n    readVarint: function() {\n        var buf = this.buf,\n            val, b, b0, b1, b2, b3;\n\n        b0 = buf[this.pos++]; if (b0 < 0x80) return b0;                 b0 = b0 & 0x7f;\n        b1 = buf[this.pos++]; if (b1 < 0x80) return b0 | b1 << 7;       b1 = (b1 & 0x7f) << 7;\n        b2 = buf[this.pos++]; if (b2 < 0x80) return b0 | b1 | b2 << 14; b2 = (b2 & 0x7f) << 14;\n        b3 = buf[this.pos++]; if (b3 < 0x80) return b0 | b1 | b2 | b3 << 21;\n\n        val = b0 | b1 | b2 | (b3 & 0x7f) << 21;\n\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x10000000;         if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x800000000;        if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x40000000000;      if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x2000000000000;    if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x100000000000000;  if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x8000000000000000; if (b < 0x80) return val;\n\n        throw new Error('Expected varint not more than 10 bytes');\n    },\n\n    readVarint64: function() {\n        var startPos = this.pos,\n            val = this.readVarint();\n\n        if (val < POW_2_63) return val;\n\n        var pos = this.pos - 2;\n        while (this.buf[pos] === 0xff) pos--;\n        if (pos < startPos) pos = startPos;\n\n        val = 0;\n        for (var i = 0; i < pos - startPos + 1; i++) {\n            var b = ~this.buf[startPos + i] & 0x7f;\n            val += i < 4 ? b << i * 7 : b * Math.pow(2, i * 7);\n        }\n\n        return -val - 1;\n    },\n\n    readSVarint: function() {\n        var num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    },\n\n    readBoolean: function() {\n        return Boolean(this.readVarint());\n    },\n\n    readString: function() {\n        var end = this.readVarint() + this.pos,\n            str = this.buf.toString('utf8', this.pos, end);\n        this.pos = end;\n        return str;\n    },\n\n    readBytes: function() {\n        var end = this.readVarint() + this.pos,\n            buffer = this.buf.slice(this.pos, end);\n        this.pos = end;\n        return buffer;\n    },\n\n    // verbose for performance reasons; doesn't affect gzipped size\n\n    readPackedVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readVarint());\n        return arr;\n    },\n    readPackedSVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    },\n    readPackedBoolean: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    },\n    readPackedFloat: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    },\n    readPackedDouble: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    },\n    readPackedFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    },\n    readPackedSFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    },\n    readPackedFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    },\n    readPackedSFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    },\n\n    skip: function(val) {\n        var type = val & 0x7;\n        if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}\n        else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;\n        else if (type === Pbf.Fixed32) this.pos += 4;\n        else if (type === Pbf.Fixed64) this.pos += 8;\n        else throw new Error('Unimplemented type: ' + type);\n    },\n\n    // === WRITING =================================================================\n\n    writeTag: function(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    },\n\n    realloc: function(min) {\n        var length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            var buf = new Buffer(length);\n            this.buf.copy(buf);\n            this.buf = buf;\n            this.length = length;\n        }\n    },\n\n    finish: function() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.slice(0, this.length);\n    },\n\n    writeFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeUInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeSFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeUInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeSFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeVarint: function(val) {\n        val = +val;\n\n        if (val <= 0x7f) {\n            this.realloc(1);\n            this.buf[this.pos++] = val;\n\n        } else if (val <= 0x3fff) {\n            this.realloc(2);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f);\n\n        } else if (val <= 0x1fffff) {\n            this.realloc(3);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f);\n\n        } else if (val <= 0xfffffff) {\n            this.realloc(4);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 21) & 0x7f);\n\n        } else {\n            var pos = this.pos;\n            while (val >= 0x80) {\n                this.realloc(1);\n                this.buf[this.pos++] = (val & 0xff) | 0x80;\n                val /= 0x80;\n            }\n            this.realloc(1);\n            this.buf[this.pos++] = val | 0;\n            if (this.pos - pos > 10) throw new Error('Given varint doesn\\'t fit into 10 bytes');\n        }\n    },\n\n    writeSVarint: function(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    },\n\n    writeBoolean: function(val) {\n        this.writeVarint(Boolean(val));\n    },\n\n    writeString: function(str) {\n        str = String(str);\n        var bytes = Buffer.byteLength(str);\n        this.writeVarint(bytes);\n        this.realloc(bytes);\n        this.buf.write(str, this.pos);\n        this.pos += bytes;\n    },\n\n    writeFloat: function(val) {\n        this.realloc(4);\n        this.buf.writeFloatLE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeDouble: function(val) {\n        this.realloc(8);\n        this.buf.writeDoubleLE(val, this.pos);\n        this.pos += 8;\n    },\n\n    writeBytes: function(buffer) {\n        var len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    },\n\n    writeMessage: function(tag, fn, obj) {\n        this.writeTag(tag, Pbf.Bytes);\n\n        this.pos++; // reserve 1 byte for short message length\n\n        // write the message directly to the buffer and see how much was written\n        var startPos = this.pos;\n        fn(obj, this);\n        var len = this.pos - startPos;\n\n        var varintLen =\n            len <= 0x7f ? 1 :\n            len <= 0x3fff ? 2 :\n            len <= 0x1fffff ? 3 :\n            len <= 0xfffffff ? 4 : Math.ceil(Math.log(len) / (Math.LN2 * 7));\n\n        // if 1 byte isn't enough for encoding message length, shift the data to the right\n        if (varintLen > 1) {\n            this.realloc(varintLen - 1);\n            for (var i = this.pos - 1; i >= startPos; i--) this.buf[i + varintLen - 1] = this.buf[i];\n        }\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    },\n\n    writePackedVarint:   function(tag, arr) { this.writeMessage(tag, writePackedVarint, arr);   },\n    writePackedSVarint:  function(tag, arr) { this.writeMessage(tag, writePackedSVarint, arr);  },\n    writePackedBoolean:  function(tag, arr) { this.writeMessage(tag, writePackedBoolean, arr);  },\n    writePackedFloat:    function(tag, arr) { this.writeMessage(tag, writePackedFloat, arr);    },\n    writePackedDouble:   function(tag, arr) { this.writeMessage(tag, writePackedDouble, arr);   },\n    writePackedFixed32:  function(tag, arr) { this.writeMessage(tag, writePackedFixed32, arr);  },\n    writePackedSFixed32: function(tag, arr) { this.writeMessage(tag, writePackedSFixed32, arr); },\n    writePackedFixed64:  function(tag, arr) { this.writeMessage(tag, writePackedFixed64, arr);  },\n    writePackedSFixed64: function(tag, arr) { this.writeMessage(tag, writePackedSFixed64, arr); },\n\n    writeBytesField: function(tag, buffer) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeBytes(buffer);\n    },\n    writeFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFixed32(val);\n    },\n    writeSFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeSFixed32(val);\n    },\n    writeFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeFixed64(val);\n    },\n    writeSFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeSFixed64(val);\n    },\n    writeVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeVarint(val);\n    },\n    writeSVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeSVarint(val);\n    },\n    writeStringField: function(tag, str) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeString(str);\n    },\n    writeFloatField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFloat(val);\n    },\n    writeDoubleField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeDouble(val);\n    },\n    writeBooleanField: function(tag, val) {\n        this.writeVarintField(tag, Boolean(val));\n    }\n};\n\nfunction writePackedVarint(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);   }\nfunction writePackedSVarint(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);  }\nfunction writePackedFloat(arr, pbf)    { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);    }\nfunction writePackedDouble(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);   }\nfunction writePackedBoolean(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);  }\nfunction writePackedFixed32(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);  }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);  }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/pbf/index.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["'use strict';\n\nmodule.exports = Pbf;\n\nvar Buffer = global.Buffer || require('./buffer');\n\nfunction Pbf(buf) {\n    this.buf = !Buffer.isBuffer(buf) ? new Buffer(buf || 0) : buf;\n    this.pos = 0;\n    this.length = this.buf.length;\n}\n\nPbf.Varint  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n    SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32,\n    POW_2_63 = Math.pow(2, 63);\n\nPbf.prototype = {\n\n    destroy: function() {\n        this.buf = null;\n    },\n\n    // === READING =================================================================\n\n    readFields: function(readField, result, end) {\n        end = end || this.length;\n\n        while (this.pos < end) {\n            var val = this.readVarint(),\n                tag = val >> 3,\n                startPos = this.pos;\n\n            readField(tag, result, this);\n\n            if (this.pos === startPos) this.skip(val);\n        }\n        return result;\n    },\n\n    readMessage: function(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    },\n\n    readFixed32: function() {\n        var val = this.buf.readUInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readSFixed32: function() {\n        var val = this.buf.readInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n    readFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readUInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readSFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readFloat: function() {\n        var val = this.buf.readFloatLE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readDouble: function() {\n        var val = this.buf.readDoubleLE(this.pos);\n        this.pos += 8;\n        return val;\n    },\n\n    readVarint: function() {\n        var buf = this.buf,\n            val, b, b0, b1, b2, b3;\n\n        b0 = buf[this.pos++]; if (b0 < 0x80) return b0;                 b0 = b0 & 0x7f;\n        b1 = buf[this.pos++]; if (b1 < 0x80) return b0 | b1 << 7;       b1 = (b1 & 0x7f) << 7;\n        b2 = buf[this.pos++]; if (b2 < 0x80) return b0 | b1 | b2 << 14; b2 = (b2 & 0x7f) << 14;\n        b3 = buf[this.pos++]; if (b3 < 0x80) return b0 | b1 | b2 | b3 << 21;\n\n        val = b0 | b1 | b2 | (b3 & 0x7f) << 21;\n\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x10000000;         if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x800000000;        if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x40000000000;      if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x2000000000000;    if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x100000000000000;  if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x8000000000000000; if (b < 0x80) return val;\n\n        throw new Error('Expected varint not more than 10 bytes');\n    },\n\n    readVarint64: function() {\n        var startPos = this.pos,\n            val = this.readVarint();\n\n        if (val < POW_2_63) return val;\n\n        var pos = this.pos - 2;\n        while (this.buf[pos] === 0xff) pos--;\n        if (pos < startPos) pos = startPos;\n\n        val = 0;\n        for (var i = 0; i < pos - startPos + 1; i++) {\n            var b = ~this.buf[startPos + i] & 0x7f;\n            val += i < 4 ? b << i * 7 : b * Math.pow(2, i * 7);\n        }\n\n        return -val - 1;\n    },\n\n    readSVarint: function() {\n        var num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    },\n\n    readBoolean: function() {\n        return Boolean(this.readVarint());\n    },\n\n    readString: function() {\n        var end = this.readVarint() + this.pos,\n            str = this.buf.toString('utf8', this.pos, end);\n        this.pos = end;\n        return str;\n    },\n\n    readBytes: function() {\n        var end = this.readVarint() + this.pos,\n            buffer = this.buf.slice(this.pos, end);\n        this.pos = end;\n        return buffer;\n    },\n\n    // verbose for performance reasons; doesn't affect gzipped size\n\n    readPackedVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readVarint());\n        return arr;\n    },\n    readPackedSVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    },\n    readPackedBoolean: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    },\n    readPackedFloat: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    },\n    readPackedDouble: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    },\n    readPackedFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    },\n    readPackedSFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    },\n    readPackedFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    },\n    readPackedSFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    },\n\n    skip: function(val) {\n        var type = val & 0x7;\n        if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}\n        else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;\n        else if (type === Pbf.Fixed32) this.pos += 4;\n        else if (type === Pbf.Fixed64) this.pos += 8;\n        else throw new Error('Unimplemented type: ' + type);\n    },\n\n    // === WRITING =================================================================\n\n    writeTag: function(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    },\n\n    realloc: function(min) {\n        var length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            var buf = new Buffer(length);\n            this.buf.copy(buf);\n            this.buf = buf;\n            this.length = length;\n        }\n    },\n\n    finish: function() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.slice(0, this.length);\n    },\n\n    writeFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeUInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeSFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeUInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeSFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeVarint: function(val) {\n        val = +val;\n\n        if (val <= 0x7f) {\n            this.realloc(1);\n            this.buf[this.pos++] = val;\n\n        } else if (val <= 0x3fff) {\n            this.realloc(2);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f);\n\n        } else if (val <= 0x1fffff) {\n            this.realloc(3);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f);\n\n        } else if (val <= 0xfffffff) {\n            this.realloc(4);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 21) & 0x7f);\n\n        } else {\n            var pos = this.pos;\n            while (val >= 0x80) {\n                this.realloc(1);\n                this.buf[this.pos++] = (val & 0xff) | 0x80;\n                val /= 0x80;\n            }\n            this.realloc(1);\n            this.buf[this.pos++] = val | 0;\n            if (this.pos - pos > 10) throw new Error('Given varint doesn\\'t fit into 10 bytes');\n        }\n    },\n\n    writeSVarint: function(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    },\n\n    writeBoolean: function(val) {\n        this.writeVarint(Boolean(val));\n    },\n\n    writeString: function(str) {\n        str = String(str);\n        var bytes = Buffer.byteLength(str);\n        this.writeVarint(bytes);\n        this.realloc(bytes);\n        this.buf.write(str, this.pos);\n        this.pos += bytes;\n    },\n\n    writeFloat: function(val) {\n        this.realloc(4);\n        this.buf.writeFloatLE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeDouble: function(val) {\n        this.realloc(8);\n        this.buf.writeDoubleLE(val, this.pos);\n        this.pos += 8;\n    },\n\n    writeBytes: function(buffer) {\n        var len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    },\n\n    writeMessage: function(tag, fn, obj) {\n        this.writeTag(tag, Pbf.Bytes);\n\n        this.pos++; // reserve 1 byte for short message length\n\n        // write the message directly to the buffer and see how much was written\n        var startPos = this.pos;\n        fn(obj, this);\n        var len = this.pos - startPos;\n\n        var varintLen =\n            len <= 0x7f ? 1 :\n            len <= 0x3fff ? 2 :\n            len <= 0x1fffff ? 3 :\n            len <= 0xfffffff ? 4 : Math.ceil(Math.log(len) / (Math.LN2 * 7));\n\n        // if 1 byte isn't enough for encoding message length, shift the data to the right\n        if (varintLen > 1) {\n            this.realloc(varintLen - 1);\n            for (var i = this.pos - 1; i >= startPos; i--) this.buf[i + varintLen - 1] = this.buf[i];\n        }\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    },\n\n    writePackedVarint:   function(tag, arr) { this.writeMessage(tag, writePackedVarint, arr);   },\n    writePackedSVarint:  function(tag, arr) { this.writeMessage(tag, writePackedSVarint, arr);  },\n    writePackedBoolean:  function(tag, arr) { this.writeMessage(tag, writePackedBoolean, arr);  },\n    writePackedFloat:    function(tag, arr) { this.writeMessage(tag, writePackedFloat, arr);    },\n    writePackedDouble:   function(tag, arr) { this.writeMessage(tag, writePackedDouble, arr);   },\n    writePackedFixed32:  function(tag, arr) { this.writeMessage(tag, writePackedFixed32, arr);  },\n    writePackedSFixed32: function(tag, arr) { this.writeMessage(tag, writePackedSFixed32, arr); },\n    writePackedFixed64:  function(tag, arr) { this.writeMessage(tag, writePackedFixed64, arr);  },\n    writePackedSFixed64: function(tag, arr) { this.writeMessage(tag, writePackedSFixed64, arr); },\n\n    writeBytesField: function(tag, buffer) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeBytes(buffer);\n    },\n    writeFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFixed32(val);\n    },\n    writeSFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeSFixed32(val);\n    },\n    writeFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeFixed64(val);\n    },\n    writeSFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeSFixed64(val);\n    },\n    writeVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeVarint(val);\n    },\n    writeSVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeSVarint(val);\n    },\n    writeStringField: function(tag, str) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeString(str);\n    },\n    writeFloatField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFloat(val);\n    },\n    writeDoubleField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeDouble(val);\n    },\n    writeBooleanField: function(tag, val) {\n        this.writeVarintField(tag, Boolean(val));\n    }\n};\n\nfunction writePackedVarint(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);   }\nfunction writePackedSVarint(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);  }\nfunction writePackedFloat(arr, pbf)    { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);    }\nfunction writePackedDouble(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);   }\nfunction writePackedBoolean(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);  }\nfunction writePackedFixed32(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);  }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);  }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n"]}","/*!\n * strip-comments <https://github.com/jonschlinkert/strip-comments>\n *\n * Copyright (c) 2014 Jon Schlinkert, contributors.\n * Licensed under the MIT license.\n */\n\n'use stric';\n\nvar reBlock = '\\\\/\\\\*';\nvar reBlockIgnore = '\\\\/\\\\*(?!\\\\*?\\\\!)';\nvar reBlockEnd = '(.|[\\\\r\\\\n]|\\\\n)*?\\\\*\\\\/\\\\n?\\\\n?';\nvar reLine = /(^|[^\\S\\n])(?:\\/\\/)([\\s\\S]+?)$/gm;\nvar reLineIgnore = /(^|[^\\S\\n])(?:\\/\\/[^!])([\\s\\S]+?)$/gm;\n\n\n/**\n * Strip all comments\n *\n * {%= docs(\"strip\") %}\n *\n * @param   {String} `str`  file contents or string to strip.\n * @param   {Object} `opts`  options are passed to `.block`, and `.line`\n * @return  {String} String without comments.\n * @api public\n */\n\nvar strip = module.exports = function(str, opts) {\n  return str ? strip.block(strip.line(str, opts), opts) : '';\n};\n\n\n/**\n * Strip only block comments, optionally leaving protected comments\n * (e.g. `/*!`) intact.\n *\n * {%= docs(\"block\") %}\n *\n * @param   {String} `str`  file content or string to strip to\n * @param   {Object} `opts`  if `safe:true`, strip only comments that do not start with `/*!` or `/**!`\n * @return  {String} String without block comments.\n * @api public\n */\n\nstrip.block = function(str, opts) {\n  opts = opts || {};\n  var re = new RegExp(reBlock + reBlockEnd, 'gm');\n  if(opts.safe) {\n    re = new RegExp(reBlockIgnore + reBlockEnd, 'gm');\n  }\n  return str ? str.replace(re, '') : '';\n};\n\n\n/**\n * Strip only line comments\n *\n * {%= docs(\"line\") %}\n *\n * @param   {String} `str`  file content or string to strip to\n * @param   {Object} `opts`  if `safe:true`, strip all that not starts with `//!`\n * @return  {String} String without line comments.\n * @api public\n */\n\nstrip.line = function(str, opts) {\n  opts = opts || {};\n  var re = reLine;\n  if(opts.safe) {\n    re = reLineIgnore;\n  }\n  return str ? str.replace(re, '') : '';\n};\n","!function() {\n  var topojson = {\n    version: \"1.6.19\",\n    mesh: function(topology) { return object(topology, meshArcs.apply(this, arguments)); },\n    meshArcs: meshArcs,\n    merge: function(topology) { return object(topology, mergeArcs.apply(this, arguments)); },\n    mergeArcs: mergeArcs,\n    feature: featureOrCollection,\n    neighbors: neighbors,\n    presimplify: presimplify\n  };\n\n  function stitchArcs(topology, arcs) {\n    var stitchedArcs = {},\n        fragmentByStart = {},\n        fragmentByEnd = {},\n        fragments = [],\n        emptyIndex = -1;\n\n    // Stitch empty arcs first, since they may be subsumed by other arcs.\n    arcs.forEach(function(i, j) {\n      var arc = topology.arcs[i < 0 ? ~i : i], t;\n      if (arc.length < 3 && !arc[1][0] && !arc[1][1]) {\n        t = arcs[++emptyIndex], arcs[emptyIndex] = i, arcs[j] = t;\n      }\n    });\n\n    arcs.forEach(function(i) {\n      var e = ends(i),\n          start = e[0],\n          end = e[1],\n          f, g;\n\n      if (f = fragmentByEnd[start]) {\n        delete fragmentByEnd[f.end];\n        f.push(i);\n        f.end = end;\n        if (g = fragmentByStart[end]) {\n          delete fragmentByStart[g.start];\n          var fg = g === f ? f : f.concat(g);\n          fragmentByStart[fg.start = f.start] = fragmentByEnd[fg.end = g.end] = fg;\n        } else {\n          fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n        }\n      } else if (f = fragmentByStart[end]) {\n        delete fragmentByStart[f.start];\n        f.unshift(i);\n        f.start = start;\n        if (g = fragmentByEnd[start]) {\n          delete fragmentByEnd[g.end];\n          var gf = g === f ? f : g.concat(f);\n          fragmentByStart[gf.start = g.start] = fragmentByEnd[gf.end = f.end] = gf;\n        } else {\n          fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n        }\n      } else {\n        f = [i];\n        fragmentByStart[f.start = start] = fragmentByEnd[f.end = end] = f;\n      }\n    });\n\n    function ends(i) {\n      var arc = topology.arcs[i < 0 ? ~i : i], p0 = arc[0], p1;\n      if (topology.transform) p1 = [0, 0], arc.forEach(function(dp) { p1[0] += dp[0], p1[1] += dp[1]; });\n      else p1 = arc[arc.length - 1];\n      return i < 0 ? [p1, p0] : [p0, p1];\n    }\n\n    function flush(fragmentByEnd, fragmentByStart) {\n      for (var k in fragmentByEnd) {\n        var f = fragmentByEnd[k];\n        delete fragmentByStart[f.start];\n        delete f.start;\n        delete f.end;\n        f.forEach(function(i) { stitchedArcs[i < 0 ? ~i : i] = 1; });\n        fragments.push(f);\n      }\n    }\n\n    flush(fragmentByEnd, fragmentByStart);\n    flush(fragmentByStart, fragmentByEnd);\n    arcs.forEach(function(i) { if (!stitchedArcs[i < 0 ? ~i : i]) fragments.push([i]); });\n\n    return fragments;\n  }\n\n  function meshArcs(topology, o, filter) {\n    var arcs = [];\n\n    if (arguments.length > 1) {\n      var geomsByArc = [],\n          geom;\n\n      function arc(i) {\n        var j = i < 0 ? ~i : i;\n        (geomsByArc[j] || (geomsByArc[j] = [])).push({i: i, g: geom});\n      }\n\n      function line(arcs) {\n        arcs.forEach(arc);\n      }\n\n      function polygon(arcs) {\n        arcs.forEach(line);\n      }\n\n      function geometry(o) {\n        if (o.type === \"GeometryCollection\") o.geometries.forEach(geometry);\n        else if (o.type in geometryType) geom = o, geometryType[o.type](o.arcs);\n      }\n\n      var geometryType = {\n        LineString: line,\n        MultiLineString: polygon,\n        Polygon: polygon,\n        MultiPolygon: function(arcs) { arcs.forEach(polygon); }\n      };\n\n      geometry(o);\n\n      geomsByArc.forEach(arguments.length < 3\n          ? function(geoms) { arcs.push(geoms[0].i); }\n          : function(geoms) { if (filter(geoms[0].g, geoms[geoms.length - 1].g)) arcs.push(geoms[0].i); });\n    } else {\n      for (var i = 0, n = topology.arcs.length; i < n; ++i) arcs.push(i);\n    }\n\n    return {type: \"MultiLineString\", arcs: stitchArcs(topology, arcs)};\n  }\n\n  function mergeArcs(topology, objects) {\n    var polygonsByArc = {},\n        polygons = [],\n        components = [];\n\n    objects.forEach(function(o) {\n      if (o.type === \"Polygon\") register(o.arcs);\n      else if (o.type === \"MultiPolygon\") o.arcs.forEach(register);\n    });\n\n    function register(polygon) {\n      polygon.forEach(function(ring) {\n        ring.forEach(function(arc) {\n          (polygonsByArc[arc = arc < 0 ? ~arc : arc] || (polygonsByArc[arc] = [])).push(polygon);\n        });\n      });\n      polygons.push(polygon);\n    }\n\n    function exterior(ring) {\n      return cartesianRingArea(object(topology, {type: \"Polygon\", arcs: [ring]}).coordinates[0]) > 0; // TODO allow spherical?\n    }\n\n    polygons.forEach(function(polygon) {\n      if (!polygon._) {\n        var component = [],\n            neighbors = [polygon];\n        polygon._ = 1;\n        components.push(component);\n        while (polygon = neighbors.pop()) {\n          component.push(polygon);\n          polygon.forEach(function(ring) {\n            ring.forEach(function(arc) {\n              polygonsByArc[arc < 0 ? ~arc : arc].forEach(function(polygon) {\n                if (!polygon._) {\n                  polygon._ = 1;\n                  neighbors.push(polygon);\n                }\n              });\n            });\n          });\n        }\n      }\n    });\n\n    polygons.forEach(function(polygon) {\n      delete polygon._;\n    });\n\n    return {\n      type: \"MultiPolygon\",\n      arcs: components.map(function(polygons) {\n        var arcs = [];\n\n        // Extract the exterior (unique) arcs.\n        polygons.forEach(function(polygon) {\n          polygon.forEach(function(ring) {\n            ring.forEach(function(arc) {\n              if (polygonsByArc[arc < 0 ? ~arc : arc].length < 2) {\n                arcs.push(arc);\n              }\n            });\n          });\n        });\n\n        // Stitch the arcs into one or more rings.\n        arcs = stitchArcs(topology, arcs);\n\n        // If more than one ring is returned,\n        // at most one of these rings can be the exterior;\n        // this exterior ring has the same winding order\n        // as any exterior ring in the original polygons.\n        if ((n = arcs.length) > 1) {\n          var sgn = exterior(polygons[0][0]);\n          for (var i = 0, t; i < n; ++i) {\n            if (sgn === exterior(arcs[i])) {\n              t = arcs[0], arcs[0] = arcs[i], arcs[i] = t;\n              break;\n            }\n          }\n        }\n\n        return arcs;\n      })\n    };\n  }\n\n  function featureOrCollection(topology, o) {\n    return o.type === \"GeometryCollection\" ? {\n      type: \"FeatureCollection\",\n      features: o.geometries.map(function(o) { return feature(topology, o); })\n    } : feature(topology, o);\n  }\n\n  function feature(topology, o) {\n    var f = {\n      type: \"Feature\",\n      id: o.id,\n      properties: o.properties || {},\n      geometry: object(topology, o)\n    };\n    if (o.id == null) delete f.id;\n    return f;\n  }\n\n  function object(topology, o) {\n    var absolute = transformAbsolute(topology.transform),\n        arcs = topology.arcs;\n\n    function arc(i, points) {\n      if (points.length) points.pop();\n      for (var a = arcs[i < 0 ? ~i : i], k = 0, n = a.length, p; k < n; ++k) {\n        points.push(p = a[k].slice());\n        absolute(p, k);\n      }\n      if (i < 0) reverse(points, n);\n    }\n\n    function point(p) {\n      p = p.slice();\n      absolute(p, 0);\n      return p;\n    }\n\n    function line(arcs) {\n      var points = [];\n      for (var i = 0, n = arcs.length; i < n; ++i) arc(arcs[i], points);\n      if (points.length < 2) points.push(points[0].slice());\n      return points;\n    }\n\n    function ring(arcs) {\n      var points = line(arcs);\n      while (points.length < 4) points.push(points[0].slice());\n      return points;\n    }\n\n    function polygon(arcs) {\n      return arcs.map(ring);\n    }\n\n    function geometry(o) {\n      var t = o.type;\n      return t === \"GeometryCollection\" ? {type: t, geometries: o.geometries.map(geometry)}\n          : t in geometryType ? {type: t, coordinates: geometryType[t](o)}\n          : null;\n    }\n\n    var geometryType = {\n      Point: function(o) { return point(o.coordinates); },\n      MultiPoint: function(o) { return o.coordinates.map(point); },\n      LineString: function(o) { return line(o.arcs); },\n      MultiLineString: function(o) { return o.arcs.map(line); },\n      Polygon: function(o) { return polygon(o.arcs); },\n      MultiPolygon: function(o) { return o.arcs.map(polygon); }\n    };\n\n    return geometry(o);\n  }\n\n  function reverse(array, n) {\n    var t, j = array.length, i = j - n; while (i < --j) t = array[i], array[i++] = array[j], array[j] = t;\n  }\n\n  function bisect(a, x) {\n    var lo = 0, hi = a.length;\n    while (lo < hi) {\n      var mid = lo + hi >>> 1;\n      if (a[mid] < x) lo = mid + 1;\n      else hi = mid;\n    }\n    return lo;\n  }\n\n  function neighbors(objects) {\n    var indexesByArc = {}, // arc index -> array of object indexes\n        neighbors = objects.map(function() { return []; });\n\n    function line(arcs, i) {\n      arcs.forEach(function(a) {\n        if (a < 0) a = ~a;\n        var o = indexesByArc[a];\n        if (o) o.push(i);\n        else indexesByArc[a] = [i];\n      });\n    }\n\n    function polygon(arcs, i) {\n      arcs.forEach(function(arc) { line(arc, i); });\n    }\n\n    function geometry(o, i) {\n      if (o.type === \"GeometryCollection\") o.geometries.forEach(function(o) { geometry(o, i); });\n      else if (o.type in geometryType) geometryType[o.type](o.arcs, i);\n    }\n\n    var geometryType = {\n      LineString: line,\n      MultiLineString: polygon,\n      Polygon: polygon,\n      MultiPolygon: function(arcs, i) { arcs.forEach(function(arc) { polygon(arc, i); }); }\n    };\n\n    objects.forEach(geometry);\n\n    for (var i in indexesByArc) {\n      for (var indexes = indexesByArc[i], m = indexes.length, j = 0; j < m; ++j) {\n        for (var k = j + 1; k < m; ++k) {\n          var ij = indexes[j], ik = indexes[k], n;\n          if ((n = neighbors[ij])[i = bisect(n, ik)] !== ik) n.splice(i, 0, ik);\n          if ((n = neighbors[ik])[i = bisect(n, ij)] !== ij) n.splice(i, 0, ij);\n        }\n      }\n    }\n\n    return neighbors;\n  }\n\n  function presimplify(topology, triangleArea) {\n    var absolute = transformAbsolute(topology.transform),\n        relative = transformRelative(topology.transform),\n        heap = minAreaHeap();\n\n    if (!triangleArea) triangleArea = cartesianTriangleArea;\n\n    topology.arcs.forEach(function(arc) {\n      var triangles = [],\n          maxArea = 0,\n          triangle;\n\n      // To store each point’s effective area, we create a new array rather than\n      // extending the passed-in point to workaround a Chrome/V8 bug (getting\n      // stuck in smi mode). For midpoints, the initial effective area of\n      // Infinity will be computed in the next step.\n      for (var i = 0, n = arc.length, p; i < n; ++i) {\n        p = arc[i];\n        absolute(arc[i] = [p[0], p[1], Infinity], i);\n      }\n\n      for (var i = 1, n = arc.length - 1; i < n; ++i) {\n        triangle = arc.slice(i - 1, i + 2);\n        triangle[1][2] = triangleArea(triangle);\n        triangles.push(triangle);\n        heap.push(triangle);\n      }\n\n      for (var i = 0, n = triangles.length; i < n; ++i) {\n        triangle = triangles[i];\n        triangle.previous = triangles[i - 1];\n        triangle.next = triangles[i + 1];\n      }\n\n      while (triangle = heap.pop()) {\n        var previous = triangle.previous,\n            next = triangle.next;\n\n        // If the area of the current point is less than that of the previous point\n        // to be eliminated, use the latter's area instead. This ensures that the\n        // current point cannot be eliminated without eliminating previously-\n        // eliminated points.\n        if (triangle[1][2] < maxArea) triangle[1][2] = maxArea;\n        else maxArea = triangle[1][2];\n\n        if (previous) {\n          previous.next = next;\n          previous[2] = triangle[2];\n          update(previous);\n        }\n\n        if (next) {\n          next.previous = previous;\n          next[0] = triangle[0];\n          update(next);\n        }\n      }\n\n      arc.forEach(relative);\n    });\n\n    function update(triangle) {\n      heap.remove(triangle);\n      triangle[1][2] = triangleArea(triangle);\n      heap.push(triangle);\n    }\n\n    return topology;\n  };\n\n  function cartesianRingArea(ring) {\n    var i = -1,\n        n = ring.length,\n        a,\n        b = ring[n - 1],\n        area = 0;\n\n    while (++i < n) {\n      a = b;\n      b = ring[i];\n      area += a[0] * b[1] - a[1] * b[0];\n    }\n\n    return area * .5;\n  }\n\n  function cartesianTriangleArea(triangle) {\n    var a = triangle[0], b = triangle[1], c = triangle[2];\n    return Math.abs((a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]));\n  }\n\n  function compareArea(a, b) {\n    return a[1][2] - b[1][2];\n  }\n\n  function minAreaHeap() {\n    var heap = {},\n        array = [],\n        size = 0;\n\n    heap.push = function(object) {\n      up(array[object._ = size] = object, size++);\n      return size;\n    };\n\n    heap.pop = function() {\n      if (size <= 0) return;\n      var removed = array[0], object;\n      if (--size > 0) object = array[size], down(array[object._ = 0] = object, 0);\n      return removed;\n    };\n\n    heap.remove = function(removed) {\n      var i = removed._, object;\n      if (array[i] !== removed) return; // invalid request\n      if (i !== --size) object = array[size], (compareArea(object, removed) < 0 ? up : down)(array[object._ = i] = object, i);\n      return i;\n    };\n\n    function up(object, i) {\n      while (i > 0) {\n        var j = ((i + 1) >> 1) - 1,\n            parent = array[j];\n        if (compareArea(object, parent) >= 0) break;\n        array[parent._ = i] = parent;\n        array[object._ = i = j] = object;\n      }\n    }\n\n    function down(object, i) {\n      while (true) {\n        var r = (i + 1) << 1,\n            l = r - 1,\n            j = i,\n            child = array[j];\n        if (l < size && compareArea(array[l], child) < 0) child = array[j = l];\n        if (r < size && compareArea(array[r], child) < 0) child = array[j = r];\n        if (j === i) break;\n        array[child._ = i] = child;\n        array[object._ = i = j] = object;\n      }\n    }\n\n    return heap;\n  }\n\n  function transformAbsolute(transform) {\n    if (!transform) return noop;\n    var x0,\n        y0,\n        kx = transform.scale[0],\n        ky = transform.scale[1],\n        dx = transform.translate[0],\n        dy = transform.translate[1];\n    return function(point, i) {\n      if (!i) x0 = y0 = 0;\n      point[0] = (x0 += point[0]) * kx + dx;\n      point[1] = (y0 += point[1]) * ky + dy;\n    };\n  }\n\n  function transformRelative(transform) {\n    if (!transform) return noop;\n    var x0,\n        y0,\n        kx = transform.scale[0],\n        ky = transform.scale[1],\n        dx = transform.translate[0],\n        dy = transform.translate[1];\n    return function(point, i) {\n      if (!i) x0 = y0 = 0;\n      var x1 = (point[0] - dx) / kx | 0,\n          y1 = (point[1] - dy) / ky | 0;\n      point[0] = x1 - x0;\n      point[1] = y1 - y0;\n      x0 = x1;\n      y0 = y1;\n    };\n  }\n\n  function noop() {}\n\n  if (typeof define === \"function\" && define.amd) define(topojson);\n  else if (typeof module === \"object\" && module.exports) module.exports = topojson;\n  else this.topojson = topojson;\n}();\n","module.exports.VectorTile = require('./lib/vectortile.js');\nmodule.exports.VectorTileFeature = require('./lib/vectortilefeature.js');\nmodule.exports.VectorTileLayer = require('./lib/vectortilelayer.js');\n","'use strict';\n\nvar VectorTileLayer = require('./vectortilelayer');\n\nmodule.exports = VectorTile;\n\nfunction VectorTile(pbf, end) {\n    this.layers = pbf.readFields(readTile, {}, end);\n}\n\nfunction readTile(tag, layers, pbf) {\n    if (tag === 3) {\n        var layer = new VectorTileLayer(pbf, pbf.readVarint() + pbf.pos);\n        if (layer.length) layers[layer.name] = layer;\n    }\n}\n\n","'use strict';\n\nvar Point = require('point-geometry');\n\nmodule.exports = VectorTileFeature;\n\nfunction VectorTileFeature(pbf, end, extent, keys, values) {\n    // Public\n    this.properties = {};\n    this.extent = extent;\n    this.type = 0;\n\n    // Private\n    this._pbf = pbf;\n    this._geometry = -1;\n    this._keys = keys;\n    this._values = values;\n\n    pbf.readFields(readFeature, this, end);\n}\n\nfunction readFeature(tag, feature, pbf) {\n    if (tag == 1) feature._id = pbf.readVarint();\n    else if (tag == 2) readTag(pbf, feature);\n    else if (tag == 3) feature.type = pbf.readVarint();\n    else if (tag == 4) feature._geometry = pbf.pos;\n}\n\nfunction readTag(pbf, feature) {\n    var end = pbf.readVarint() + pbf.pos;\n\n    while (pbf.pos < end) {\n        var key = feature._keys[pbf.readVarint()],\n            value = feature._values[pbf.readVarint()];\n        feature.properties[key] = value;\n    }\n}\n\nVectorTileFeature.types = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nVectorTileFeature.prototype.loadGeometry = function() {\n    var pbf = this._pbf;\n    pbf.pos = this._geometry;\n\n    var end = pbf.readVarint() + pbf.pos,\n        cmd = 1,\n        length = 0,\n        x = 0,\n        y = 0,\n        lines = [],\n        line;\n\n    while (pbf.pos < end) {\n        if (!length) {\n            var cmdLen = pbf.readVarint();\n            cmd = cmdLen & 0x7;\n            length = cmdLen >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += pbf.readSVarint();\n            y += pbf.readSVarint();\n\n            if (cmd === 1) { // moveTo\n                if (line) lines.push(line);\n                line = [];\n            }\n\n            line.push(new Point(x, y));\n\n        } else if (cmd === 7) {\n            line.push(line[0].clone()); // closePolygon\n\n        } else {\n            throw new Error('unknown command ' + cmd);\n        }\n    }\n\n    if (line) lines.push(line);\n\n    return lines;\n};\n\nVectorTileFeature.prototype.bbox = function() {\n    var pbf = this._pbf;\n    pbf.pos = this._geometry;\n\n    var end = pbf.readVarint() + pbf.pos,\n        cmd = 1,\n        length = 0,\n        x = 0,\n        y = 0,\n        x1 = Infinity,\n        x2 = -Infinity,\n        y1 = Infinity,\n        y2 = -Infinity;\n\n    while (pbf.pos < end) {\n        if (!length) {\n            var cmdLen = pbf.readVarint();\n            cmd = cmdLen & 0x7;\n            length = cmdLen >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += pbf.readSVarint();\n            y += pbf.readSVarint();\n            if (x < x1) x1 = x;\n            if (x > x2) x2 = x;\n            if (y < y1) y1 = y;\n            if (y > y2) y2 = y;\n\n        } else if (cmd !== 7) {\n            throw new Error('unknown command ' + cmd);\n        }\n    }\n\n    return [x1, y1, x2, y2];\n};\n\nVectorTileFeature.prototype.toGeoJSON = function(x, y, z) {\n    var size = this.extent * Math.pow(2, z),\n        x0 = this.extent * x,\n        y0 = this.extent * y,\n        coords = this.loadGeometry(),\n        type = VectorTileFeature.types[this.type];\n\n    for (var i = 0; i < coords.length; i++) {\n        var line = coords[i];\n        for (var j = 0; j < line.length; j++) {\n            var p = line[j], y2 = 180 - (p.y + y0) * 360 / size;\n            line[j] = [\n                (p.x + x0) * 360 / size - 180,\n                360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90\n            ];\n        }\n    }\n\n    if (type === 'Point' && coords.length === 1) {\n        coords = coords[0][0];\n    } else if (type === 'Point') {\n        coords = coords[0];\n        type = 'MultiPoint';\n    } else if (type === 'LineString' && coords.length === 1) {\n        coords = coords[0];\n    } else if (type === 'LineString') {\n        type = 'MultiLineString';\n    }\n\n    return {\n        type: \"Feature\",\n        geometry: {\n            type: type,\n            coordinates: coords\n        },\n        properties: this.properties\n    };\n};\n","'use strict';\n\nvar VectorTileFeature = require('./vectortilefeature.js');\n\nmodule.exports = VectorTileLayer;\n\nfunction VectorTileLayer(pbf, end) {\n    // Public\n    this.version = 1;\n    this.name = null;\n    this.extent = 4096;\n    this.length = 0;\n\n    // Private\n    this._pbf = pbf;\n    this._keys = [];\n    this._values = [];\n    this._features = [];\n\n    pbf.readFields(readLayer, this, end);\n\n    this.length = this._features.length;\n}\n\nfunction readLayer(tag, layer, pbf) {\n    if (tag === 15) layer.version = pbf.readVarint();\n    else if (tag === 1) layer.name = pbf.readString();\n    else if (tag === 5) layer.extent = pbf.readVarint();\n    else if (tag === 2) layer._features.push(pbf.pos);\n    else if (tag === 3) layer._keys.push(pbf.readString());\n    else if (tag === 4) layer._values.push(readValueMessage(pbf));\n}\n\nfunction readValueMessage(pbf) {\n    var value = null,\n        end = pbf.readVarint() + pbf.pos;\n\n    while (pbf.pos < end) {\n        var tag = pbf.readVarint() >> 3;\n\n        value = tag === 1 ? pbf.readString() :\n            tag === 2 ? pbf.readFloat() :\n            tag === 3 ? pbf.readDouble() :\n            tag === 4 ? pbf.readVarint64() :\n            tag === 5 ? pbf.readVarint() :\n            tag === 6 ? pbf.readSVarint() :\n            tag === 7 ? pbf.readBoolean() : null;\n    }\n\n    return value;\n}\n\n// return feature `i` from this layer as a `VectorTileFeature`\nVectorTileLayer.prototype.feature = function(i) {\n    if (i < 0 || i >= this._features.length) throw new Error('feature index out of bounds');\n\n    this._pbf.pos = this._features[i];\n\n    var end = this._pbf.readVarint() + this._pbf.pos;\n    return new VectorTileFeature(this._pbf, end, this.extent, this._keys, this._values);\n};\n","'use strict';\n\nmodule.exports = Point;\n\nfunction Point(x, y) {\n    this.x = x;\n    this.y = y;\n}\n\nPoint.prototype = {\n    clone: function() { return new Point(this.x, this.y); },\n\n    add:     function(p) { return this.clone()._add(p);     },\n    sub:     function(p) { return this.clone()._sub(p);     },\n    mult:    function(k) { return this.clone()._mult(k);    },\n    div:     function(k) { return this.clone()._div(k);     },\n    rotate:  function(a) { return this.clone()._rotate(a);  },\n    matMult: function(m) { return this.clone()._matMult(m); },\n    unit:    function() { return this.clone()._unit(); },\n    perp:    function() { return this.clone()._perp(); },\n    round:   function() { return this.clone()._round(); },\n\n    mag: function() {\n        return Math.sqrt(this.x * this.x + this.y * this.y);\n    },\n\n    equals: function(p) {\n        return this.x === p.x &&\n               this.y === p.y;\n    },\n\n    dist: function(p) {\n        return Math.sqrt(this.distSqr(p));\n    },\n\n    distSqr: function(p) {\n        var dx = p.x - this.x,\n            dy = p.y - this.y;\n        return dx * dx + dy * dy;\n    },\n\n    angle: function() {\n        return Math.atan2(this.y, this.x);\n    },\n\n    angleTo: function(b) {\n        return Math.atan2(this.y - b.y, this.x - b.x);\n    },\n\n    angleWith: function(b) {\n        return this.angleWithSep(b.x, b.y);\n    },\n\n    // Find the angle of the two vectors, solving the formula for the cross product a x b = |a||b|sin(θ) for θ.\n    angleWithSep: function(x, y) {\n        return Math.atan2(\n            this.x * y - this.y * x,\n            this.x * x + this.y * y);\n    },\n\n    _matMult: function(m) {\n        var x = m[0] * this.x + m[1] * this.y,\n            y = m[2] * this.x + m[3] * this.y;\n        this.x = x;\n        this.y = y;\n        return this;\n    },\n\n    _add: function(p) {\n        this.x += p.x;\n        this.y += p.y;\n        return this;\n    },\n\n    _sub: function(p) {\n        this.x -= p.x;\n        this.y -= p.y;\n        return this;\n    },\n\n    _mult: function(k) {\n        this.x *= k;\n        this.y *= k;\n        return this;\n    },\n\n    _div: function(k) {\n        this.x /= k;\n        this.y /= k;\n        return this;\n    },\n\n    _unit: function() {\n        this._div(this.mag());\n        return this;\n    },\n\n    _perp: function() {\n        var y = this.y;\n        this.y = this.x;\n        this.x = -y;\n        return this;\n    },\n\n    _rotate: function(angle) {\n        var cos = Math.cos(angle),\n            sin = Math.sin(angle),\n            x = cos * this.x - sin * this.y,\n            y = sin * this.x + cos * this.y;\n        this.x = x;\n        this.y = y;\n        return this;\n    },\n\n    _round: function() {\n        this.x = Math.round(this.x);\n        this.y = Math.round(this.y);\n        return this;\n    }\n};\n\n// constructs Point from an array if necessary\nPoint.convert = function (a) {\n    if (a instanceof Point) {\n        return a;\n    }\n    if (Array.isArray(a)) {\n        return new Point(a[0], a[1]);\n    }\n    return a;\n};\n","/*global Camera */\nimport Geo from './geo';\nimport Utils from './utils/utils';\nimport ShaderProgram from './gl/shader_program';\n\nimport glMatrix from 'gl-matrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\n// Abstract base class\nexport default class Camera {\n\n    constructor(name, scene, options = {}) {\n        this.scene = scene;\n        this.position = options.position;\n        this.zoom = options.zoom;\n        // this.updateScene();\n    }\n\n    // Create a camera by type name, factory-style\n    static create(name, scene, config) {\n        switch (config.type) {\n            case 'isometric':\n                return new IsometricCamera(name, scene, config);\n            case 'flat':\n                return new FlatCamera(name, scene, config);\n            case 'perspective':\n            /* falls through */\n            default:\n                return new PerspectiveCamera(name, scene, config);\n        }\n    }\n\n    // Update method called once per frame\n    update() {\n        // this.updateScene();\n    }\n\n    // Called once per frame per program (e.g. for main render pass, then for each additional pass for feature selection, etc.)\n    setupProgram(program) {\n    }\n\n    /**\n        Sync camera position and/or zoom to scene\n        position: [lat, lng] or [lat, lng, zoom]\n        zoom: zoom\n    */\n    updateScene () {\n        if (this.position || this.zoom) {\n            var view = {};\n            if (this.position) {\n                view = { lng: this.position[0], lat: this.position[1], zoom: this.position[2] };\n            }\n            if (this.zoom) {\n                view.zoom = this.zoom;\n            }\n            this.scene.setView(view);\n        }\n    }\n\n}\n\n/**\n    Perspective matrix projection\n\n    This is a specialized perspective camera that, given a desired camera focal length (which can also vary by zoom level),\n    constrains the camera height above the ground plane such that the displayed ground area of the map matches that of\n    a traditional web mercator map. This means you can set the camera location by [lat, lng, zoom] as you would a typical\n    web mercator map, then adjust the focal length as needed.\n\n    Vanishing point can also be adjusted to achieve different \"viewing angles\", e.g. instead of looking straight down into\n    the center of the viewport, the camera appears to be tilted at an angle. For example:\n\n    [0, 0] = looking towards center of viewport\n    [-250, -250] = looking 250 pixels from the viewport center to the lower-left corner\n    [400, 0] = looking 400 pixels to the right of the viewport center\n*/\nclass PerspectiveCamera extends Camera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'perspective';\n\n        // a single scalar, or pairs of stops mapping zoom levels, e.g. [zoom, focal length]\n        this.focal_length = options.focal_length;\n        this.fov = options.fov;\n        if (!this.focal_length && !this.fov) {\n            // Default focal length ranges by zoom\n            this.focal_length = [[16, 2], [17, 2.5], [18, 3], [19, 4], [20, 6]];\n        }\n\n        this.vanishing_point = options.vanishing_point || [0, 0]; // [x, y]\n        this.vanishing_point = this.vanishing_point.map(parseFloat); // we implicitly only support px units here\n        this.vanishing_point_skew = [];\n\n        this.position_meters = null;\n        this.viewMatrix = new Float64Array(16);\n        this.projectionMatrix = new Float32Array(16);\n\n        // 'camera' is the name of the shader block, e.g. determines where in the shader this code is injected\n        ShaderProgram.replaceBlock('camera', `\n            uniform mat4 u_projection;\n            uniform vec3 u_eye;\n            uniform vec2 u_vanishing_point;\n\n            void cameraProjection (inout vec4 position) {\n                position = u_projection * position;\n            }`\n        );\n    }\n\n    // Constrains the camera so that the viewable area matches given the viewport height\n    // (in world space, e.g. meters), given either a camera focal length or field-of-view\n    // (focal length is used if both are passed).\n    constrainCamera({ view_height, height, focal_length, fov }) {\n        // Solve for camera height\n        if (!height) {\n            // We have focal length, calculate FOV\n            if (focal_length) {\n                fov = Math.atan(1 / focal_length) * 2;\n            }\n            // We have FOV, calculate focal length\n            else if (fov) {\n                fov = fov * Math.PI / 180; // convert FOV degrees to radians\n                focal_length = 1 / Math.tan(fov / 2);\n            }\n\n            // Distance that camera should be from ground such that it fits the field of view expected\n            // for a conventional web mercator map at the current zoom level and camera focal length\n            height = view_height / 2 * focal_length;\n        }\n        // Solve for camera focal length / field-of-view\n        else {\n            focal_length = 2 * height / view_height;\n            fov = Math.atan(1 / focal_length) * 2;\n        }\n\n        return { view_height, height, focal_length, fov };\n    }\n\n    updateMatrices() {\n        // TODO: only re-calculate these vars when necessary\n\n        // Height of the viewport in meters at current zoom\n        var viewport_height = this.scene.css_size.height * Geo.metersPerPixel(this.scene.zoom);\n\n        // Compute camera properties to fit desired view\n        var { height, fov } = this.constrainCamera({\n            view_height: viewport_height,\n            focal_length: Utils.interpolate(this.scene.zoom, this.focal_length),\n            fov: Utils.interpolate(this.scene.zoom, this.fov)\n         });\n\n        // View matrix\n        var position = [this.scene.center_meters.x, this.scene.center_meters.y, height];\n        this.position_meters = position;\n\n        // mat4.lookAt(this.viewMatrix,\n        //     vec3.fromValues(...position),\n        //     vec3.fromValues(position[0], position[1], height - 1),\n        //     vec3.fromValues(0, 1, 0));\n        // Exclude camera height from view matrix\n        mat4.lookAt(this.viewMatrix,\n            vec3.fromValues(position[0], position[1], 0),\n            vec3.fromValues(position[0], position[1], -1),\n            vec3.fromValues(0, 1, 0));\n\n        // Projection matrix\n        mat4.perspective(this.projectionMatrix, fov, this.scene.view_aspect, 1, height * 2);\n\n        // Convert vanishing point from pixels to viewport space\n        this.vanishing_point_skew[0] = this.vanishing_point[0] / this.scene.css_size.width;\n        this.vanishing_point_skew[1] = this.vanishing_point[1] / this.scene.css_size.height;\n\n        // Adjust projection matrix to include vanishing point skew\n        this.projectionMatrix[8] = -this.vanishing_point_skew[0]; // z column of x row, e.g. amount z skews x\n        this.projectionMatrix[9] = -this.vanishing_point_skew[1]; // z column of y row, e.g. amount z skews y\n\n        // Translate geometry into the distance so that camera is appropriate height above ground\n        // Additionally, adjust xy to compensate for any vanishing point skew, e.g. move geometry so that the displayed g\n        // plane of the map matches that expected by a traditional web mercator map at this [lat, lng, zoom].\n        mat4.translate(this.projectionMatrix, this.projectionMatrix,\n            vec3.fromValues(\n                viewport_height/2 * this.scene.view_aspect * -this.vanishing_point_skew[0],\n                viewport_height/2 * -this.vanishing_point_skew[1],\n                0\n            )\n        );\n\n        // Include camera height in projection matrix\n        mat4.translate(this.projectionMatrix, this.projectionMatrix, vec3.fromValues(0, 0, -height));\n    }\n\n    update() {\n        super.update();\n        this.updateMatrices();\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projectionMatrix);\n        program.uniform('3f', 'u_eye', 0, 0, this.position_meters[2]);\n        program.uniform('2fv', 'u_vanishing_point', this.vanishing_point_skew);\n    }\n\n}\n\n// Isometric-style projection\n// Note: this is actually an \"axonometric\" projection, but I'm using the colloquial term isometric because it is more recognizable.\n// An isometric projection is a specific subset of axonometric projections.\n// 'axis' determines the xy skew applied to a vertex based on its z coordinate, e.g. [0, 1] axis causes buildings to be drawn\n// straight upwards on screen at their true height, [0, .5] would draw them up at half-height, [1, 0] would be sideways, etc.\nclass IsometricCamera extends Camera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'isometric';\n        this.axis = options.axis || { x: 0, y: 1 };\n        if (this.axis.length === 2) {\n            this.axis = { x: this.axis[0], y: this.axis[1] }; // allow axis to also be passed as 2-elem array\n        }\n\n        this.position_meters = null;\n        this.viewport_height = null;\n\n        this.viewMatrix = new Float64Array(16);\n        this.projectionMatrix = new Float32Array(16);\n\n        // 'camera' is the name of the shader block, e.g. determines where in the shader this code is injected\n        ShaderProgram.replaceBlock('camera', `\n            uniform mat4 u_projection;\n            uniform vec3 u_eye;\n            uniform vec2 u_vanishing_point;\n\n            void cameraProjection (inout vec4 position) {\n                position = u_projection * position;\n                // position.xy += position.z * u_isometric_axis;\n\n                // Reverse z for depth buffer so up is negative,\n                // and scale down values so objects higher than one screen height will not get clipped\n                // pull forward slightly to avoid going past far clipping plane\n                position.z = -position.z / 100. + 1. - 0.001;\n            }`\n        );\n    }\n\n    update() {\n        super.update();\n\n        this.viewport_height = this.scene.css_size.height * Geo.metersPerPixel(this.scene.zoom);\n        var position = [this.scene.center_meters.x, this.scene.center_meters.y, this.viewport_height];\n        this.position_meters = position;\n\n        // View\n        mat4.identity(this.viewMatrix);\n        mat4.translate(this.viewMatrix, this.viewMatrix, vec3.fromValues(-position[0], -position[1], 0));\n\n        // Projection\n        mat4.identity(this.projectionMatrix);\n\n        // apply isometric skew\n        this.projectionMatrix[8] = this.axis.x / this.scene.view_aspect;    // z column of x row, e.g. amount z skews x\n        this.projectionMatrix[9] = this.axis.y;                             // z column of x row, e.g. amount z skews y\n\n        // convert meters to viewport\n        mat4.scale(this.projectionMatrix, this.projectionMatrix,\n            vec3.fromValues(\n                2 / this.scene.viewport_meters.x,\n                2 / this.scene.viewport_meters.y,\n                2 / this.scene.viewport_meters.y\n            )\n        );\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projectionMatrix);\n\n        program.uniform('3f', 'u_eye', 0, 0, this.viewport_height);\n        // program.uniform('3f', 'u_eye', this.viewport_height * this.axis.x, this.viewport_height * this.axis.y, this.viewport_height);\n        program.uniform('2f', 'u_vanishing_point', 0, 0);\n    }\n\n}\n\n// Flat projection (e.g. just top-down, no perspective) - a degenerate isometric camera\nclass FlatCamera extends IsometricCamera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'flat';\n    }\n\n    update() {\n        // Axis is fixed to (0, 0) for flat camera\n        this.axis.x = 0;\n        this.axis.y = 0;\n\n        super.update();\n    }\n\n}\n","// Miscellaneous geo functions\n\nvar Geo;\nexport default Geo = {};\n\n// Projection constants\nGeo.tile_size = 256;\nGeo.half_circumference_meters = 20037508.342789244;\nGeo.circumference_meters = Geo.half_circumference_meters * 2;\nGeo.min_zoom_meters_per_pixel = Geo.circumference_meters / Geo.tile_size; // min zoom draws world as 2 tiles wide\nGeo.meters_per_pixel = [];\nGeo.meters_per_tile = [];\nGeo.max_zoom = 18;\nfor (var z=0; z <= Geo.max_zoom; z++) {\n    Geo.meters_per_pixel[z] = Geo.min_zoom_meters_per_pixel / Math.pow(2, z);\n    Geo.meters_per_tile[z] = Geo.circumference_meters / Math.pow(2, z);\n}\n\nGeo.metersPerPixel = function (zoom) {\n    return Geo.min_zoom_meters_per_pixel / Math.pow(2, zoom);\n};\n\n// Conversion functions based on an defined tile scale\nGeo.units_per_meter = [];\nGeo.tile_scale = 4096; // coordinates are locally scaled to the range [0, tile_scale]\nGeo.units_per_pixel = Geo.tile_scale / Geo.tile_size;\n\nfor (let z=0; z <= Geo.max_zoom; z++) {\n    Geo.units_per_meter[z] = Geo.tile_scale / (Geo.tile_size * Geo.meters_per_pixel[z]);\n}\n\n// Convert tile location to mercator meters - multiply by pixels per tile, then by meters per pixel, adjust for map origin\nGeo.metersForTile = function (tile) {\n    return {\n        x: tile.x * Geo.circumference_meters / Math.pow(2, tile.z) - Geo.half_circumference_meters,\n        y: -(tile.y * Geo.circumference_meters / Math.pow(2, tile.z) - Geo.half_circumference_meters)\n    };\n};\n\n/**\n   Given a point in mercator meters and a zoom level, return the tile X/Y/Z that the point lies in\n*/\nGeo.tileForMeters = function ([x, y], zoom) {\n    return {\n        x: Math.floor((x + Geo.half_circumference_meters) / (Geo.circumference_meters / Math.pow(2, zoom))),\n        y: Math.floor((-y + Geo.half_circumference_meters) / (Geo.circumference_meters / Math.pow(2, zoom))),\n        z: zoom\n    };\n};\n\n// Wrap a tile to positive #s for zoom\n// Optionally specify the axes to wrap\nGeo.wrapTile = function({ x, y, z }, mask = { x: true, y: false }) {\n    var m = (1 << z) - 1;\n    if (mask.x) {\n        x = x & m;\n    }\n    if (mask.y) {\n        y = y & m;\n    }\n    return { x, y, z };\n};\n\n/**\n   Convert mercator meters to lat-lng\n*/\nGeo.metersToLatLng = function ([x, y]) {\n\n    x /= Geo.half_circumference_meters;\n    y /= Geo.half_circumference_meters;\n\n    y = (2 * Math.atan(Math.exp(y * Math.PI)) - (Math.PI / 2)) / Math.PI;\n\n    x *= 180;\n    y *= 180;\n\n    return [x, y];\n};\n\n/**\n  Convert lat-lng to mercator meters\n*/\nGeo.latLngToMeters = function([x, y]) {\n\n    // Latitude\n    y = Math.log(Math.tan(y*Math.PI/360 + Math.PI/4)) / Math.PI;\n    y *= Geo.half_circumference_meters;\n\n    // Longitude\n    x *= Geo.half_circumference_meters / 180;\n\n    return [x, y];\n};\n\nGeo.wrapLng = function(x) {\n    if (x > 180 || x < -180) {\n        x = ((x + 180) % 360 + 360) % 360 - 180;\n    }\n    return x;\n};\n\n// Run an in-place transform function on each cooordinate in a GeoJSON geometry\nGeo.transformGeometry = function (geometry, transform) {\n    if (geometry.type === 'Point') {\n        transform(geometry.coordinates);\n    }\n    else if (geometry.type === 'LineString' || geometry.type === 'MultiPoint') {\n        geometry.coordinates.forEach(transform);\n    }\n    else if (geometry.type === 'Polygon' || geometry.type === 'MultiLineString') {\n        geometry.coordinates.forEach(coordinates => coordinates.forEach(transform));\n    }\n    else if (geometry.type === 'MultiPolygon') {\n        geometry.coordinates.forEach(polygon => {\n            polygon.forEach(coordinates => coordinates.forEach(transform));\n        });\n    }\n    // TODO: support GeometryCollection\n};\n\nGeo.boxIntersect = function (b1, b2) {\n    return !(\n        b2.sw.x > b1.ne.x ||\n        b2.ne.x < b1.sw.x ||\n        b2.sw.y > b1.ne.y ||\n        b2.ne.y < b1.sw.y\n    );\n};\n\n// Finds the axis-aligned bounding box for a polygon\nGeo.findBoundingBox = function (polygon) {\n    var min_x = Infinity,\n        max_x = -Infinity,\n        min_y = Infinity,\n        max_y = -Infinity;\n\n    // Only need to examine outer ring (polygon[0])\n    var num_coords = polygon[0].length;\n    for (var c=0; c < num_coords; c++) {\n        var coord = polygon[0][c];\n\n        if (coord[0] < min_x) {\n            min_x = coord[0];\n        }\n        if (coord[1] < min_y) {\n            min_y = coord[1];\n        }\n        if (coord[0] > max_x) {\n            max_x = coord[0];\n        }\n        if (coord[1] > max_y) {\n            max_y = coord[1];\n        }\n    }\n\n    return [min_x, min_y, max_x, max_y];\n};\n\n// Convert geometry type to one of: 'point', 'line', 'polygon'\nGeo.geometryType = function(type) {\n    if (type === 'Polygon' || type === 'MultiPolygon') {\n        return 'polygon';\n    }\n    else if (type === 'LineString' || type === 'MultiLineString') {\n        return 'line';\n    }\n    if (type === 'Point' || type === 'MultiPoint') {\n        return 'point';\n    }\n};\n\nGeo.centroid = function (polygon) {\n    let n = polygon.length;\n    let centroid = [0, 0];\n\n    for (let p=0; p < polygon.length; p++) {\n        centroid[0] += polygon[p][0];\n        centroid[1] += polygon[p][1];\n    }\n\n    centroid[0] /= n;\n    centroid[1] /= n;\n\n    return centroid;\n};\n\nGeo.multiCentroid = function (polygons) {\n    let n = polygons.length;\n    let centroid = [0, 0];\n\n    for (let p=0; p < polygons.length; p++) {\n        let polygon = polygons[p][0];\n        let c = Geo.centroid(polygon);\n        centroid[0] += c[0];\n        centroid[1] += c[1];\n    }\n\n    centroid[0] /= n;\n    centroid[1] /= n;\n\n    return centroid;\n};\n\nGeo.signedPolygonAreaSum = function (polygon) {\n    let area = 0;\n    let n = polygon.length;\n\n    for (let i = 0; i < n - 1; i++) {\n        let p0 = polygon[i];\n        let p1 = polygon[i+1];\n\n        area += p0[0] * p1[1] - p1[0] * p0[1];\n    }\n\n    area += polygon[n - 1][0] * polygon[0][1] - polygon[0][0] * polygon[n - 1][1];\n    return area;\n};\n\n// TODO: subtract inner ring areas\nGeo.polygonArea = function (polygon) {\n    return Math.abs(Geo.signedPolygonAreaSum(polygon)) / 2;\n};\n\nGeo.multiPolygonArea = function (polygons) {\n    let area = 0;\n\n    for (let p=0; p < polygons.length; p++) {\n        let polygon = polygons[p][0];\n        area += Geo.polygonArea(polygon);\n    }\n\n    return area;\n};\n\nGeo.ringWinding = function (ring) {\n    return Geo.signedPolygonAreaSum(ring) > 0 ? 'CW' : 'CCW';\n};\n\n// Enforce winding order on outer/inner rings\n// winding: 'CW' or 'CCW'\nGeo.enforceWinding = function (geom, winding) {\n    let polys;\n    if (geom.type === 'Polygon') {\n        polys = [geom.coordinates];\n    }\n    else if (geom.type === 'MultiPolygon') {\n        polys = geom.coordinates;\n    }\n    else {\n        return geom;\n    }\n\n    for (let p=0; p < polys.length; p++) {\n        let poly = polys[p];\n\n        // If first ring winding doesn't match, reverse all rings\n        // NOTE: assumes ring winding orders already alternate as expected\n        if (Geo.ringWinding(poly[0]) !== winding) {\n            for (let ring of poly) {\n                ring.reverse();\n            }\n        }\n    }\n    return geom;\n};\n","// WebGL constants - need to import these separately to make them available in the web worker\n\nvar gl;\nexport default gl = {};\n\n/* DataType */\ngl.BYTE                           = 0x1400;\ngl.UNSIGNED_BYTE                  = 0x1401;\ngl.SHORT                          = 0x1402;\ngl.UNSIGNED_SHORT                 = 0x1403;\ngl.INT                            = 0x1404;\ngl.UNSIGNED_INT                   = 0x1405;\ngl.FLOAT                          = 0x1406;\n","// WebGL context wrapper\n\nvar Context;\nexport default Context = {};\n\n// Setup a WebGL context\n// If no canvas element is provided, one is created and added to the document body\nContext.getContext = function getContext (canvas, options)\n{\n    var fullscreen = false;\n    if (canvas == null) {\n        canvas = document.createElement('canvas');\n        canvas.style.position = 'absolute';\n        canvas.style.top = 0;\n        canvas.style.left = 0;\n        canvas.style.zIndex = -1;\n        document.body.appendChild(canvas);\n        fullscreen = true;\n    }\n\n    var gl = canvas.getContext('webgl', options) || canvas.getContext('experimental-webgl', options);\n    if (!gl) {\n        throw new Error(\"Couldn't create WebGL context.\");\n    }\n\n    Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\n    if (fullscreen === true) {\n        window.addEventListener('resize', function () {\n            Context.resize(gl, window.innerWidth, window.innerHeight);\n        });\n    }\n\n    return gl;\n};\n\nContext.resize = function (gl, width, height, device_pixel_ratio)\n{\n    device_pixel_ratio = device_pixel_ratio || window.devicePixelRatio || 1;\n    gl.canvas.style.width = width + 'px';\n    gl.canvas.style.height = height + 'px';\n    gl.canvas.width = Math.round(gl.canvas.style.width * device_pixel_ratio);\n    gl.canvas.height = Math.round(gl.canvas.style.width * device_pixel_ratio);\n    gl.viewport(0, 0, gl.canvas.width, gl.canvas.height);\n};\n","// WebGL extension wrapper\n// Stores extensions by name and GL context\n\nlet extensions = new Map(); // map of extensions by GL context\n\nexport default function getExtension (gl, name) {\n    let exts = extensions.get(gl);\n    if (!exts) {\n        extensions.set(gl, new Map());\n        exts = extensions.get(gl);\n    }\n\n    if (!exts.get(name)) {\n        exts.set(name, gl.getExtension(name));\n    }\n    return exts.get(name);\n}\n","var GLSL = {};\nexport default GLSL;\n\n/**\n    Parse uniforms from a JS object, infers types and returns an array of objects with the\n    necessary information to set uniform values on a GL program. Each object in the returned\n    array has the form:\n    { type, method, name, value }\n\n    type: the GL uniform type, such as 'vec3', 'float', etc.\n    method: the GL uniform setter method to use, such as '1f', '3fv', etc.\n    name: the fully qualified name of the GL uniform location, e.g. 'array[0].field', etc.\n    value: the value to be passed to the GL uniform setter for that type, e.g. [1, 2, 3] for a vec3\n\n    Textures have special behavior: uniforms with string values are treated as textures, and\n    the string is used as a unique texture 'key' to be interpreted by the caller (which is responsible\n    for actually setting the uniforms). For example, this could be used as a key into a dictionary of\n    known texture names, or it could simply be used as a URL to dynamically load the texture from.\n*/\nGLSL.parseUniforms = function (uniforms, prefix = null) {\n    var parsed = [];\n\n    for (var name in uniforms) {\n        var key = name; // save the original name\n        var uniform = uniforms[name];\n        var u;\n\n        if (prefix) {\n            name = prefix + '.' + name;\n        }\n\n        // Single float\n        if (typeof uniform === 'number') {\n            parsed.push({\n                type: 'float',\n                method: '1f',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Array: vector, array of floats, array of textures, or array of structs\n        else if (Array.isArray(uniform)) {\n            // Numeric values\n            if (typeof uniform[0] === 'number') {\n                // float vectors (vec2, vec3, vec4)\n                if (uniform.length >= 2 && uniform.length <= 4) {\n                    parsed.push({\n                        type: 'vec' + uniform.length,\n                        method: uniform.length + 'fv',\n                        name,\n                        value: uniform,\n                        key,\n                        uniforms\n                    });\n                }\n                // float array\n                else if (uniform.length > 4) {\n                    parsed.push({\n                        type: 'float[]',\n                        method: '1fv',\n                        name: name + '[0]',\n                        value: uniform,\n                        key,\n                        uniforms\n                    });\n                }\n                // TODO: assume matrix for (typeof == Float32Array && length == 16)?\n            }\n            // Array of textures\n            else if (typeof uniform[0] === 'string') {\n                for (u=0; u < uniform.length; u++) {\n                    parsed.push({\n                        type: 'sampler2D',\n                        method: '1i',\n                        name: name + '[' + u + ']',\n                        value: uniform[u],\n                        key: u,\n                        uniforms: uniform\n                    });\n                }\n            }\n            // Array of arrays - but only arrays of vectors are allowed in this case\n            else if (Array.isArray(uniform[0]) && typeof uniform[0][0] === 'number') {\n                // float vectors (vec2, vec3, vec4)\n                if (uniform[0].length >= 2 && uniform[0].length <= 4) {\n                    // Set each vector in the array\n                    for (u=0; u < uniform.length; u++) {\n                        parsed.push({\n                            type: 'vec' + uniform[0].length,\n                            method: uniform[u].length + 'fv',\n                            name: name + '[' + u + ']',\n                            value: uniform[u],\n                            key: u,\n                            uniforms: uniform\n                        });\n                    }\n                }\n                // else error?\n            }\n            // Array of structures\n            else if (typeof uniform[0] === 'object') {\n                for (u=0; u < uniform.length; u++) {\n                    // Set each struct in the array\n                    parsed.push(...GLSL.parseUniforms(uniform[u], name + '[' + u + ']'));\n                }\n            }\n        }\n        // Boolean\n        else if (typeof uniform === 'boolean') {\n            parsed.push({\n                type: 'bool',\n                method: '1i',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Texture\n        else if (typeof uniform === 'string') {\n            parsed.push({\n                type: 'sampler2D',\n                method: '1i',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Structure\n        else if (typeof uniform === 'object') {\n            // Set each field in the struct\n            parsed.push(...GLSL.parseUniforms(uniform, name));\n        }\n\n        // TODO: support other non-float types? (int, etc.)\n    }\n\n    return parsed;\n};\n\n/**\n    Generate a GLSL variable definition from a JS object\n*/\nGLSL.defineVariable = function (name, value, prefix = null) {\n    var type, array;\n    var structs = '';\n    prefix = prefix ? prefix + '_' + name : name;\n\n    // Single float\n    if (typeof value === 'number') {\n        type = 'float';\n    }\n    // Multiple floats - vector or array\n    else if (Array.isArray(value)) {\n        // Numeric values\n        if (typeof value[0] === 'number') {\n            // float vectors (vec2, vec3, vec4)\n            if (value.length >= 2 && value.length <= 4) {\n                type = 'vec' + value.length;\n            }\n            // float array\n            else { //if (value.length > 4) {\n                type = 'float';\n                array = value.length;\n            }\n            // TODO: assume matrix for (typeof == Float32Array && length == 16)?\n        }\n        // Array of textures\n        else if (typeof value[0] === 'string') {\n            type = 'sampler2D';\n            array = value.length;\n        }\n        // Array of arrays - but only arrays of vectors are allowed in this case\n        else if (Array.isArray(value[0]) && typeof value[0][0] === 'number') {\n            // float vectors (vec2, vec3, vec4)\n            if (value[0].length >= 2 && value[0].length <= 4) {\n                type = 'vec' + value[0].length;\n            }\n            // else error?\n            array = value[0].length;\n        }\n        // Array of structures\n        else if (typeof value[0] === 'object') {\n            type = '_type_' + prefix; // custom struct name\n            array = value.length;\n            structs += GLSL.defineStruct(type, value[0], prefix) + '\\n'; // build & add to list of dependent structs\n        }\n    }\n    // Boolean\n    else if (typeof value === 'boolean') {\n        type = 'bool';\n    }\n    // Texture\n    else if (typeof value === 'string') {\n        type = 'sampler2D';\n    }\n    // Structure\n    else if (typeof value === 'object') {\n        type = '_type_' + prefix; // custom struct name\n        structs += GLSL.defineStruct(type, value, prefix) + '\\n'; // build & add to list of dependent structs\n    }\n\n    // Construct variable definition\n    var variable = '';\n    variable += `${type} ${name}`;\n    if (array) {\n        variable += `[${array}]`;\n    }\n    variable += ';\\n';\n\n    // Return the variable definition itself, and any dependent struct definitions\n    return { variable, structs };\n};\n\n/**\n    Generate a GLSL structure definition from a JS object\n*/\nGLSL.defineStruct = function (type, value, prefix = null) {\n    var struct = `struct ${type} {\\n`;\n    var dependents = '';\n    for (var field in value) {\n        var subvar = GLSL.defineVariable(field, value[field], prefix);\n        struct += '    ' + subvar.variable;\n        dependents += subvar.structs;\n    }\n    struct += '};\\n';\n    struct = dependents + struct;\n    return struct;\n};\n\n/**\n    Generate a GLSL uniform definition from a JS object\n*/\nGLSL.defineUniform = function (name, value) {\n    var def = GLSL.defineVariable(name, value);\n    def = def.structs + 'uniform ' + def.variable;\n    return def;\n};\n\n/**\n    Check for a uniform definition of 'name' in the provided GLSL source\n    Simple regex check for 'uniform' keyword and var name, does not attempt to parse/extract GLSL\n    NOTE: assumes comments have been stripped from source\n*/\nGLSL.isUniformDefined = function (name, source) {\n    // Match, in order:\n    // - the keyword 'uniform'\n    // - at least one character that is anything except a semicolon, ;\n    // - optionally, anything enclosed in curly braces, { ... } (an inline structure definition can go here)\n    // - optionally, any # of characters that is not a semicolon, ;\n    // - the name of the uniform\n\n    var re = new RegExp('uniform[^;]+(?:{[\\\\s\\\\S]*})?[^;]*\\\\b' + name + '\\\\b', 'g');\n    if (source.match(re)) {\n        return true;\n    }\n    return false;\n};\n\n/**\n    Check that a symbol is referenced in the GLSL source\n    NOTE: assumes comments have been stripped from source\n*/\nGLSL.isSymbolReferenced = function (name, source) {\n    var re = new RegExp('\\\\b' + name + '\\\\b', 'g');\n    if (source.search(re) >= 0) {\n        return true;\n    }\n    return false;\n};\n\n/**\n    Expand a single value or 2-element array into a 3-element array, with the last ( z )\n    coordinate defaulting to 1 (with option to specify). Also runs parseFloat to try to maintain\n    data integrity. Returns null if input couldn't be parsed.\n*/\nGLSL.expandVec3 = function (v, z = 1) {\n    let x;\n    if (Array.isArray(v) && v.length === 2) {\n        x = [...v, z].map(parseFloat);\n    }\n    else {\n        x = [v, v, v].map(parseFloat);\n    }\n\n    if (x && x.every(n => typeof n === 'number' && !isNaN(n))) {\n        return x;\n    }\n};\n\n/**\n    Expand a single value or 3-element array into a 4-element array, with the last (e.g. w or a)\n    coordinate defaulting to 1 (with option to specify). Also runs parseFloat to try to maintain\n    data integrity. Returns null if input couldn't be parsed.\n*/\nGLSL.expandVec4 = function (v, w = 1) {\n    let x;\n    if (Array.isArray(v) && v.length === 3) {\n        x = [...v, w].map(parseFloat);\n    }\n    else {\n        x = [v, v, v, w].map(parseFloat);\n    }\n\n    if (x && x.every(n => typeof n === 'number' && !isNaN(n))) {\n        return x;\n    }\n};\n\n\n","\nexport default class RenderState {\n\tconstructor (value, setup) {\n        setup(value);\n        this.value = value;\n        this.setup = setup;\n    }\n\n    set (value) {\n    \t// if the states are different, call the GL context for a state change\n    \tif (JSON.stringify(this.value) !== JSON.stringify(value)) {\n    \t\tthis.setup(value);\n    \t\tthis.value = value;\n    \t}\n    }\n\n    static initialize (gl) {\n    \t// Culling\n    \tRenderState.culling = new RenderState(\n    \t\t{ cull: true, face: gl.BACK },\n    \t\t(value) => {\n    \t\t\tif (value.cull) {\n    \t\t\t\tgl.enable(gl.CULL_FACE);\n            \t\tgl.cullFace(value.face);\n    \t\t\t} else {\n    \t\t\t\tgl.disable(gl.CULL_FACE);\n    \t\t\t}\n    \t\t}\n    \t);\n\n    \t// Blending mode\n    \tRenderState.blending = new RenderState(\n    \t\t{ blend: false, src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA},\n    \t\t(value) => {\n    \t\t\tif (value.blend) {\n            \t\tgl.enable(gl.BLEND);\n                \tgl.blendFunc(value.src, value.dst);\n    \t\t\t} else {\n    \t\t\t\tgl.disable(gl.BLEND);\n    \t\t\t}\n    \t\t}\n    \t);\n\n    \t// Depth write\n    \tRenderState.depth_write = new RenderState(\n    \t\t{ depth_write: true },\n    \t\t(value) => {\n        \t\tgl.depthMask(value.depth_write);\n    \t\t}\n    \t);\n\n    \t// Depth test\n    \tRenderState.depth_test = new RenderState(\n    \t\t{ depth_test: true, depth_func: gl.LEQUAL },\n    \t\t(value) => {\n    \t\t\tif (value.depth_test) {\n            \t\tgl.enable(gl.DEPTH_TEST);\n        \t\t\tgl.depthFunc(value.depth_func);\n    \t\t\t} else {\n            \t\tgl.disable(gl.DEPTH_TEST);\n    \t\t\t}\n    \t\t}\n    \t);\n    }\n}\n","/* global ShaderProgram */\n// GL program wrapper to cache uniform locations/values, do compile-time pre-processing\n// (injecting #defines and #pragma blocks into shaders), etc.\n\nimport GLSL from './glsl';\nimport Texture from './texture';\nimport getExtension from './extensions';\n\nimport log from 'loglevel';\nimport strip from 'strip-comments';\nimport { default as parseShaderErrors } from 'gl-shader-errors';\n\nexport default class ShaderProgram {\n\n    constructor(gl, vertex_source, fragment_source, options) {\n        options = options || {};\n\n        this.gl = gl;\n        this.program = null;\n        this.compiled = false;\n        this.compiling = false;\n        this.error = null;\n\n        // key/values inserted as #defines into shaders at compile-time\n        this.defines = Object.assign({}, options.defines||{});\n\n        // key/values for blocks that can be injected into shaders at compile-time\n        this.blocks = Object.assign({}, options.blocks||{});\n        this.block_scopes = Object.assign({}, options.block_scopes||{});\n\n        // list of extensions to activate\n        this.extensions = options.extensions || [];\n\n        // JS-object uniforms that are expected by this program\n        // If they are not found in the existing shader source, their types will be inferred and definitions\n        // for each will be injected.\n        this.dependent_uniforms = options.uniforms;\n\n        this.uniforms = {}; // program locations of uniforms, lazily added as each uniform is set\n        this.attribs = {}; // program locations of vertex attributes, lazily added as each attribute is accessed\n\n        this.vertex_source = vertex_source;\n        this.fragment_source = fragment_source;\n\n        this.id = ShaderProgram.id++;\n        ShaderProgram.programs[this.id] = this;\n        this.name = options.name; // can provide a program name (useful for debugging)\n    }\n\n    destroy() {\n        this.gl.useProgram(null);\n        this.gl.deleteProgram(this.program);\n        this.program = null;\n        this.uniforms = {};\n        this.attribs = {};\n        delete ShaderProgram.programs[this.id];\n        this.compiled = false;\n    }\n\n    // Use program wrapper with simple state cache\n    use() {\n        if (!this.compiled) {\n            return;\n        }\n\n        if (ShaderProgram.current !== this) {\n            this.gl.useProgram(this.program);\n        }\n        ShaderProgram.current = this;\n    }\n\n    compile() {\n        if (this.compiling) {\n            throw(new Error(`ShaderProgram.compile(): skipping for ${this.id} (${this.name}) because already compiling`));\n        }\n        this.compiling = true;\n        this.compiled = false;\n        this.error = null;\n\n        // Copy sources from pre-modified template\n        this.computed_vertex_source = this.vertex_source;\n        this.computed_fragment_source = this.fragment_source;\n\n        // Check for extension availability\n        let extensions = this.checkExtensions();\n\n        // Make list of defines to be injected later\n        var defines = this.buildDefineList();\n\n        // Inject user-defined blocks (arbitrary code points matching named #pragmas)\n        // Replace according to this pattern:\n        // #pragma tangram: [key]\n        // e.g. #pragma tangram: global\n\n        // Gather all block code snippets\n        var blocks = this.buildShaderBlockList();\n        var regexp;\n\n        for (var key in blocks) {\n            var block = blocks[key];\n            if (!block || (Array.isArray(block) && block.length === 0)) {\n                continue;\n            }\n\n            // First find code replace points in shaders\n            regexp = new RegExp('^\\\\s*#pragma\\\\s+tangram:\\\\s+' + key + '\\\\s*$', 'm');\n            var inject_vertex = this.computed_vertex_source.match(regexp);\n            var inject_fragment = this.computed_fragment_source.match(regexp);\n\n            // Avoid network request if nothing to replace\n            if (inject_vertex == null && inject_fragment == null) {\n                continue;\n            }\n\n            // Combine all blocks into one string\n            var source = '';\n            block.forEach(val => {\n                // Mark start and end of each block with metadata (which can be extracted from\n                // final source for error handling, debugging, etc.)\n                let mark = `${val.scope}, ${val.key}, ${val.num}`;\n                source += `\\n// tangram-block-start: ${mark}\\n`;\n                source += val.source;\n                source += `\\n// tangram-block-end: ${mark}\\n`;\n            });\n\n            // Inject\n            if (inject_vertex != null) {\n                this.computed_vertex_source = this.computed_vertex_source.replace(regexp, source);\n            }\n            if (inject_fragment != null) {\n                this.computed_fragment_source = this.computed_fragment_source.replace(regexp, source);\n            }\n\n            // Add a #define for this injection point\n            defines['TANGRAM_BLOCK_' + key.replace(/[\\s-]+/g, '_').toUpperCase()] = true;\n        }\n\n        // Clean-up any #pragmas that weren't replaced (to prevent compiler warnings)\n        regexp = new RegExp('^\\\\s*#pragma.*$', 'gm');\n        this.computed_vertex_source = this.computed_vertex_source.replace(regexp, '');\n        this.computed_fragment_source = this.computed_fragment_source.replace(regexp, '');\n\n        // Detect uniform definitions, inject any missing ones\n        this.ensureUniforms(this.dependent_uniforms);\n\n        // Build & inject extensions & defines\n        // This is done *after* code injection so that we can add defines for which code points were injected\n        let info = (this.name ? (this.name + ' / id ' + this.id) : ('id ' + this.id));\n        let header = `// Program: ${info}\\n` +\n            ShaderProgram.buildExtensionString(extensions);\n\n        defines['TANGRAM_VERTEX_SHADER'] = true;\n        defines['TANGRAM_FRAGMENT_SHADER'] = false;\n        this.computed_vertex_source = header + ShaderProgram.buildDefineString(defines) + this.computed_vertex_source;\n\n        defines['TANGRAM_VERTEX_SHADER'] = false;\n        defines['TANGRAM_FRAGMENT_SHADER'] = true;\n        this.computed_fragment_source = header + ShaderProgram.buildDefineString(defines) + this.computed_fragment_source;\n\n        // Add precision qualifier\n        this.computed_fragment_source = '#ifdef GL_ES\\nprecision highp float;\\n#endif\\n\\n' + this.computed_fragment_source;\n\n        // Compile & set uniforms to cached values\n        try {\n            this.program = ShaderProgram.updateProgram(this.gl, this.program, this.computed_vertex_source, this.computed_fragment_source);\n            this.compiled = true;\n            this.compiling = false;\n        }\n        catch(error) {\n            this.program = null;\n            this.compiled = false;\n            this.compiling = false;\n            this.error = error;\n\n            // shader error info\n            if (error.type === 'vertex' || error.type === 'fragment') {\n                this.shader_errors = error.errors;\n                for (let e of this.shader_errors) {\n                    e.type = error.type;\n                    e.block = this.block(error.type, e.line);\n                }\n            }\n\n            throw(new Error(`ShaderProgram.compile(): program ${this.id} (${this.name}) error:`, error));\n        }\n\n        this.use();\n        this.refreshUniforms();\n        this.refreshAttributes();\n    }\n\n    // Make list of defines (global, then program-specific)\n    buildDefineList() {\n        var d, defines = {};\n        for (d in ShaderProgram.defines) {\n            defines[d] = ShaderProgram.defines[d];\n        }\n        for (d in this.defines) {\n            defines[d] = this.defines[d];\n        }\n        return defines;\n    }\n\n    // Make list of shader blocks (global, then program-specific)\n    buildShaderBlockList() {\n        let key, blocks = {};\n\n        // Global blocks\n        for (key in ShaderProgram.blocks) {\n            blocks[key] = [];\n\n            if (Array.isArray(ShaderProgram.blocks[key])) {\n                blocks[key].push(\n                    ...ShaderProgram.blocks[key].map((source, num) => {\n                        return { key, source, num, scope: 'ShaderProgram' };\n                    })\n                );\n            }\n            else {\n                blocks[key] = [{ key, source: ShaderProgram.blocks[key], num: 0, scope: 'ShaderProgram' }];\n            }\n        }\n\n        // Program-specific blocks\n        for (key in this.blocks) {\n            blocks[key] = blocks[key] || [];\n\n            if (Array.isArray(this.blocks[key])) {\n                let scopes = (this.block_scopes && this.block_scopes[key]) || [];\n                let cur_scope = null, num = 0;\n\n                for (let b=0; b < this.blocks[key].length; b++) {\n                    // Count blocks relative to current scope\n                    if (scopes[b] !== cur_scope) {\n                        cur_scope = scopes[b];\n                        num = 0;\n                    }\n\n                    blocks[key].push({\n                        key,\n                        source: this.blocks[key][b],\n                        num,\n                        scope: cur_scope || this.name\n                    });\n\n                    num++;\n                }\n            }\n            else {\n                // TODO: address discrepancy in array vs. single-value blocks\n                // styles assume array when tracking block scopes\n                blocks[key].push({ key, source: this.blocks[key], num: 0, scope: this.name });\n            }\n        }\n        return blocks;\n    }\n\n    // Detect uniform definitions, inject any missing ones\n    ensureUniforms(uniforms) {\n        if (!uniforms) {\n            return;\n        }\n\n        var vs = strip(this.computed_vertex_source);\n        var fs = strip(this.computed_fragment_source);\n        var inject, vs_injections = [], fs_injections = [];\n\n        // Check for missing uniform definitions\n        for (var name in uniforms) {\n            inject = null;\n\n            // Check vertex shader\n            if (!GLSL.isUniformDefined(name, vs) && GLSL.isSymbolReferenced(name, vs)) {\n                if (!inject) {\n                    inject = GLSL.defineUniform(name, uniforms[name]);\n                }\n                log.trace(`Program ${this.name}: ${name} not defined in vertex shader, injecting: '${inject}'`);\n                vs_injections.push(inject);\n\n            }\n            // Check fragment shader\n            if (!GLSL.isUniformDefined(name, fs) && GLSL.isSymbolReferenced(name, fs)) {\n                if (!inject) {\n                    inject = GLSL.defineUniform(name, uniforms[name]);\n                }\n                log.trace(`Program ${this.name}: ${name} not defined in fragment shader, injecting: '${inject}'`);\n                fs_injections.push(inject);\n            }\n        }\n\n        // Inject missing uniforms\n        // NOTE: these are injected at the very top of the shaders, even before any #defines or #pragmas are added\n        // this could cause some issues with certain #pragmas, or other functions that might expect #defines\n        if (vs_injections.length > 0) {\n            this.computed_vertex_source = vs_injections.join('\\n') + this.computed_vertex_source;\n        }\n\n        if (fs_injections.length > 0) {\n            this.computed_fragment_source = fs_injections.join('\\n') + this.computed_fragment_source;\n        }\n    }\n\n    // Set uniforms from a JS object, with inferred types\n    setUniforms(uniforms, reset_texture_unit = true) {\n        if (!this.compiled) {\n            return;\n        }\n\n        // TODO: only update uniforms when changed\n\n        // Texture units must be tracked and incremented each time a texture sampler uniform is set.\n        // By default, the texture unit is reset to 0 each time setUniforms is called, but they can\n        // also be preserved, for example in cases where multiple calls to setUniforms are expected\n        // (e.g. program-specific uniforms followed by mesh-specific ones).\n        if (reset_texture_unit) {\n            this.texture_unit = 0;\n        }\n\n        // Parse uniform types and values from the JS object\n        var parsed = GLSL.parseUniforms(uniforms);\n\n        // Set each uniform\n        for (var uniform of parsed) {\n            if (uniform.type === 'sampler2D') {\n                // For textures, we need to track texture units, so we have a special setter\n                this.setTextureUniform(uniform.name, uniform.value);\n            }\n            else {\n                this.uniform(uniform.method, uniform.name, uniform.value);\n            }\n        }\n    }\n\n    // Cache some or all uniform values so they can be restored\n    saveUniforms(subset) {\n        let uniforms = subset || this.uniforms;\n        for (let u in uniforms) {\n            let uniform = this.uniforms[u];\n            if (uniform) {\n                uniform.saved_value = uniform.value;\n            }\n        }\n        this.saved_texture_unit = this.texture_unit || 0;\n    }\n\n    // Restore some or all uniforms to saved values\n    restoreUniforms(subset) {\n        let uniforms = subset || this.uniforms;\n        for (let u in uniforms) {\n            let uniform = this.uniforms[u];\n            if (uniform && uniform.saved_value) {\n                uniform.value = uniform.saved_value;\n                this.updateUniform(u);\n            }\n        }\n        this.texture_unit = this.saved_texture_unit || 0;\n    }\n\n    // Set a texture uniform, finds texture by name or creates a new one\n    setTextureUniform(uniform_name, texture_name) {\n        var texture = Texture.textures[texture_name];\n        if (texture == null) {\n            texture = new Texture(this.gl, texture_name);\n            texture.load(texture_name);\n        }\n\n        texture.bind(this.texture_unit);\n        this.uniform('1i', uniform_name, this.texture_unit);\n        this.texture_unit++; // TODO: track max texture units and log/throw errors\n    }\n\n    // ex: program.uniform('3f', 'position', x, y, z);\n    // TODO: only update uniforms when changed\n    uniform(method, name, ...value) { // 'value' is a method-appropriate arguments list\n        if (!this.compiled) {\n            return;\n        }\n\n        this.uniforms[name] = this.uniforms[name] || {};\n        let uniform = this.uniforms[name];\n        uniform.name = name;\n        if (uniform.location === undefined) {\n            uniform.location = this.gl.getUniformLocation(this.program, name);\n        }\n        uniform.method = 'uniform' + method;\n        uniform.value = value;\n        this.updateUniform(name);\n    }\n\n    // Set a single uniform\n    updateUniform(name) {\n        if (!this.compiled) {\n            return;\n        }\n\n        var uniform = this.uniforms[name];\n        if (!uniform || uniform.location == null) {\n            return;\n        }\n\n        this.use();\n        this.gl[uniform.method].apply(this.gl, [uniform.location].concat(uniform.value)); // call appropriate GL uniform method and pass through arguments\n    }\n\n    // Refresh uniform locations and set to last cached values\n    refreshUniforms() {\n        if (!this.compiled) {\n            return;\n        }\n\n        for (var u in this.uniforms) {\n            this.uniforms[u].location = this.gl.getUniformLocation(this.program, u);\n            this.updateUniform(u);\n        }\n    }\n\n    refreshAttributes() {\n        // var len = this.gl.getProgramParameter(this.program, this.gl.ACTIVE_ATTRIBUTES);\n        // for (var i=0; i < len; i++) {\n        //     var a = this.gl.getActiveAttrib(this.program, i);\n        // }\n        this.attribs = {};\n    }\n\n    // Get the location of a vertex attribute\n    attribute(name) {\n        if (!this.compiled) {\n            return;\n        }\n\n        var attrib = (this.attribs[name] = this.attribs[name] || {});\n        if (attrib.location != null) {\n            return attrib;\n        }\n\n        attrib.name = name;\n        attrib.location = this.gl.getAttribLocation(this.program, name);\n\n        // var info = this.gl.getActiveAttrib(this.program, attrib.location);\n        // attrib.type = info.type;\n        // attrib.size = info.size;\n\n        return attrib;\n    }\n\n    // Get shader source as string\n    source(type) {\n        if (type === 'vertex') {\n            return this.computed_vertex_source;\n        }\n        else if (type === 'fragment') {\n            return this.computed_fragment_source;\n        }\n    }\n\n    // Get shader source as array of line strings\n    lines(type) {\n        let source = this.source(type);\n        if (source) {\n            return source.split('\\n');\n        }\n        return [];\n    }\n\n    // Get a specific line from shader source\n    line(type, num) {\n        let source = this.lines(type);\n        if (source) {\n            return source[num];\n        }\n    }\n\n    // Get info on which shader block (if any) a particular line number in a shader is in\n    // Returns an object with the following info if a block is found: { name, line, source }\n    //  scope: where the shader block originated, either a style name, or global such as ShaderProgram\n    //  name: shader block name (e.g. 'color', 'position', 'global')\n    //  num: the block number *within* local scope (e.g. if a style has multiple 'color' blocks)\n    //  line: line number *within* the shader block (not the whole shader program), useful for error highlighting\n    //  source: the code for the line\n    // NOTE: this does a bruteforce loop over the shader source and looks for shader block start/end markers\n    // We could track line ranges for shader blocks as they are inserted, but as this code is only used for\n    // error handling on compilation failure, it was simpler to keep it separate than to burden the core\n    // compilation path.\n    block(type, num) {\n        let lines = this.lines(type);\n        let block;\n        for (let i=0; i < num && i < lines.length; i++) {\n            let line = lines[i];\n            let match = line.match(/\\/\\/ tangram-block-start: (\\w+), (\\w+), (\\d+)/);\n            if (match && match.length > 1) {\n                // mark current block\n                block = {\n                    scope: match[1],\n                    name: match[2],\n                    num: match[3]\n                };\n            }\n            else {\n                match = line.match(/\\/\\/ tangram-block-end: (\\w+), (\\w+), (\\d+)/);\n                if (match && match.length > 1) {\n                    block = null; // clear current block\n                }\n            }\n\n            // update line # and content\n            if (block) {\n                // init to -1 so that line 0 is first actual line of block code, after comment marker\n                block.line = (block.line == null) ? -1 : block.line + 1;\n                block.source = line;\n            }\n        }\n        return block;\n    }\n\n    // Returns list of available extensions from those requested\n    // Sets internal #defines indicating availability of each requested extension\n    checkExtensions() {\n        let exts = [];\n        for (let name of this.extensions) {\n            let ext = getExtension(this.gl, name);\n            let def = `TANGRAM_EXTENSION_${name}`;\n\n            this.defines[def] = (ext != null);\n\n            if (ext) {\n                exts.push(name);\n            }\n            else {\n                log.debug(`Could not enable extension '${name}'`);\n            }\n        }\n        return exts;\n    }\n\n}\n\n\n// Static methods and state\n\nShaderProgram.id = 0;           // assign each program a unique id\nShaderProgram.programs = {};    // programs, by id\nShaderProgram.current = null;   // currently bound program\n\n// Global config applied to all programs (duplicate properties for a specific program will take precedence)\nShaderProgram.defines = {};\nShaderProgram.blocks = {};\n\n// Turn an object of key/value pairs into single string of #define statements\nShaderProgram.buildDefineString = function (defines) {\n    var define_str = \"\";\n    for (var d in defines) {\n        if (defines[d] === false) {\n            continue;\n        }\n        else if (typeof defines[d] === 'boolean' && defines[d] === true) { // booleans are simple defines with no value\n            define_str += \"#define \" + d + \"\\n\";\n        }\n        else if (typeof defines[d] === 'number' && Math.floor(defines[d]) === defines[d]) { // int to float conversion to satisfy GLSL floats\n            define_str += \"#define \" + d + \" \" + defines[d].toFixed(1) + \"\\n\";\n        }\n        else { // any other float or string value\n            define_str += \"#define \" + d + \" \" + defines[d] + \"\\n\";\n        }\n    }\n    return define_str;\n};\n\n// Turn a list of extension names into single string of #extension statements\nShaderProgram.buildExtensionString = function (extensions) {\n    extensions = extensions || [];\n    let str = \"\";\n    for (let ext of extensions) {\n        str += `#extension GL_${ext} : enable\\n`;\n    }\n    return str;\n};\n\nShaderProgram.addBlock = function (key, ...blocks) {\n    ShaderProgram.blocks[key] = ShaderProgram.blocks[key] || [];\n    ShaderProgram.blocks[key].push(...blocks);\n};\n\n// Remove all global shader blocks for a given key\nShaderProgram.removeBlock = function (key) {\n    ShaderProgram.blocks[key] = [];\n};\n\nShaderProgram.replaceBlock = function (key, ...blocks) {\n    ShaderProgram.removeBlock(key);\n    ShaderProgram.addBlock(key, ...blocks);\n};\n\n// Compile & link a WebGL program from provided vertex and fragment shader sources\n// update a program if one is passed in. Create one if not. Alert and don't update anything if the shaders don't compile.\nShaderProgram.updateProgram = function (gl, program, vertex_shader_source, fragment_shader_source) {\n    try {\n        var vertex_shader = ShaderProgram.createShader(gl, vertex_shader_source, gl.VERTEX_SHADER);\n        var fragment_shader = ShaderProgram.createShader(gl, fragment_shader_source, gl.FRAGMENT_SHADER);\n    }\n    catch(err) {\n        log.error(err.message);\n        throw err;\n    }\n\n    gl.useProgram(null);\n    if (program != null) {\n        var old_shaders = gl.getAttachedShaders(program);\n        for(var i = 0; i < old_shaders.length; i++) {\n            gl.detachShader(program, old_shaders[i]);\n        }\n    } else {\n        program = gl.createProgram();\n    }\n\n    if (vertex_shader == null || fragment_shader == null) {\n        return program;\n    }\n\n    gl.attachShader(program, vertex_shader);\n    gl.attachShader(program, fragment_shader);\n\n    gl.deleteShader(vertex_shader);\n    gl.deleteShader(fragment_shader);\n\n    gl.linkProgram(program);\n\n    if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {\n        let message = new Error(\n            `WebGL program error:\n            VALIDATE_STATUS: ${gl.getProgramParameter(program, gl.VALIDATE_STATUS)}\n            ERROR: ${gl.getError()}\n            --- Vertex Shader ---\n            ${vertex_shader_source}\n            --- Fragment Shader ---\n            ${fragment_shader_source}`);\n\n        let error = { type: 'program', message };\n        log.error(error.message);\n        throw error;\n    }\n\n    return program;\n};\n\n// Compile a vertex or fragment shader from provided source\nShaderProgram.createShader = function (gl, source, stype) {\n    let shader = gl.createShader(stype);\n\n    gl.shaderSource(shader, source);\n    gl.compileShader(shader);\n\n    if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {\n        let type = (stype === gl.VERTEX_SHADER ? 'vertex' : 'fragment');\n        let message = gl.getShaderInfoLog(shader);\n        let errors = parseShaderErrors(message);\n        throw { type, message, errors };\n    }\n\n    return shader;\n};\n","// Generated from GLSL files, don't edit!\nvar shaderSources = {};\n\nshaderSources['gl/shaders/ambientLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct AmbientLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in AmbientLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"    light_accumulator_ambient += _light.ambient;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/directionalLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct DirectionalLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec3 direction;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in DirectionalLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    light_accumulator_ambient += _light.ambient;\\n\" +\n\"\\n\" +\n\"    float nDotVP = clamp(dot(_normal, -normalize(_light.direction)), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        float pf = 0.0;\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(normalize(_light.direction), _normal);\\n\" +\n\"            float eyeDotR = max(dot(normalize(_eyeToPoint), reflectVector), 0.0);\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"        light_accumulator_specular += _light.specular * pf;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/layer_order'] =\n\"// Apply layer ordering to avoid z-fighting\\n\" +\n\"void applyLayerOrder (float layer, inout vec4 position) {\\n\" +\n\"    position.z -= layer * TANGRAM_LAYER_DELTA * position.w;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/material'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Defines globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"// MATERIALS\\n\" +\n\"//\\n\" +\n\"struct Material {\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_EMISSION\\n\" +\n\"        vec4 emission;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"            vec3 emissionScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_AMBIENT\\n\" +\n\"        vec4 ambient;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"            vec3 ambientScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        vec4 diffuse;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"            vec3 diffuseScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        vec4 specular;\\n\" +\n\"        float shininess;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"            vec3 specularScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"        vec3 normalScale;\\n\" +\n\"        float normalAmount;\\n\" +\n\"    #endif\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"// Note: uniform is copied to a global instance to allow modification\\n\" +\n\"uniform Material u_material;\\n\" +\n\"Material material = u_material;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"uniform sampler2D u_material_emission_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"uniform sampler2D u_material_ambient_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"uniform sampler2D u_material_diffuse_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"uniform sampler2D u_material_specular_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"uniform sampler2D u_material_normal_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Global light accumulators for each property\\n\" +\n\"vec4 light_accumulator_ambient = vec4(0.0);\\n\" +\n\"vec4 light_accumulator_diffuse = vec4(0.0);\\n\" +\n\"#ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"    vec4 light_accumulator_specular = vec4(0.0);\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\\n\" +\n\"vec4 getSphereMap (in sampler2D _tex, in vec3 _eyeToPoint, in vec3 _normal, in vec2 _skew) {\\n\" +\n\"    vec3 eye = normalize(_eyeToPoint);\\n\" +\n\"    eye.xy -= _skew;\\n\" +\n\"    eye = normalize(eye);\\n\" +\n\"\\n\" +\n\"    vec3 r = reflect(eye, _normal);\\n\" +\n\"    r.z += 1.0;\\n\" +\n\"    float m = 2. * length(r);\\n\" +\n\"    vec2 uv = r.xy / m + .5;\\n\" +\n\"    return texture2D(_tex, uv);\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_TRIPLANAR\\n\" +\n\"vec3 getTriPlanarBlend (in vec3 _normal) {\\n\" +\n\"    vec3 blending = abs(_normal);\\n\" +\n\"    blending = normalize(max(blending, 0.00001));\\n\" +\n\"    float b = (blending.x + blending.y + blending.z);\\n\" +\n\"    return blending / b;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"vec4 getTriPlanar (in sampler2D _tex, in vec3 _pos, in vec3 _normal, in vec3 _scale) {\\n\" +\n\"    vec3 blending = getTriPlanarBlend(_normal);\\n\" +\n\"    vec4 xaxis = texture2D(_tex, fract(_pos.yz * _scale.x));\\n\" +\n\"    vec4 yaxis = texture2D(_tex, fract(_pos.xz * _scale.y));\\n\" +\n\"    vec4 zaxis = texture2D(_tex, fract(_pos.xy * _scale.z));\\n\" +\n\"    return  xaxis * blending.x + yaxis * blending.y + zaxis * blending.z;\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_PLANAR\\n\" +\n\"vec4 getPlanar (in sampler2D _tex, in vec3 _pos, in vec2 _scale) {\\n\" +\n\"    return texture2D( _tex, fract(_pos.xy * _scale.x) );\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"void calculateNormal (inout vec3 _normal) {\\n\" +\n\"    // Get NORMALMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_UV\\n\" +\n\"    _normal += texture2D(u_material_normal_texture, fract(v_texcoord*material.normalScale.xy)).rgb*2.0-1.0;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_PLANAR\\n\" +\n\"    vec3 normalTex = getPlanar(u_material_normal_texture, v_world_position.xyz, material.normalScale.xy).rgb*2.0-1.0;\\n\" +\n\"    _normal += normalTex;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_TRIPLANAR\\n\" +\n\"    vec3 normalTex = getTriPlanar(u_material_normal_texture, v_world_position.xyz, _normal, material.normalScale).rgb*2.0-1.0;\\n\" +\n\"    _normal += normalTex;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    _normal = normalize(_normal);\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"void calculateMaterial (in vec3 _eyeToPoint, inout vec3 _normal) {\\n\" +\n\"    // get EMISSION TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_UV\\n\" +\n\"        material.emission *= texture2D(u_material_emission_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_PLANAR\\n\" +\n\"        material.emission *= getPlanar(u_material_emission_texture, v_world_position.xyz, material.emissionScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_TRIPLANAR\\n\" +\n\"        material.emission *= getTriPlanar(u_material_emission_texture, v_world_position.xyz, _normal, material.emissionScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_SPHEREMAP\\n\" +\n\"        material.emission *= getSphereMap(u_material_emission_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get AMBIENT TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_UV\\n\" +\n\"        material.ambient *= texture2D(u_material_ambient_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_PLANAR\\n\" +\n\"        material.ambient *= getPlanar(u_material_ambient_texture, v_world_position.xyz, material.ambientScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_TRIPLANAR\\n\" +\n\"        material.ambient *= getTriPlanar(u_material_ambient_texture, v_world_position.xyz, _normal, material.ambientScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_SPHEREMAP\\n\" +\n\"        material.ambient *= getSphereMap(u_material_ambient_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get DIFFUSE TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_UV\\n\" +\n\"        material.diffuse *= texture2D(u_material_diffuse_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_PLANAR\\n\" +\n\"        material.diffuse *= getPlanar(u_material_diffuse_texture, v_world_position.xyz, material.diffuseScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_TRIPLANAR\\n\" +\n\"        material.diffuse *= getTriPlanar(u_material_diffuse_texture, v_world_position.xyz, _normal, material.diffuseScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_SPHEREMAP\\n\" +\n\"        material.diffuse *= getSphereMap(u_material_diffuse_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get SPECULAR TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_UV\\n\" +\n\"        material.specular *= texture2D(u_material_specular_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_PLANAR\\n\" +\n\"        material.specular *= getPlanar(u_material_specular_texture, v_world_position.xyz, material.specularScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_TRIPLANAR\\n\" +\n\"        material.specular *= getTriPlanar(u_material_specular_texture, v_world_position.xyz, _normal, material.specularScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_SPHEREMAP\\n\" +\n\"        material.specular *= getSphereMap(u_material_specular_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/pointLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct PointLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec4 position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"    float attenuationExponent;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"    float innerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"    float outerRadius;\\n\" +\n\"#endif\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in PointLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    float dist = length(_light.position.xyz - _eyeToPoint);\\n\" +\n\"\\n\" +\n\"    // Compute vector from surface to light position\\n\" +\n\"    vec3 VP = (_light.position.xyz - _eyeToPoint) / dist;\\n\" +\n\"\\n\" +\n\"    // Normalize the vector from surface to light position\\n\" +\n\"    float nDotVP = clamp(dot(VP, _normal), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    // Attenuation defaults\\n\" +\n\"    float attenuation = 1.0;\\n\" +\n\"    #ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"        float Rin = 1.0;\\n\" +\n\"        float e = _light.attenuationExponent;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"            float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"            float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"            attenuation = 1.0-(pow(d,e));\\n\" +\n\"        #else\\n\" +\n\"            // If no outer is provide behaves like:\\n\" +\n\"            // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"            float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"            attenuation = clamp(1.0/(pow(d,e)), 0.0, 1.0);\\n\" +\n\"        #endif\\n\" +\n\"    #else\\n\" +\n\"        float Rin = 0.0;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"                float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                // If no outer is provide behaves like:\\n\" +\n\"                // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"                float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"                attenuation = clamp(1.0/d, 0.0, 1.0);\\n\" +\n\"            #endif\\n\" +\n\"        #else\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float d = clamp(dist/_light.outerRadius, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                attenuation = 1.0;\\n\" +\n\"            #endif\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Computer accumulators\\n\" +\n\"    light_accumulator_ambient += _light.ambient * attenuation;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP * attenuation;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        float pf = 0.0; // power factor for shiny speculars\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(-VP, _normal);\\n\" +\n\"            float eyeDotR = max(0.0, dot(-normalize(_eyeToPoint), reflectVector));\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"\\n\" +\n\"        light_accumulator_specular += _light.specular * pf * attenuation;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_fragment'] =\n\"// Fragment shader for feature selection passes\\n\" +\n\"// Renders in silhouette according to selection (picking) color, or black if none defined\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_FEATURE_SELECTION\\n\" +\n\"    varying vec4 v_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    #ifdef TANGRAM_FEATURE_SELECTION\\n\" +\n\"        gl_FragColor = v_selection_color;\\n\" +\n\"    #else\\n\" +\n\"        gl_FragColor = vec4(0., 0., 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_globals'] =\n\"// Vertex attribute + varying for feature selection\\n\" +\n\"#if defined(TANGRAM_FEATURE_SELECTION) && defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"    attribute vec4 a_selection_color;\\n\" +\n\"    varying vec4 v_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_vertex'] =\n\"// Selection pass-specific rendering\\n\" +\n\"#if defined(TANGRAM_FEATURE_SELECTION) && defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"    if (a_selection_color.rgb == vec3(0.)) {\\n\" +\n\"        // Discard by forcing invalid triangle if we\\'re in the feature\\n\" +\n\"        // selection pass but have no selection info\\n\" +\n\"        // TODO: in some cases we may actually want non-selectable features to occlude selectable ones?\\n\" +\n\"        gl_Position = vec4(0., 0., 0., 1.);\\n\" +\n\"        return;\\n\" +\n\"    }\\n\" +\n\"    v_selection_color = a_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['gl/shaders/spherical_environment_map'] =\n\"// Spherical environment map\\n\" +\n\"// Based on: http://www.clicktorelease.com/blog/creating-spherical-environment-mapping-shader\\n\" +\n\"\\n\" +\n\"// view: location of camera\\n\" +\n\"// position: location of current point on surface\\n\" +\n\"// normal: normal of current point on surface\\n\" +\n\"// skew: skewing factor (used to compensate for altered vanishing point)\\n\" +\n\"// envmap: spherical environment map texture\\n\" +\n\"\\n\" +\n\"vec4 sphericalEnvironmentMap(vec3 view, vec3 position, vec3 normal, vec2 skew, sampler2D envmap) {\\n\" +\n\"    // Normalized vector from camera to surface\\n\" +\n\"    vec3 eye = normalize(position.xyz - view.xyz);\\n\" +\n\"\\n\" +\n\"    // Skew\\n\" +\n\"    eye.xy -= skew;\\n\" +\n\"    eye = normalize(eye);\\n\" +\n\"\\n\" +\n\"    // Reflection of eye off of surface normal\\n\" +\n\"    vec3 r = reflect(eye, normal);\\n\" +\n\"\\n\" +\n\"    // Map reflected vector onto the surface of a sphere\\n\" +\n\"    r.z += 1.;\\n\" +\n\"    float m = 2. * length(r);\\n\" +\n\"\\n\" +\n\"    // Adjust xy to account for spherical shape, and center in middle of texture\\n\" +\n\"    vec2 uv = r.xy / m + .5;\\n\" +\n\"\\n\" +\n\"    // Sample the environment map\\n\" +\n\"    return texture2D(envmap, uv);\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/spotLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct SpotLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec4 position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"    float attenuationExponent;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"    float innerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"    float outerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"    vec3 direction;\\n\" +\n\"    float spotCosCutoff;\\n\" +\n\"    float spotExponent;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in SpotLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    float dist = length(_light.position.xyz - _eyeToPoint);\\n\" +\n\"\\n\" +\n\"    // Compute vector from surface to light position\\n\" +\n\"    vec3 VP = (_light.position.xyz - _eyeToPoint) / dist;\\n\" +\n\"\\n\" +\n\"    // normal . light direction\\n\" +\n\"    float nDotVP = clamp(dot(_normal, VP), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    // Attenuation defaults\\n\" +\n\"    float attenuation = 1.0;\\n\" +\n\"    #ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"        float Rin = 1.0;\\n\" +\n\"        float e = _light.attenuationExponent;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"            float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"            float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"            attenuation = 1.0-(pow(d,e));\\n\" +\n\"        #else\\n\" +\n\"            // If no outer is provide behaves like:\\n\" +\n\"            // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"            float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"            attenuation = clamp(1.0/(pow(d,e)), 0.0, 1.0);\\n\" +\n\"        #endif\\n\" +\n\"    #else\\n\" +\n\"        float Rin = 0.0;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"                float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                // If no outer is provide behaves like:\\n\" +\n\"                // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"                float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"                attenuation = clamp(1.0/d, 0.0, 1.0);\\n\" +\n\"            #endif\\n\" +\n\"        #else\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float d = clamp(dist/_light.outerRadius, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                attenuation = 1.0;\\n\" +\n\"            #endif\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // spotlight attenuation factor\\n\" +\n\"    float spotAttenuation = 0.0;\\n\" +\n\"\\n\" +\n\"    // See if point on surface is inside cone of illumination\\n\" +\n\"    float spotDot = clamp(dot(-VP, normalize(_light.direction)), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    if (spotDot >= _light.spotCosCutoff) {\\n\" +\n\"        spotAttenuation = pow(spotDot, _light.spotExponent);\\n\" +\n\"    }\\n\" +\n\"\\n\" +\n\"    light_accumulator_ambient += _light.ambient * attenuation * spotAttenuation;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP * attenuation * spotAttenuation;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        // Power factor for shiny speculars\\n\" +\n\"        float pf = 0.0;\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(-VP, _normal);\\n\" +\n\"            float eyeDotR = max(dot(-normalize(_eyeToPoint), reflectVector), 0.0);\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"        light_accumulator_specular += _light.specular * pf * attenuation * spotAttenuation;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/world_position_wrap'] =\n\"// Define a wrap value for world coordinates (allows more precision at higher zooms)\\n\" +\n\"// e.g. at wrap 1000, the world space will wrap every 1000 meters\\n\" +\n\"#if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"    vec2 world_position_anchor = vec2(floor(u_tile_origin / TANGRAM_WORLD_POSITION_WRAP) * TANGRAM_WORLD_POSITION_WRAP);\\n\" +\n\"\\n\" +\n\"    // Convert back to absolute world position if needed\\n\" +\n\"    vec4 absoluteWorldPosition () {\\n\" +\n\"        return vec4(v_world_position.xy + world_position_anchor, v_world_position.z, v_world_position.w);\\n\" +\n\"    }\\n\" +\n\"#else\\n\" +\n\"    vec4 absoluteWorldPosition () {\\n\" +\n\"        return v_world_position;\\n\" +\n\"    }\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['styles/points/points_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"\\n\" +\n\"uniform sampler2D u_texture;\\n\" +\n\"\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec2 v_texcoord;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"// Alpha discard threshold (substitute for alpha blending)\\n\" +\n\"#ifndef TANGRAM_ALPHA_DISCARD\\n\" +\n\"#define TANGRAM_ALPHA_DISCARD 0.5\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Alpha fade range for edges of points\\n\" +\n\"#ifndef TANGRAM_FADE_RANGE\\n\" +\n\"#define TANGRAM_FADE_RANGE .15\\n\" +\n\"#endif\\n\" +\n\"#define TANGRAM_FADE_START (1. - TANGRAM_FADE_RANGE)\\n\" +\n\"\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"\\n\" +\n\"    // Apply a texture\\n\" +\n\"    #ifdef TANGRAM_POINT_TEXTURE\\n\" +\n\"        color *= texture2D(u_texture, v_texcoord);\\n\" +\n\"    // Draw a point\\n\" +\n\"    #else\\n\" +\n\"        // Fade alpha near circle edge\\n\" +\n\"        vec2 uv = v_texcoord * 2. - 1.;\\n\" +\n\"        float point_dist = length(uv);\\n\" +\n\"        color.a = clamp(1. - (smoothstep(0., TANGRAM_FADE_RANGE, (point_dist - TANGRAM_FADE_START)) / TANGRAM_FADE_RANGE), 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // If blending is off, use alpha discard as a lower-quality substitute\\n\" +\n\"    #ifndef TANGRAM_BLEND_OVERLAY\\n\" +\n\"        if (color.a < TANGRAM_ALPHA_DISCARD) {\\n\" +\n\"            discard;\\n\" +\n\"        }\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Manually un-multiply alpha, for cases where texture has pre-multiplied alpha\\n\" +\n\"    #ifdef TANGRAM_UNMULTIPLY_ALPHA\\n\" +\n\"        color.rgb /= max(color.a, 0.001);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"    #pragma tangram: filter\\n\" +\n\"\\n\" +\n\"    gl_FragColor = color;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/points/points_vertex'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"\\n\" +\n\"uniform mat4 u_model;\\n\" +\n\"uniform mat4 u_modelView;\\n\" +\n\"\\n\" +\n\"attribute vec4 a_position;\\n\" +\n\"attribute vec4 a_shape;\\n\" +\n\"attribute vec4 a_color;\\n\" +\n\"attribute vec2 a_texcoord;\\n\" +\n\"attribute vec2 a_offset;\\n\" +\n\"\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec2 v_texcoord;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"vec2 rotate2D(vec2 _st, float _angle) {\\n\" +\n\"    return mat2(cos(_angle),-sin(_angle),\\n\" +\n\"                sin(_angle),cos(_angle)) * _st;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Adds vertex shader support for feature selection\\n\" +\n\"    #pragma tangram: feature-selection-vertex\\n\" +\n\"\\n\" +\n\"    v_color = a_color;\\n\" +\n\"    v_texcoord = a_texcoord;\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = u_modelView * vec4(a_position.xyz * 32767., 1.);\\n\" +\n\"\\n\" +\n\"    // Apply positioning and scaling in screen space\\n\" +\n\"    float zscale = fract(u_map_position.z) * (a_shape.w * 256. - 1.) + 1.;\\n\" +\n\"    // float zscale = log(fract(u_map_position.z) + 1.) / log(2.) * (a_shape.w - 1.) + 1.;\\n\" +\n\"    vec2 shape = a_shape.xy * 256. * zscale;     //\\n\" +\n\"    vec2 offset = vec2(a_offset.x, -a_offset.y); // flip y to make it point down\\n\" +\n\"    float theta = radians(a_shape.z * 360.);\\n\" +\n\"\\n\" +\n\"    shape = rotate2D(shape, theta);             // apply rotation to vertex\\n\" +\n\"    shape += rotate2D(offset * 32767., theta);  // apply offset on rotated axis (e.g. so line labels follow text axis)\\n\" +\n\"\\n\" +\n\"    // World coordinates for 3d procedural textures\\n\" +\n\"    v_world_position = u_model * position;\\n\" +\n\"    v_world_position.xy += shape * u_meters_per_pixel;\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"        v_world_position.xy -= world_position_anchor;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify position before camera projection\\n\" +\n\"    #pragma tangram: position\\n\" +\n\"\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_LAYER_ORDER\\n\" +\n\"        applyLayerOrder(a_position.w * 32767., position);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    position.xy += shape * 2. * position.w / u_resolution;\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/polygons/polygons_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"\\n\" +\n\"varying vec4 v_position;\\n\" +\n\"varying vec3 v_normal;\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    varying vec4 v_lighting;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"    vec3 normal = v_normal;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"        calculateNormal(normal);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify normal before lighting\\n\" +\n\"    #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"    // Modify color and material properties before lighting\\n\" +\n\"    #if !defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT)\\n\" +\n\"        color = calculateLighting(v_position.xyz - u_eye, normal, color);\\n\" +\n\"    #elif defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        color = v_lighting;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify color after lighting (filter-like effects that don\\'t require a additional render passes)\\n\" +\n\"    #pragma tangram: filter\\n\" +\n\"\\n\" +\n\"    gl_FragColor = color;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/polygons/polygons_vertex'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat4 u_model;\\n\" +\n\"uniform mat4 u_modelView;\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"\\n\" +\n\"attribute vec4 a_position;\\n\" +\n\"attribute vec4 a_color;\\n\" +\n\"\\n\" +\n\"// Optional normal attribute, otherwise default to up\\n\" +\n\"#ifdef TANGRAM_NORMAL_ATTRIBUTE\\n\" +\n\"    attribute vec3 a_normal;\\n\" +\n\"    #define TANGRAM_NORMAL a_normal\\n\" +\n\"#else\\n\" +\n\"    #define TANGRAM_NORMAL vec3(0., 0., 1.)\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Optional dynamic line extrusion\\n\" +\n\"#ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"    // xy: extrusion direction in xy plane\\n\" +\n\"    // z:  half-width of line (amount to extrude)\\n\" +\n\"    // w:  scaling factor for interpolating width between zooms\\n\" +\n\"    attribute vec4 a_extrude;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"varying vec4 v_position;\\n\" +\n\"varying vec3 v_normal;\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"// Optional texture UVs\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    attribute vec2 a_texcoord;\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    varying vec4 v_lighting;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Adds vertex shader support for feature selection\\n\" +\n\"    #pragma tangram: feature-selection-vertex\\n\" +\n\"\\n\" +\n\"    // Texture UVs\\n\" +\n\"    #ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"        v_texcoord = a_texcoord;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = vec4(a_position.xyz * 32767., 1.);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"        vec2 extrude = a_extrude.xy * 255.;\\n\" +\n\"        float width = a_extrude.z * 32767.;\\n\" +\n\"        float scale = a_extrude.w * 255.;\\n\" +\n\"\\n\" +\n\"        // Keep line width constant in screen-space\\n\" +\n\"        float zscale = u_tile_origin.z - u_map_position.z;\\n\" +\n\"        width *= pow(2., zscale);\\n\" +\n\"\\n\" +\n\"        // Smoothly interpolate line width between zooms\\n\" +\n\"        width = mix(width, width * scale, -zscale);\\n\" +\n\"\\n\" +\n\"        // Modify line width before extrusion\\n\" +\n\"        #pragma tangram: width\\n\" +\n\"\\n\" +\n\"        position.xy += extrude * width;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // World coordinates for 3d procedural textures\\n\" +\n\"    v_world_position = u_model * position;\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"        v_world_position.xy -= world_position_anchor;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Adjust for tile and view position\\n\" +\n\"    position = u_modelView * position;\\n\" +\n\"\\n\" +\n\"    // Modify position before camera projection\\n\" +\n\"    #pragma tangram: position\\n\" +\n\"\\n\" +\n\"    // Setup varyings\\n\" +\n\"    v_position = position;\\n\" +\n\"    v_normal = normalize(u_normalMatrix * TANGRAM_NORMAL);\\n\" +\n\"    v_color = a_color;\\n\" +\n\"\\n\" +\n\"    // Vertex lighting\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        vec4 color = a_color;\\n\" +\n\"        vec3 normal = TANGRAM_NORMAL;\\n\" +\n\"\\n\" +\n\"        // Modify normal before lighting\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"        // Modify color and material properties before lighting\\n\" +\n\"        #pragma tangram: color\\n\" +\n\"\\n\" +\n\"        v_lighting = calculateLighting(position.xyz, normal, color);\\n\" +\n\"        v_color = color;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Camera\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"    applyLayerOrder(a_position.w * 32767., position);\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nmodule.exports = shaderSources;\n","/*global Texture */\n// Texture management\nimport Utils from '../utils/utils';\nimport subscribeMixin from '../utils/subscribe';\nimport WorkerBroker from '../utils/worker_broker';\nimport Builders from '../styles/builders';\nimport log from 'loglevel';\n\n// GL texture wrapper object for keeping track of a global set of textures, keyed by a unique user-defined name\nexport default class Texture {\n\n    constructor(gl, name, options = {}) {\n        this.gl = gl;\n        this.texture = gl.createTexture();\n        if (this.texture) {\n            this.valid = true;\n        }\n        this.bind();\n        this.image = null;      // an Image object/element that is the source for this texture\n        this.canvas = null;     // a Canvas object/element that is the source for this texture\n        this.loading = null;    // a Promise object to track the loading state of this texture\n\n        // Default to a 1-pixel black texture so we can safely render while we wait for an image to load\n        // See: http://stackoverflow.com/questions/19722247/webgl-wait-for-texture-to-load\n        this.setData(1, 1, new Uint8Array([0, 0, 0, 255]), { filtering: 'nearest' });\n\n        // TODO: better support for non-URL sources: canvas/video elements, raw pixel buffers\n\n        this.name = name;\n        this.filtering = options.filtering;\n\n        // Destroy previous texture if present\n        if (Texture.textures[this.name]) {\n            Texture.textures[this.name].destroy();\n        }\n\n        Texture.textures[this.name] = this;\n\n        this.sprites = options.sprites;\n        this.texcoords = {};\n    }\n\n    // Destroy a single texture instance\n    destroy() {\n        if (!this.valid) {\n            return;\n        }\n        this.gl.deleteTexture(this.texture);\n        this.texture = null;\n        delete this.data;\n        this.data = null;\n        delete Texture.textures[this.name];\n        this.valid = false;\n    }\n\n    bind(unit) {\n        if (!this.valid) {\n            return;\n        }\n        if (typeof unit === 'number') {\n            if (Texture.activeUnit !== unit) {\n                this.gl.activeTexture(this.gl.TEXTURE0 + unit);\n                Texture.activeUnit = unit;\n            }\n        }\n        if (Texture.activeTexture !== this.texture) {\n            this.gl.bindTexture(this.gl.TEXTURE_2D, this.texture);\n            Texture.activeTexture = this.texture;\n        }\n    }\n\n    // Loads a texture from a URL\n    load(url, options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        if (Texture.base_url) {\n            url = Utils.addBaseURL(url, Texture.base_url);\n        }\n\n        this.loading = new Promise((resolve, reject) => {\n            this.image = new Image();\n            this.image.onload = () => {\n                try {\n                    this.update(options);\n                    this.setTextureFiltering(options);\n                    this.calculateSprites();\n\n                    this.canvas = null; // mutually exclusive with other types\n                    this.data = null;\n                }\n                catch (e) {\n                    log.warn(`Texture: failed to load url: '${url}'`, e, options);\n                    Texture.trigger('warning', { message: `Failed to load texture from ${url}`, error: e, texture: options });\n                }\n\n                resolve(this);\n            };\n            this.image.onerror = e => {\n                // Warn and resolve on error\n                log.warn(`Texture: failed to load url: '${url}'`, e, options);\n                Texture.trigger('warning', { message: `Failed to load texture from ${url}`, error: e, texture: options });\n                resolve(this);\n            };\n            this.image.crossOrigin = 'anonymous';\n            this.image.src = url;\n        });\n        return this.loading;\n    }\n\n    // Sets texture to a raw image buffer\n    setData(width, height, data, options = {}) {\n        this.width = width;\n        this.height = height;\n        this.data = data;\n\n        this.image = null; // mutually exclusive with other types\n        this.canvas = null;\n\n        this.update(options);\n        this.setTextureFiltering(options);\n    }\n\n    // Sets the texture to track a canvas element\n    setCanvas(canvas, options) {\n        this.canvas = canvas;\n        this.update(options);\n        this.setTextureFiltering(options);\n\n        this.image = null; // mutually exclusive with other types\n        this.data = null;\n    }\n\n    // Uploads current image or buffer to the GPU (can be used to update animated textures on the fly)\n    update(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        this.bind();\n        this.gl.pixelStorei(this.gl.UNPACK_FLIP_Y_WEBGL, (options.UNPACK_FLIP_Y_WEBGL === false ? false : true));\n        this.gl.pixelStorei(this.gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, options.UNPACK_PREMULTIPLY_ALPHA_WEBGL || false);\n\n        // Image element\n        if (this.image && this.image.complete) {\n            this.width = this.image.width;\n            this.height = this.image.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.image);\n        }\n        // Canvas element\n        else if (this.canvas) {\n            this.width = this.canvas.width;\n            this.height = this.canvas.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.canvas);\n        }\n        // Raw image buffer\n        else if (this.width && this.height) { // NOTE: this.data can be null, to zero out texture\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.width, this.height, 0, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.data);\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Determines appropriate filtering mode\n    setTextureFiltering(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        options.filtering = options.filtering || this.filtering || 'linear';\n\n        var gl = this.gl;\n        this.bind();\n\n        // For power-of-2 textures, the following presets are available:\n        // mipmap: linear blend from nearest mip\n        // linear: linear blend from original image (no mips)\n        // nearest: nearest pixel from original image (no mips, 'blocky' look)\n        if (Utils.isPowerOf2(this.width) && Utils.isPowerOf2(this.height)) {\n            this.power_of_2 = true;\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, options.TEXTURE_WRAP_S || (options.repeat && gl.REPEAT) || gl.CLAMP_TO_EDGE);\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, options.TEXTURE_WRAP_T || (options.repeat && gl.REPEAT) || gl.CLAMP_TO_EDGE);\n\n            // gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, options.TEXTURE_WRAP_S || gl.REPEAT);\n            // gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, options.TEXTURE_WRAP_T || gl.REPEAT);\n\n            if (options.filtering === 'mipmap') {\n                log.trace('power-of-2 MIPMAP');\n                this.filtering = 'mipmap';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR_MIPMAP_LINEAR); // TODO: use trilinear filtering by defualt instead?\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n                gl.generateMipmap(gl.TEXTURE_2D);\n            }\n            else if (options.filtering === 'linear') {\n                log.trace('power-of-2 LINEAR');\n                this.filtering = 'linear';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n            }\n            else if (options.filtering === 'nearest') {\n                log.trace('power-of-2 NEAREST');\n                this.filtering = 'nearest';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n            }\n        }\n        else {\n            // WebGL has strict requirements on non-power-of-2 textures:\n            // No mipmaps and must clamp to edge\n            this.power_of_2 = false;\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n            if (options.filtering === 'nearest') {\n                log.trace('power-of-2 NEAREST');\n                this.filtering = 'nearest';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n            }\n            else { // default to linear for non-power-of-2 textures\n                log.trace('power-of-2 LINEAR');\n                this.filtering = 'linear';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n            }\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Pre-calc sprite regions for a texture sprite in UV [0, 1] space\n    calculateSprites() {\n        if (this.sprites) {\n            for (let s in this.sprites) {\n                let sprite = this.sprites[s];\n\n                // Map [0, 0] to [1, 1] coords to the appropriate sprite sub-area of the texture\n                this.texcoords[s] = Builders.getTexcoordsForSprite(\n                    [sprite[0], sprite[1]],\n                    [sprite[2], sprite[3]],\n                    [this.width, this.height]\n                );\n            }\n        }\n    }\n\n}\n\n\n// Static/class methods and state\n\n// Destroy all texture instances for a given GL context\nTexture.destroy = function (gl) {\n    var textures = Object.keys(Texture.textures);\n    for (var t of textures) {\n        var texture = Texture.textures[t];\n        if (texture.gl === gl) {\n            log.trace(`destroying Texture ${texture.name}`);\n            texture.destroy();\n        }\n    }\n};\n\n// Get sprite sub-area to use for texture coordinates (default is [0, 1])\nTexture.getSpriteTexcoords = function (texname, sprite) {\n    let texture = Texture.textures[texname];\n    return texture && texture.texcoords[sprite];\n};\n\n// Create a set of textures keyed in an object\n// Optionally load each if it has a URL specified\nTexture.createFromObject = function (gl, textures) {\n    let loading = [];\n    if (textures) {\n        for (let texname in textures) {\n            let config = textures[texname];\n            let texture = new Texture(gl, texname, config);\n            if (config.url) {\n                loading.push(texture.load(config.url, config));\n            }\n        }\n    }\n    return Promise.all(loading);\n};\n\n// Get metadata for a texture by name\n// Returns via promise, in case texture is still loading\n// Can be called on main thread from worker, to sync texture info to worker\nTexture.getInfo = function (name) {\n    // Get info for all textures by default\n    if (!name) {\n        name = Object.keys(Texture.textures);\n    }\n\n    // Get multiple textures\n    if (Array.isArray(name)) {\n        return Promise.all(name.map(n => Texture.getInfo(n)));\n    }\n\n    // Get single texture\n    var tex = Texture.textures[name];\n    if (tex) {\n        // Wait for this texture to finish loading, or return immediately\n        var loading = tex.loading || Promise.resolve(tex);\n        return loading.then(() => {\n            // Return a subset of texture info\n            // (compatible w/structured cloning, suitable for passing to a worker)\n            return {\n                name: tex.name,\n                width: tex.width,\n                height: tex.height,\n                sprites: tex.sprites,\n                texcoords: tex.texcoords,\n                filtering: tex.filtering,\n                power_of_2: tex.power_of_2,\n                valid: tex.valid\n            };\n        });\n    }\n    else {\n        // No texture found\n        return Promise.resolve(null);\n    }\n};\n\n// Sync texture info to worker\n// Called from worker, gets info on one or more textures info from main thread via remote call, then stores it\n// locally in worker. 'textures' can be an array of texture names to sync, or if null, all textures are synced.\nTexture.syncTexturesToWorker = function (names) {\n    return WorkerBroker.postMessage('Texture', 'getInfo', names).\n        then(textures => {\n            for (var tex of textures) {\n                Texture.textures[tex.name] = tex;\n            }\n            return Texture.textures;\n        });\n};\n\n// Global set of textures, by name\nTexture.textures = {};\nTexture.boundTexture = -1;\nTexture.activeUnit = -1;\n\nTexture.base_url = null; // optional base URL to add to textures\n\nsubscribeMixin(Texture);\n","// Creates a Vertex Array Object if the extension is available, or falls back on standard attribute calls\n\nimport log from 'loglevel';\n\nvar VertexArrayObject;\nexport default VertexArrayObject = {};\n\nVertexArrayObject.disabled = false; // set to true to disable VAOs even if extension is available\nVertexArrayObject.bound_vao = null; // currently bound VAO\n\nVertexArrayObject.init = function (gl) {\n    if (VertexArrayObject.ext == null) {\n        if (VertexArrayObject.disabled !== true) {\n            VertexArrayObject.ext = gl.getExtension(\"OES_vertex_array_object\");\n        }\n\n        if (VertexArrayObject.ext != null) {\n            log.info('Vertex Array Object extension available');\n        }\n        else if (VertexArrayObject.disabled !== true) {\n            log.warn('Vertex Array Object extension NOT available');\n        }\n        else {\n            log.warn('Vertex Array Object extension force disabled');\n        }\n    }\n};\n\nVertexArrayObject.create = function (setup, teardown) {\n    let vao = {};\n    vao.setup = setup;\n    vao.teardown = teardown;\n\n    let ext = VertexArrayObject.ext;\n    if (ext != null) {\n        vao._vao = ext.createVertexArrayOES();\n        ext.bindVertexArrayOES(vao._vao);\n    }\n\n    vao.setup(true);\n\n    return vao;\n};\n\nVertexArrayObject.bind = function (vao) {\n    let ext = VertexArrayObject.ext;\n    if (vao != null) {\n        if (ext != null && vao._vao != null) {\n            ext.bindVertexArrayOES(vao._vao);\n            VertexArrayObject.bound_vao = vao;\n        }\n        else {\n            vao.setup(false);\n        }\n    }\n    else {\n        if (ext != null) {\n            ext.bindVertexArrayOES(null);\n        }\n        else if (VertexArrayObject.bound_vao != null && typeof VertexArrayObject.bound_vao.teardown === 'function') {\n            VertexArrayObject.bound_vao.teardown();\n        }\n        VertexArrayObject.bound_vao = null;\n    }\n};\n","/* global VBOMesh */\n// Manage rendering for primitives\nimport GLSL from './glsl';\nimport ShaderProgram from './shader_program';\nimport Texture from './texture';\nimport VertexArrayObject from './vao';\nimport log from 'loglevel';\n\n// A single mesh/VBO, described by a vertex layout, that can be drawn with one or more programs\nexport default class VBOMesh  {\n\n    constructor(gl, vertex_data, vertex_layout, options) {\n        options = options || {};\n\n        this.gl = gl;\n        this.vertex_data = vertex_data; // typed array\n        this.vertex_layout = vertex_layout;\n        this.buffer = this.gl.createBuffer();\n        this.draw_mode = options.draw_mode || this.gl.TRIANGLES;\n        this.data_usage = options.data_usage || this.gl.STATIC_DRAW;\n        this.vertices_per_geometry = 3; // TODO: support lines, strip, fan, etc.\n        this.uniforms = options.uniforms;\n        this.retain = options.retain || false; // whether to retain mesh data in CPU after uploading to GPU\n\n        this.vertex_count = this.vertex_data.byteLength / this.vertex_layout.stride;\n        this.geometry_count = this.vertex_count / this.vertices_per_geometry;\n        this.vaos = new Map(); // map of VertexArrayObjects, keyed by program\n\n        this.gl.bindBuffer(this.gl.ARRAY_BUFFER, this.buffer);\n        this.gl.bufferData(this.gl.ARRAY_BUFFER, this.vertex_data, this.data_usage);\n\n        if (!this.retain) {\n            delete this.vertex_data;\n        }\n        this.valid = true;\n    }\n\n    // Render, by default with currently bound program, or otherwise with optionally provided one\n    render(options = {}) {\n        if (!this.valid) {\n            return false;\n        }\n\n        if (typeof this._render_setup === 'function') {\n            this._render_setup();\n        }\n\n        var program = options.program || ShaderProgram.current;\n        program.use();\n\n        if (this.uniforms) {\n            program.saveUniforms(this.uniforms);\n            program.setUniforms(this.uniforms, false); // don't reset texture unit\n        }\n\n        this.bind(program);\n\n        // TODO: support element array mode\n        this.gl.drawArrays(this.draw_mode, 0, this.vertex_count);\n        VertexArrayObject.bind(null);\n\n        if (this.uniforms) {\n            program.restoreUniforms(this.uniforms);\n        }\n\n        return true;\n    }\n\n    // Bind buffers and vertex attributes to prepare for rendering\n    bind(program) {\n        // Bind VAO for this progam, or create one\n        let vao = this.vaos.get(program);\n        if (vao) {\n            VertexArrayObject.bind(vao);\n        }\n        else {\n            this.vaos.set(program, VertexArrayObject.create((force) => {\n                this.gl.bindBuffer(this.gl.ARRAY_BUFFER, this.buffer);\n                this.vertex_layout.enable(this.gl, program, force);\n            }));\n        }\n    }\n\n    destroy() {\n        if (!this.valid) {\n            return false;\n        }\n        this.valid = false;\n\n        log.trace('VBOMesh.destroy: delete buffer' + (this.vertex_data ? ` of size ${this.vertex_data.byteLength}` : ''));\n\n        this.gl.deleteBuffer(this.buffer);\n        this.buffer = null;\n        delete this.vertex_data;\n\n        // Free texture uniforms that are owned by this mesh\n        for (let {type, value} of GLSL.parseUniforms(this.uniforms)) {\n            if (type === 'sampler2D' && Texture.textures[value]) {\n                Texture.textures[value].destroy();\n            }\n        }\n\n        return true;\n    }\n\n}\n","/* global VertexData */\n\nimport gl from './constants'; // web workers don't have access to GL context, so import all GL constants\nimport {log} from '../utils/utils';\n\n// Maps GL types to JS array types\nlet array_types = {\n    [gl.FLOAT]: Float32Array,\n    [gl.BYTE]: Int8Array,\n    [gl.UNSIGNED_BYTE]: Uint8Array,\n    [gl.INT]: Int32Array,\n    [gl.UNSIGNED_INT]: Uint32Array,\n    [gl.SHORT]: Int16Array,\n    [gl.UNSIGNED_SHORT]: Uint16Array\n};\n\n// An intermediary object that holds vertex data in typed arrays, according to a given vertex layout\n// Used to construct a mesh/VBO for rendering\nexport default class VertexData {\n\n    constructor (vertex_layout, { prealloc } = {}) {\n        this.vertex_layout = vertex_layout;\n\n        if (VertexData.array_pool.length > 0) {\n            this.buffer = VertexData.array_pool.pop();\n            this.buffer_length = this.buffer.byteLength;\n            this.buffer_size = Math.floor(this.buffer_length / this.vertex_layout.stride);\n            log('trace', `VertexData: reused buffer of bytes ${this.buffer_length}, ${this.buffer_size} vertices`);\n        }\n        else {\n            this.buffer_size = prealloc || 500; // # of vertices to allocate\n            this.buffer_length = this.vertex_layout.stride * this.buffer_size;\n            this.buffer = new Uint8Array(this.buffer_length);\n        }\n        this.buffer_offset = 0;             // byte offset into currently allocated buffer\n\n        this.components = [];\n        for (var component of this.vertex_layout.components) {\n            this.components.push([...component]);\n        }\n        this.vertex_count = 0;\n        this.realloc_count = 0;\n        this.setBufferViews();\n    }\n\n    // (Re-)allocate typed views into the main buffer - only create the types we need for this layout\n    setBufferViews () {\n        this.buffer_views = {};\n        this.buffer_views[gl.UNSIGNED_BYTE] = this.buffer;\n        for (var attrib of this.vertex_layout.attribs) {\n            // Need view for this type?\n            if (this.buffer_views[attrib.type] == null) {\n                var array_type = array_types[attrib.type];\n                this.buffer_views[attrib.type] = new array_type(this.buffer.buffer);\n            }\n        }\n\n        // Update component buffer pointers\n        for (var component of this.components) {\n            component[1] = this.buffer_views[component[0]];\n        }\n    }\n\n    // Check allocated buffer size, expand/realloc buffer if needed\n    checkBufferSize () {\n        if ((this.buffer_offset + this.vertex_layout.stride) > this.buffer_length) {\n            this.buffer_size = Math.floor(this.buffer_size * 1.5);\n            this.buffer_size -= this.buffer_size % 4;\n            this.buffer_length = this.vertex_layout.stride * this.buffer_size;\n            var new_view = new Uint8Array(this.buffer_length);\n            new_view.set(this.buffer); // copy existing data to new buffer\n            VertexData.array_pool.push(this.buffer); // save previous buffer for use by next tile\n            this.buffer = new_view;\n            this.setBufferViews();\n            this.realloc_count++;\n            // log.info(`VertexData: expanded vertex block to ${this.buffer_size} vertices`);\n        }\n    }\n\n    // Add a vertex, copied from a plain JS array of elements matching the order of the vertex layout.\n    // Note: uses pre-calculated info about each attribute, including pointer to appropriate typed array\n    // view and offset into it. This was the fastest method profiled so far for filling a mixed-type\n    // vertex layout (though still slower than the previous method that only supported Float32Array attributes).\n    addVertex (vertex) {\n        this.checkBufferSize();\n        var i=0;\n\n        var clen = this.components.length;\n        for (var c=0; c < clen; c++) {\n            var component = this.components[c];\n            component[1][(this.buffer_offset >> component[2]) + component[3]] = vertex[i++];\n        }\n\n        this.buffer_offset += this.vertex_layout.stride;\n        this.vertex_count++;\n    }\n\n    // Finalize vertex buffer for use in constructing a mesh\n    end () {\n        // Clip the buffer to size used for this VBO\n        this.buffer = this.buffer.subarray(0, this.buffer_offset);\n        log('trace', `VertexData: ${this.buffer_size} vertices total, realloc count ${this.realloc_count}`);\n        return this;\n    }\n\n}\n\nVertexData.array_pool = []; // pool of currently available (previously used) buffers (uint8)\n","/* global VertexLayout */\n\nimport gl from './constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexData from './vertex_data';\n\n// Describes a vertex layout that can be used with many different GL programs.\nexport default class VertexLayout {\n    // Attribs are an array, in layout order, of: name, size, type, normalized\n    // ex: { name: 'position', size: 3, type: gl.FLOAT, normalized: false }\n    constructor (attribs) {\n        this.attribs = attribs; // dictionary of attributes, specified as standard GL attrib options\n        this.components = [];   // list of type and offset info about each attribute component\n        this.index = {};        // linear buffer index of each attribute component, e.g. this.index.position.x\n\n        // Calc vertex stride\n        this.stride = 0;\n\n        var count = 0;\n        for (var attrib of this.attribs) {\n            attrib.offset = this.stride;\n            attrib.byte_size = attrib.size;\n            var shift = 0;\n\n            switch (attrib.type) {\n                case gl.FLOAT:\n                case gl.INT:\n                case gl.UNSIGNED_INT:\n                    attrib.byte_size *= 4;\n                    shift = 2;\n                    break;\n                case gl.SHORT:\n                case gl.UNSIGNED_SHORT:\n                    attrib.byte_size *= 2;\n                    shift = 1;\n                    break;\n            }\n\n            // Force 4-byte alignment on attributes\n            this.stride += attrib.byte_size;\n            if (this.stride & 3) { // pad to multiple of 4 bytes\n                this.stride += 4 - (this.stride & 3);\n            }\n\n            // Add info to list of attribute components\n            // Used to build the vertex data, provides pointers and offsets into each typed array view\n            // Each component is an array of:\n            // [GL attrib type, pointer to typed array view, bits to shift right to determine buffer offset, additional buffer offset for the component]\n            var offset_typed = attrib.offset >> shift;\n            if (attrib.size > 1) {\n                for (var a=0; a < attrib.size; a++) {\n                    this.components.push([attrib.type, null, shift, offset_typed++]);\n                }\n            }\n            else {\n                this.components.push([attrib.type, null, shift, offset_typed]);\n            }\n\n            // Provide an index into the vertex data buffer for each attribute component\n            this.index[attrib.name] = count;\n            count += attrib.size;\n        }\n    }\n\n    // Setup a vertex layout for a specific GL program\n    // Assumes that the desired vertex buffer (VBO) is already bound\n    // If a given program doesn't include all attributes, it can still use the vertex layout\n    // to read those attribs that it does recognize, using the attrib offsets to skip others.\n    enable (gl, program, force)\n    {\n        var attrib, location;\n\n        // Enable all attributes for this layout\n        for (var a=0; a < this.attribs.length; a++) {\n            attrib = this.attribs[a];\n            location = program.attribute(attrib.name).location;\n\n            if (location !== -1) {\n                if (!VertexLayout.enabled_attribs[location] || force) {\n                    gl.enableVertexAttribArray(location);\n                }\n                gl.vertexAttribPointer(location, attrib.size, attrib.type, attrib.normalized, this.stride, attrib.offset);\n                VertexLayout.enabled_attribs[location] = program;\n            }\n        }\n\n        // Disable any previously bound attributes that aren't for this layout\n        for (location in VertexLayout.enabled_attribs) {\n            this.disableUnusedAttribute(gl, location, program);\n        }\n    }\n\n    // Disable an attribute if it was not enabled for the specified program\n    // NOTE: this was moved out of the inner loop in enable() to assist w/VM optimization\n    disableUnusedAttribute (gl, location, program) {\n        if (VertexLayout.enabled_attribs[location] !== program) {\n            gl.disableVertexAttribArray(location);\n            delete VertexLayout.enabled_attribs[location];\n        }\n    }\n\n    createVertexData () {\n        return new VertexData(this);\n    }\n\n}\n\n// Track currently enabled attribs, by the program they are bound to\n// Static class property to reflect global GL state\nVertexLayout.enabled_attribs = {};\n","import Utils from './utils/utils';\nimport Scene from './scene';\nimport Geo from './geo';\n\n// Exports must appear outside a function, but will only be defined in main thread (below)\nexport var LeafletLayer;\nexport function leafletLayer(options) {\n    return new LeafletLayer(options);\n}\n\n// Leaflet layer functionality is only defined in main thread\nif (Utils.isMainThread) {\n\n    // Determine if we are extending the leaflet 0.7.x TileLayer class, or the newer\n    // leaflet 1.x GridLayer class.\n    let layerBaseClass = L.GridLayer ? L.GridLayer : L.TileLayer;\n    let leafletVersion = layerBaseClass === L.GridLayer ? '1.x' : '0.7.x';\n    let layerClassConfig = {};\n\n    // If extending leaflet 0.7.x TileLayer, make add/remove tile no ops\n    if (layerBaseClass === L.TileLayer) {\n        layerClassConfig._addTile = function(){};\n        layerClassConfig._removeTile = function(){};\n    }\n\n    // Define custom layer methods\n    Object.assign(layerClassConfig, {\n\n        initialize: function (options) {\n            // Defaults\n            options.showDebug = (!options.showDebug ? false : true);\n\n            L.setOptions(this, options);\n            this.createScene();\n            this.hooks = {};\n            this._updating_tangram = false;\n\n            // Force leaflet zoom animations off\n            this._zoomAnimated = false;\n        },\n\n        createScene: function () {\n            this.scene = Scene.create(\n                this.options.scene,\n                {\n                    numWorkers: this.options.numWorkers,\n                    preUpdate: this.options.preUpdate,\n                    postUpdate: this.options.postUpdate,\n                    continuousZoom: (LeafletLayer.leafletVersion === '1.x'),\n                    highDensityDisplay: this.options.highDensityDisplay,\n                    logLevel: this.options.logLevel,\n                    // advanced option, app will have to manually called scene.update() per frame\n                    disableRenderLoop: this.options.disableRenderLoop,\n                    // advanced option, will require library to be served as same host as page\n                    allowCrossDomainWorkers: this.options.allowCrossDomainWorkers\n                });\n        },\n\n        // Finish initializing scene and setup events when layer is added to map\n        onAdd: function (map) {\n            if (!this.scene) {\n                this.createScene();\n            }\n\n            layerBaseClass.prototype.onAdd.apply(this, arguments);\n\n            this.hooks.resize = () => {\n                this._updating_tangram = true;\n                var size = map.getSize();\n                this.scene.resizeMap(size.x, size.y);\n                this._updating_tangram = false;\n            };\n            map.on('resize', this.hooks.resize);\n\n            this.hooks.move = () => {\n                if (this._updating_tangram) {\n                    return;\n                }\n\n                this._updating_tangram = true;\n                var view = map.getCenter();\n                view.zoom = Math.min(map.getZoom(), map.getMaxZoom() || Geo.max_zoom);\n\n                this.scene.setView(view);\n                this.scene.immediateRedraw();\n                this._updating_tangram = false;\n            };\n            map.on('move', this.hooks.move);\n\n            this.hooks.zoomstart = () => {\n                if (this._updating_tangram) {\n                    return;\n                }\n\n                this._updating_tangram = true;\n                this.scene.startZoom();\n                this._updating_tangram = false;\n            };\n            map.on('zoomstart', this.hooks.zoomstart);\n\n            this.hooks.dragstart = () => {\n                this.scene.panning = true;\n            };\n            map.on('dragstart', this.hooks.dragstart);\n\n            this.hooks.dragend = () => {\n                this.scene.panning = false;\n            };\n            map.on('dragend', this.hooks.dragend);\n\n            // Force leaflet zoom animations off\n            map._zoomAnimated = false;\n\n            // Modify default leaflet scroll wheel behavior\n            this.modifyScrollWheelBehavior(map);\n\n            // Canvas element will be inserted after map container (leaflet transforms shouldn't be applied to the GL canvas)\n            // TODO: find a better way to deal with this? right now GL map only renders correctly as the bottom layer\n            this.scene.container = map.getContainer();\n\n            // Initial view\n            var view = map.getCenter();\n            view.zoom = Math.min(map.getZoom(), map.getMaxZoom() || Geo.max_zoom);\n            this.scene.setView(view);\n\n            // Subscribe to tangram events\n            this.scene.subscribe({\n                move: this.onTangramViewUpdate.bind(this)\n            });\n\n            // Use leaflet's existing event system as the callback mechanism\n            this.scene.load().then(() => {\n                this.fire('init');\n            }).catch(error => {\n                this.fire('error', error);\n            });\n        },\n\n        onRemove: function (map) {\n            layerBaseClass.prototype.onRemove.apply(this, arguments);\n\n            map.off('resize', this.hooks.resize);\n            map.off('move', this.hooks.move);\n            map.off('zoomstart', this.hooks.zoomstart);\n            map.off('dragstart', this.hooks.dragstart);\n            map.off('dragend', this.hooks.dragend);\n            this.hooks = {};\n\n            if (this.scene) {\n                this.scene.destroy();\n                this.scene = null;\n            }\n        },\n\n        createTile: function (coords) {\n            var key = coords.x + '/' + coords.y + '/' + coords.z;\n            var div = document.createElement('div');\n            div.setAttribute('data-tile-key', key);\n            div.style.width = '256px';\n            div.style.height = '256px';\n\n            if (this.options.showDebug) {\n                var debug_overlay = document.createElement('div');\n                debug_overlay.textContent = key;\n                debug_overlay.style.position = 'absolute';\n                debug_overlay.style.left = 0;\n                debug_overlay.style.top = 0;\n                debug_overlay.style.color = 'white';\n                debug_overlay.style.fontSize = '16px';\n                debug_overlay.style.textOutline = '1px #000000';\n                debug_overlay.style.padding = '8px';\n\n                div.appendChild(debug_overlay);\n                div.style.borderStyle = 'solid';\n                div.style.borderColor = 'white';\n                div.style.borderWidth = '1px';\n            }\n\n            return div;\n        },\n\n        // Modify leaflet's default scroll wheel behavior to have a much more sensitve/continuous zoom\n        // Note: this should be deprecated once leaflet continuous zoom is more widely used and the\n        // default behavior is presumably improved\n        modifyScrollWheelBehavior: function (map) {\n            if (this.scene.continuous_zoom && map.scrollWheelZoom && this.options.modifyScrollWheel !== false) {\n                map.scrollWheelZoom._performZoom = function () {\n                    var map = this._map,\n                        delta = this._delta,\n                        zoom = map.getZoom();\n\n                    map.stop(); // stop panning and fly animations if any\n\n                    // NOTE: this is the only real modification to default leaflet behavior\n                    delta /= 40;\n\n                    delta = Math.max(Math.min(delta, 4), -4);\n                    delta = map._limitZoom(zoom + delta) - zoom;\n\n                    this._delta = 0;\n                    this._startTime = null;\n\n                    if (!delta) { return; }\n\n                    if (map.options.scrollWheelZoom === 'center') {\n                        map.setZoom(zoom + delta);\n                    } else {\n                        map.setZoomAround(this._lastMousePos, zoom + delta);\n                    }\n                    return false;\n                };\n            }\n        },\n\n        onTangramViewUpdate: function () {\n            if (!this._map || this._updating_tangram) {\n                return;\n            }\n            this._updating_tangram = true;\n            this._map.setView([this.scene.center.lat, this.scene.center.lng], this.scene.zoom, { animate: false });\n            this._updating_tangram = false;\n        },\n\n        render: function () {\n            if (!this.scene) {\n                return;\n            }\n            this.scene.update();\n        }\n\n    });\n\n    // Create the layer class\n    LeafletLayer = layerBaseClass.extend(layerClassConfig);\n\n    // Polyfill some 1.0 methods\n    if (typeof LeafletLayer.remove !== 'function') {\n        LeafletLayer.prototype.remove = function() {\n            if (this._map) {\n                this._map.removeLayer(this);\n            }\n            this.fire('remove');\n        };\n    }\n\n    LeafletLayer.layerBaseClass = layerBaseClass;\n    LeafletLayer.leafletVersion = leafletVersion;\n\n}\n","/*global Light */\nimport ShaderProgram from './gl/shader_program';\nimport shaderSources from './gl/shader_sources'; // built-in shaders\nimport GLSL from './gl/glsl';\nimport Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\n\n// Abstract light\nexport default class Light {\n\n    constructor (scene, config) {\n        this.name = config.name;\n        this.scene = scene;\n\n        if (config.ambient == null || typeof config.ambient === 'number') {\n            this.ambient = GLSL.expandVec4(config.ambient || 0);\n        }\n        else {\n            this.ambient = StyleParser.parseColor(config.ambient);\n        }\n\n        if (config.diffuse == null || typeof config.diffuse === 'number') {\n            this.diffuse = GLSL.expandVec4(config.diffuse != null ? config.diffuse : 1);\n        }\n        else {\n            this.diffuse = StyleParser.parseColor(config.diffuse);\n        }\n\n        if (config.specular == null || typeof config.specular === 'number') {\n            this.specular = GLSL.expandVec4(config.specular || 0);\n        }\n        else {\n            this.specular = StyleParser.parseColor(config.specular);\n        }\n    }\n\n    // Create a light by type name, factory-style\n    // 'config' must include 'name' and 'type', along with any other type-specific properties\n    static create (scene, config) {\n        if (Light.types[config.type]) {\n            return new Light.types[config.type](scene, config);\n        }\n    }\n\n    // Set light for a style: fragment lighting, vertex lighting, or none\n    static setMode (mode, style) {\n        if (mode === true) {\n            mode = 'fragment';\n        }\n        mode = Light.enabled && ((mode != null) ? mode : 'fragment'); // default to fragment lighting\n        style.defines['TANGRAM_LIGHTING_FRAGMENT'] = (mode === 'fragment');\n        style.defines['TANGRAM_LIGHTING_VERTEX'] = (mode === 'vertex');\n    }\n\n    // Inject all provided light definitions, and calculate cumulative light function\n    static inject (lights) {\n        // Clear previous injections\n        ShaderProgram.removeBlock(Light.block);\n\n        // If lighting is globally disabled, nothing is injected (mostly for debugging or live editing)\n        if (!Light.enabled) {\n            return;\n        }\n\n        // Construct code to calculate each light instance\n        let calculateLights = \"\";\n        if (lights && Object.keys(lights).length > 0) {\n            // Collect uniques types of lights\n            let types = {};\n            for (let light_name in lights) {\n                types[lights[light_name].type] = true;\n            }\n\n            // Inject each type of light\n            for (let type in types) {\n                Light.types[type].inject();\n            }\n\n            // Inject per-instance blocks and construct the list of functions to calculate each light\n            for (let light_name in lights) {\n                // Define instance\n                lights[light_name].inject();\n\n                // Add the calculation function to the list\n                calculateLights += `calculateLight(${light_name}, _eyeToPoint, _normal);\\n`;\n            }\n        }\n        else {\n            // If no light is defined, use 100% omnidirectional diffuse light\n            calculateLights = `\n                #ifdef TANGRAM_MATERIAL_DIFFUSE\n                    light_accumulator_diffuse = vec4(1.);\n                #endif\n            `;\n        }\n\n        // Glue together the final lighting function that sums all the lights\n        let calculateFunction = `\n            vec4 calculateLighting(in vec3 _eyeToPoint, in vec3 _normal, in vec4 _color) {\n\n                // Do initial material calculations over normal, emission, ambient, diffuse and specular values\n                calculateMaterial(_eyeToPoint,_normal);\n\n                // Un roll the loop of individual ligths to calculate\n                ${calculateLights}\n\n                //  Final light intensity calculation\n                vec4 color = vec4(0.0);\n\n                #ifdef TANGRAM_MATERIAL_EMISSION\n                    color = material.emission;\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_AMBIENT\n                    color += light_accumulator_ambient * _color * material.ambient;\n                #else\n                    #ifdef TANGRAM_MATERIAL_DIFFUSE\n                        color += light_accumulator_ambient * _color * material.diffuse;\n                    #endif\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_DIFFUSE\n                    color += light_accumulator_diffuse * _color * material.diffuse;\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_SPECULAR\n                    color += light_accumulator_specular * material.specular;\n                #endif\n\n                // Clamp final color\n                color = clamp(color, 0.0, 1.0);\n\n                return color;\n            }`;\n\n        ShaderProgram.addBlock(Light.block, calculateFunction);\n    }\n\n    // Common instance definition\n    inject () {\n        let instance =  `\n            uniform ${this.struct_name} u_${this.name};\n            ${this.struct_name} ${this.name} = u_${this.name};\\n`;\n\n        ShaderProgram.addBlock(Light.block, instance);\n    }\n\n    // Update method called once per frame\n    update () {\n    }\n\n    // Called once per frame per program (e.g. for main render pass, then for each additional\n    // pass for feature selection, etc.)\n    setupProgram (_program) {\n        //  Three common light properties\n        _program.uniform('4fv', `u_${this.name}.ambient`, this.ambient);\n        _program.uniform('4fv', `u_${this.name}.diffuse`, this.diffuse);\n        _program.uniform('4fv', `u_${this.name}.specular`, this.specular);\n    }\n\n}\n\nLight.types = {}; // references to subclasses by short name\nLight.block = 'lighting'; // shader block name\nLight.enabled = true; // lighting can be globally enabled/disabled\n\n\n// Light subclasses\nclass AmbientLight extends Light {\n\n    constructor(scene, config) {\n        super(scene, config);\n        this.type = 'ambient';\n        this.struct_name = 'AmbientLight';\n    }\n\n    // Inject struct and calculate function\n    static inject() {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/ambientLight']);\n    }\n\n    setupProgram (_program) {\n        _program.uniform('4fv', `u_${this.name}.ambient`, this.ambient);\n    }\n\n}\nLight.types['ambient'] = AmbientLight;\n\nclass DirectionalLight extends Light {\n\n    constructor(scene, config) {\n        super(scene, config);\n        this.type = 'directional';\n        this.struct_name = 'DirectionalLight';\n\n        this.direction = (config.direction || [0.2, 0.7, -0.5]).map(parseFloat); // [x, y, z]\n    }\n\n    // Inject struct and calculate function\n    static inject() {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/directionalLight']);\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n        _program.uniform('3fv', `u_${this.name}.direction`, this.direction);\n    }\n\n}\nLight.types['directional'] = DirectionalLight;\n\n\nclass PointLight extends Light {\n\n    constructor (scene, config) {\n        super(scene, config);\n        this.type = 'point';\n        this.struct_name = 'PointLight';\n\n        this.position = config.position || [0, 0, 0];\n        this.position_eye = []; // position in eyespace\n        this.origin = config.origin || 'world';\n        this.attenuation = !isNaN(parseFloat(config.attenuation)) ? parseFloat(config.attenuation) : 0;\n\n        if (config.radius) {\n            if (Array.isArray(config.radius) && config.radius.length === 2) {\n                this.radius = config.radius;\n            }\n            else {\n                this.radius = [null, config.radius];\n            }\n        }\n        else {\n            this.radius = null;\n        }\n    }\n\n    // Inject struct and calculate function\n    static inject () {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/pointLight']);\n    }\n\n    // Inject isntance-specific settings\n    inject() {\n        super.inject();\n\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT'] = (this.attenuation !== 0);\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS'] = (this.radius != null && this.radius[0] != null);\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS'] = (this.radius != null);\n    }\n\n    update () {\n        this.updateEyePosition();\n    }\n\n    updateEyePosition () {\n        if (this.origin === 'world') {\n            // For world origin, format is: [longitude, latitude, meters (default) or pixels w/px units]\n\n            // Move light's world position into camera space\n            let [x, y] = Geo.latLngToMeters(this.position);\n            this.position_eye[0] = x - this.scene.camera.position_meters[0];\n            this.position_eye[1] = y - this.scene.camera.position_meters[1];\n\n            this.position_eye[2] = StyleParser.convertUnits(this.position[2], { zoom: this.scene.zoom });\n            this.position_eye[2] = this.position_eye[2] - this.scene.camera.position_meters[2];\n        }\n        if (this.origin === 'ground' || this.origin === 'camera') {\n            // For camera or ground origin, format is: [x, y, z] in meters (default) or pixels w/px units\n\n            // Light is in camera space by default\n            this.position_eye = StyleParser.convertUnits(this.position, { zoom: this.scene.zoom });\n\n            if (this.origin === 'ground') {\n                // Leave light's xy in camera space, but z needs to be moved relative to ground plane\n                this.position_eye[2] = this.position_eye[2] - this.scene.camera.position_meters[2];\n            }\n        }\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n\n        _program.uniform('4f', `u_${this.name}.position`,\n            this.position_eye[0], this.position_eye[1], this.position_eye[2], 1);\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT']) {\n            _program.uniform('1f', `u_${this.name}.attenuationExponent`, this.attenuation);\n        }\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS']) {\n            _program.uniform('1f', `u_${this.name}.innerRadius`,\n                StyleParser.convertUnits(this.radius[0], { zoom: this.scene.zoom }));\n        }\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS']) {\n            _program.uniform('1f', `u_${this.name}.outerRadius`,\n                StyleParser.convertUnits(this.radius[1], { zoom: this.scene.zoom }));\n        }\n    }\n}\nLight.types['point'] = PointLight;\n\n\nclass SpotLight extends PointLight {\n\n    constructor (scene, config) {\n        super(scene, config);\n        this.type = 'spotlight';\n        this.struct_name = 'SpotLight';\n\n        this.direction = (config.direction || [0, 0, -1]).map(parseFloat); // [x, y, z]\n        this.exponent = config.exponent ? parseFloat(config.exponent) : 0.2;\n        this.angle = config.angle ? parseFloat(config.angle) : 20;\n    }\n\n    // Inject struct and calculate function\n    static inject () {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/spotLight']);\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n\n        _program.uniform('3fv', `u_${this.name}.direction`, this.direction);\n        _program.uniform('1f', `u_${this.name}.spotCosCutoff`, Math.cos(this.angle * 3.14159 / 180));\n        _program.uniform('1f', `u_${this.name}.spotExponent`, this.exponent);\n    }\n\n}\nLight.types['spotlight'] = SpotLight;\n","/*global Material */\nimport shaderSources from './gl/shader_sources'; // built-in shaders\nimport GLSL from './gl/glsl';\nimport {StyleParser} from './styles/style_parser';\n\nexport default class Material {\n    constructor (config) {\n\n        config = config || {};\n\n        // These properties all have the same defaults, so they can be set in bulk\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            if (config[prop] != null) {\n                if (config[prop].texture) {\n                    this[prop] = {\n                        texture: config[prop].texture,\n                        mapping: config[prop].mapping || 'spheremap',\n                        scale: GLSL.expandVec3(config[prop].scale != null ? config[prop].scale : 1),\n                        amount: GLSL.expandVec4(config[prop].amount != null ? config[prop].amount : 1)\n                    };\n                }\n                else if (typeof config[prop] === 'number') {\n                    this[prop] = { amount: GLSL.expandVec4(config[prop]) };\n                }\n                else if (typeof config[prop] === 'string') {\n                    this[prop] = { amount: StyleParser.parseColor(config[prop]) };\n                }\n                else {\n                    this[prop] = config[prop];\n                }\n            }\n        }\n\n        // Extra specular props\n        if (this.specular) {\n            this.specular.shininess = config.shininess ? parseFloat(config.shininess) : 0.2;\n        }\n\n        // Normal mapping\n        if (config.normal != null) {\n            this.normal = {\n                texture: config.normal.texture,\n                mapping: config.normal.mapping || 'triplanar',\n                scale: GLSL.expandVec3(config.normal.scale != null ? config.normal.scale : 1),\n                amount: config.normal.amount != null ? config.normal.amount : 1\n            };\n        }\n    }\n\n    // Determine if a material config block has sufficient properties to create a material\n    static isValid (config) {\n        if (config == null) {\n            return false;\n        }\n\n        if (config.emission == null &&\n            config.ambient == null &&\n            config.diffuse == null &&\n            config.specular == null) {\n            return false;\n        }\n\n        return true;\n    }\n\n    inject (style) {\n        // For each property, sets defines to configure texture mapping, with a pattern like:\n        //   TANGRAM_MATERIAL_DIFFUSE, TANGRAM_MATERIAL_DIFFUSE_TEXTURE, TANGRAM_MATERIAL_DIFFUSE_TEXTURE_SPHEREMAP\n        // Also sets flags to keep track of each unique mapping type being used, e.g.:\n        //   TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\n        // Enables texture coordinates if needed and not already on\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            let def = `TANGRAM_MATERIAL_${prop.toUpperCase()}`;\n            let texdef = def + '_TEXTURE';\n            style.defines[def] = (this[prop] != null);\n            if (this[prop] && this[prop].texture) {\n                style.defines[texdef] = true;\n                style.defines[texdef + '_' + this[prop].mapping.toUpperCase()] = true;\n                style.defines[`TANGRAM_MATERIAL_TEXTURE_${this[prop].mapping.toUpperCase()}`] = true;\n                style.texcoords = style.texcoords || (this[prop].mapping === 'uv');\n            }\n        }\n\n        // Normal mapping\n        // As anove, sets flags to keep track of each unique mapping type being used, e.g.:\n        //   TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\n        if (this.normal && this.normal.texture) {\n            style.defines['TANGRAM_MATERIAL_NORMAL_TEXTURE'] = true;\n            style.defines['TANGRAM_MATERIAL_NORMAL_TEXTURE_' + this.normal.mapping.toUpperCase()] = true;\n            style.defines[`TANGRAM_MATERIAL_TEXTURE_${this.normal.mapping.toUpperCase()}`] = true;\n            style.texcoords = style.texcoords || (this.normal.mapping === 'uv');\n        }\n\n        style.replaceShaderBlock(Material.block, shaderSources['gl/shaders/material'], 'Material');\n    }\n\n    setupProgram (_program) {\n        // For each property, sets uniforms in the pattern:\n        // u_material.diffuse, u_material.diffuseScale u_material_diffuse_texture\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            if (this[prop]) {\n                if (this[prop].texture) {\n                    _program.setTextureUniform(`u_material_${prop}_texture`, this[prop].texture);\n                    _program.uniform('3fv', `u_material.${prop}Scale`, this[prop].scale);\n                    _program.uniform('4fv', `u_material.${prop}`, this[prop].amount);\n                } else if (this[prop].amount) {\n                    _program.uniform('4fv', `u_material.${prop}`, this[prop].amount);\n                }\n            }\n        }\n\n        // Extra specular props\n        if (this.specular) {\n            _program.uniform('1f', 'u_material.shininess', this.specular.shininess);\n        }\n\n        // Normal mapping\n        if (this.normal && this.normal.texture) {\n            _program.setTextureUniform('u_material_normal_texture', this.normal.texture);\n            _program.uniform('3fv', 'u_material.normalScale', this.normal.scale);\n            _program.uniform('1f', 'u_material.normalAmount', this.normal.amount);\n        }\n    }\n}\n\nMaterial.block = 'material';\n","/*jshint worker: true*/\n\n// Modules and dependencies to expose in the public Tangram module\nimport Utils from './utils/utils';\n\n// The leaflet layer plugin is currently the primary public API\nimport {LeafletLayer, leafletLayer} from './leaflet_layer';\n\n// The scene worker is only activated when a worker thread is instantiated, but must always be loaded\nimport {SceneWorker} from '../src/scene_worker';\n\n// Additional modules are exposed for debugging\nimport version from './utils/version';\nimport log from 'loglevel';\nimport Geo from './geo';\nimport DataSource from './sources/data_source';\nimport './sources/geojson';\nimport './sources/topojson';\nimport './sources/mvt';\nimport TileManager from './tile_manager';\nimport GLSL from './gl/glsl';\nimport ShaderProgram from './gl/shader_program';\nimport VertexData from './gl/vertex_data';\nimport Texture from './gl/texture';\nimport Material from './material';\nimport Light from './light';\nimport WorkerBroker from './utils/worker_broker';\nimport {ruleCache} from './styles/rule';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport FeatureSelection from './selection';\n\nimport yaml from 'js-yaml';\nimport glMatrix from 'gl-matrix';\n\n// Default to 64-bit because we need the extra precision when multiplying matrices w/mercator projected values\nglMatrix.glMatrix.setMatrixArrayType(Float64Array);\n\n// Make some modules accessible for debugging\nvar debug = {\n    log,\n    yaml,\n    Utils,\n    Geo,\n    DataSource,\n    TileManager,\n    GLSL,\n    ShaderProgram,\n    VertexData,\n    Texture,\n    Material,\n    Light,\n    SceneWorker,\n    WorkerBroker,\n    ruleCache,\n    StyleManager,\n    StyleParser,\n    FeatureSelection\n};\n\n// Window can only be set in main thread\nif (Utils.isMainThread) {\n    // Main thread objects that can be called from workers\n    WorkerBroker.addTarget('Texture', Texture);\n\n    window.Tangram = module.exports = {\n        LeafletLayer,\n        leafletLayer,\n        debug,\n        version: version.string\n    };\n\n}\n\nif (Utils.isWorkerThread) {\n    self.Tangram = {\n        debug,\n        version: version.string\n    };\n}\n\nif (Utils.isMainThread) {\n    Utils.requestAnimationFramePolyfill();\n}\n\n// Setup logging to prefix with Tangram version\nvar originalFactory = log.methodFactory;\nlog.methodFactory = function (methodName, logLevel) {\n    var rawMethod = originalFactory(methodName, logLevel);\n    return function (...message) {\n        rawMethod(`Tangram ${version.string}:`, ...message);\n    };\n};\n","/*global Scene */\nimport Geo from './geo';\nimport Utils from './utils/utils';\nimport WorkerBroker from './utils/worker_broker';\nimport subscribeMixin from './utils/subscribe';\nimport Context from './gl/context';\nimport Texture from './gl/texture';\nimport VertexArrayObject from './gl/vao';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport SceneLoader from './scene_loader';\nimport Camera from './camera';\nimport Light from './light';\nimport TileManager from './tile_manager';\nimport DataSource from './sources/data_source';\nimport FeatureSelection from './selection';\nimport RenderState from './gl/render_state';\n\nimport {Polygons} from './styles/polygons/polygons';\nimport {Lines} from './styles/lines/lines';\nimport {Points} from './styles/points/points';\nimport {TextStyle} from './styles/text/text';\n\n// Add built-in rendering styles\nStyleManager.register(Polygons);\nStyleManager.register(Lines);\nStyleManager.register(Points);\nStyleManager.register(TextStyle);\n\nimport log from 'loglevel';\nimport glMatrix from 'gl-matrix';\nlet mat4 = glMatrix.mat4;\nlet mat3 = glMatrix.mat3;\nlet vec3 = glMatrix.vec3;\n\n// Load scene definition: pass an object directly, or a URL as string to load remotely\nexport default class Scene {\n\n    constructor(config_source, options) {\n        options = options || {};\n        subscribeMixin(this);\n\n        this.initialized = false;\n        this.initializing = false;\n        this.sources = {};\n\n        this.tile_manager = TileManager;\n        this.tile_manager.init(this);\n        this.num_workers = options.numWorkers || 2;\n        this.continuous_zoom = (typeof options.continuousZoom === 'boolean') ? options.continuousZoom : true;\n        this.tile_simplification_level = 0; // level-of-detail downsampling to apply to tile loading\n        this.allow_cross_domain_workers = (options.allowCrossDomainWorkers === false ? false : true);\n        this.worker_url = options.workerUrl;\n        if (options.disableVertexArrayObjects === true) {\n            VertexArrayObject.disabled = true;\n        }\n\n        Utils.use_high_density_display = options.highDensityDisplay !== undefined ? options.highDensityDisplay : true;\n        Utils.updateDevicePixelRatio();\n\n        this.config = null;\n        this.config_source = config_source;\n        this.config_serialized = null;\n        this.last_valid_config_source = null;\n\n        this.styles = null;\n        this.active_styles = {};\n\n        this.building = null;                           // tracks current scene building state (tiles being built, etc.)\n        this.dirty = true;                              // request a redraw\n        this.animated = false;                          // request redraw every frame\n        this.preUpdate = options.preUpdate;             // optional pre-render loop hook\n        this.postUpdate = options.postUpdate;           // optional post-render loop hook\n        this.render_loop = !options.disableRenderLoop;  // disable render loop - app will have to manually call Scene.render() per frame\n        this.render_loop_active = false;\n        this.render_loop_stop = false;\n        this.frame = 0;\n        this.resetTime();\n\n        this.zoom = null;\n        this.center = null;\n\n        this.zooming = false;\n        this.preserve_tiles_within_zoom = 1;\n        this.panning = false;\n        this.container = options.container;\n\n        this.camera = null;\n        this.lights = null;\n        this.background = null;\n\n        // Model-view matrices\n        // 64-bit versions are for CPU calcuations\n        // 32-bit versions are downsampled and sent to GPU\n        this.modelMatrix = new Float64Array(16);\n        this.modelMatrix32 = new Float32Array(16);\n        this.modelViewMatrix = new Float64Array(16);\n        this.modelViewMatrix32 = new Float32Array(16);\n        this.normalMatrix = new Float64Array(9);\n        this.normalMatrix32 = new Float32Array(9);\n\n        this.selection = null;\n        this.texture_listener = null;\n\n        // Debug config\n        this.debug = {\n            profile: {\n                geometry_build: false\n            },\n            timeRebuild: n => this._timeRebuild(n)\n        };\n\n        this.updating = 0;\n        this.generation = 0; // an id that is incremented each time the scene config is invalidated\n\n        this.logLevel = options.logLevel || 'warn';\n        log.setLevel(this.logLevel);\n    }\n\n    // Load (or reload) scene config\n    // Optionally specify new scene file URL\n    load(config_source = null, config_path = null) {\n        if (this.initializing) {\n            return Promise.resolve();\n        }\n\n        this.updating++;\n        this.initialized = false;\n        this.initializing = true;\n\n        // Load scene definition (sources, styles, etc.), then create styles & workers\n        return this.loadScene(config_source, config_path)\n            .then(() => this.createWorkers())\n            .then(() => {\n                this.createCanvas();\n                this.resetFeatureSelection();\n\n                if (!this.texture_listener) {\n                    this.texture_listener = {\n                        update: () => this.dirty = true,\n                        warning: (data) => this.trigger('warning', Object.assign({ type: 'textures' }, data))\n                    };\n                    Texture.subscribe(this.texture_listener);\n                }\n\n                // Remove tiles before rebuilding\n                this.tile_manager.removeTiles(tile => !tile.visible);\n                return this.updateConfig({ rebuild: true });\n            }).then(() => {\n                this.updating--;\n                this.initializing = false;\n                this.initialized = true;\n                this.last_valid_config_source = this.config_source;\n                this.last_valid_config_path = this.config_path;\n\n                if (this.render_loop !== false) {\n                    this.setupRenderLoop();\n                }\n        }).catch(error => {\n            this.initializing = false;\n            this.updating = 0;\n\n            // Report and revert to last valid config if available\n            let type, message;\n            if (error.name === 'YAMLException') {\n                type = 'yaml';\n                message = 'Error parsing scene YAML';\n            }\n            else {\n                // TODO: more error types\n                message = 'Error initializing scene';\n            }\n            this.trigger('error', { type, message, error, url: this.config_source });\n\n            message = `Scene.load() failed to load ${this.config_source}: ${error.message}`;\n            if (this.last_valid_config_source) {\n                log.warn(message, error);\n                log.info(`Scene.load() reverting to last valid configuration`);\n                return this.load(this.last_valid_config_source, this.last_valid_config_path);\n            }\n            log.error(message, error);\n            throw error;\n        });\n    }\n\n    // For API compatibility\n    reload(config_source = null, config_path = null) {\n        return this.load(config_source, config_path);\n    }\n\n    destroy() {\n        this.initialized = false;\n        this.render_loop_stop = true; // schedule render loop to stop\n\n        this.unsubscribeAll(); // clear all event listeners\n\n        Texture.unsubscribe(this.texture_listener);\n        this.texture_listener = null;\n\n        if (this.canvas && this.canvas.parentNode) {\n            this.canvas.parentNode.removeChild(this.canvas);\n            this.canvas = null;\n        }\n        this.container = null;\n\n        if (this.selection) {\n            this.selection.destroy();\n        }\n\n        if (this.gl) {\n            Texture.destroy(this.gl);\n            StyleManager.destroy(this.gl);\n            this.styles = {};\n\n            this.gl = null;\n        }\n\n        this.sources = {};\n\n        if (Array.isArray(this.workers)) {\n            this.workers.forEach((worker) => {\n                worker.terminate();\n            });\n            this.workers = null;\n        }\n\n        this.tile_manager.destroy();\n    }\n\n    createCanvas() {\n        if (this.canvas) {\n            return;\n        }\n\n        this.container = this.container || document.body;\n        this.canvas = document.createElement('canvas');\n        this.canvas.style.position = 'absolute';\n        this.canvas.style.top = 0;\n        this.canvas.style.left = 0;\n\n        // Force tangram canvas underneath all leaflet layers, and set background to transparent\n        this.canvas.style.zIndex = -1;\n        this.container.style.cssText += 'background: transparent;';\n        this.container.appendChild(this.canvas);\n\n        try {\n            this.gl = Context.getContext(this.canvas, {\n                alpha: false /*premultipliedAlpha: false*/,\n                device_pixel_ratio: Utils.device_pixel_ratio\n            });\n        }\n        catch(e) {\n            throw new Error(\n                \"Couldn't create WebGL context. \" +\n                \"Your browser may not support WebGL, or it's turned off? \" +\n                \"Visit http://webglreport.com/ for more info.\"\n            );\n        }\n\n        this.resizeMap(this.container.clientWidth, this.container.clientHeight);\n        VertexArrayObject.init(this.gl);\n        RenderState.initialize(this.gl);\n    }\n\n    // Get the URL to load the web worker from\n    getWorkerUrl() {\n        let worker_url = this.worker_url || Utils.findCurrentURL('tangram.debug.js', 'tangram.min.js');\n\n        if (!worker_url) {\n            throw new Error(\"Can't load worker because couldn't find base URL that library was loaded from\");\n        }\n\n        if (this.allow_cross_domain_workers) {\n            let body = `importScripts('${worker_url}');`;\n            return Utils.createObjectURL(new Blob([body], { type: 'application/javascript' }));\n        }\n        return worker_url;\n    }\n\n    // Web workers handle heavy duty tile construction: networking, geometry processing, etc.\n    createWorkers() {\n        if (!this.workers) {\n            return this.makeWorkers(this.getWorkerUrl());\n        }\n        return Promise.resolve();\n    }\n\n    // Instantiate workers from URL, init event handlers\n    makeWorkers(url) {\n        var queue = [];\n\n        this.workers = [];\n        for (var id=0; id < this.num_workers; id++) {\n            var worker = new Worker(url);\n            this.workers[id] = worker;\n\n            worker.addEventListener('message', this.workerLogMessage.bind(this));\n            WorkerBroker.addWorker(worker);\n\n            log.debug(`Scene.makeWorkers: initializing worker ${id}`);\n            let _id = id;\n            queue.push(WorkerBroker.postMessage(worker, 'init', id, this.num_workers, Utils.device_pixel_ratio).then(\n                (id) => {\n                    log.debug(`Scene.makeWorkers: initialized worker ${id}`);\n                    return id;\n                },\n                (error) => {\n                    log.error(`Scene.makeWorkers: failed to initialize worker ${_id}:`, error);\n                    return Promise.reject(error);\n                })\n            );\n        }\n\n        return Promise.all(queue);\n    }\n\n    // Round robin selection of next worker\n    nextWorker() {\n        return this.workers[Math.floor(Math.random() * this.workers.length)];\n    }\n\n    /**\n        Set the map view, can be passed an object with lat/lng and/or zoom\n    */\n    setView({ lng, lat, zoom } = {}) {\n        var changed = false;\n\n        // Set center\n        if (typeof lng === 'number' && typeof lat === 'number') {\n            if (!this.center || lng !== this.center.lng || lat !== this.center.lat) {\n                changed = true;\n                this.center = { lng: Geo.wrapLng(lng), lat };\n            }\n        }\n\n        // Set zoom\n        if (typeof zoom === 'number' && zoom !== this.zoom) {\n            changed = true;\n            this.setZoom(zoom);\n        }\n\n        if (changed) {\n            this.updateBounds();\n        }\n        return changed;\n    }\n\n    startZoom() {\n        this.last_zoom = this.zoom;\n        this.zooming = true;\n    }\n\n    // Choose the base zoom level to use for a given fractional zoom\n    baseZoom(zoom) {\n        return Math.floor(zoom);\n    }\n\n    // For a given view zoom, what tile zoom should be loaded?\n    tileZoom(view_zoom) {\n        return this.baseZoom(view_zoom) - this.tile_simplification_level;\n    }\n\n    // For a given tile zoom, what style zoom should be used?\n    styleZoom(tile_zoom) {\n        return this.baseZoom(tile_zoom) + this.tile_simplification_level;\n    }\n\n    setZoom(zoom) {\n        this.zooming = false;\n        let tile_zoom = this.tileZoom(zoom);\n\n        if (!this.continuous_zoom) {\n            zoom = tile_zoom;\n        }\n\n        if (tile_zoom !== this.tileZoom(this.last_zoom)) {\n            // Remove tiles outside current zoom that are still loading\n            this.tile_manager.removeTiles(tile => {\n                if (tile.loading && this.tileZoom(tile.coords.z) !== tile_zoom) {\n                    log.trace(`removed ${tile.key} (was loading, but outside current zoom)`);\n                    return true;\n                }\n            });\n        }\n\n        this.last_zoom = this.zoom;\n        this.zoom = zoom;\n        this.tile_zoom = tile_zoom;\n\n        this.updateBounds();\n\n        this.dirty = true;\n    }\n\n    viewReady() {\n        if (this.css_size == null || this.center == null || this.zoom == null || Object.keys(this.sources).length === 0) {\n             return false;\n        }\n        return true;\n    }\n\n    // Calculate viewport bounds based on current center and zoom\n    updateBounds() {\n        // TODO: better concept of \"readiness\" state?\n        if (!this.viewReady()) {\n            return;\n        }\n\n        this.meters_per_pixel = Geo.metersPerPixel(this.zoom);\n\n        // Size of the half-viewport in meters at current zoom\n        this.viewport_meters = {\n            x: this.css_size.width * this.meters_per_pixel,\n            y: this.css_size.height * this.meters_per_pixel\n        };\n\n        // Center of viewport in meters, and tile\n        let [x, y] = Geo.latLngToMeters([this.center.lng, this.center.lat]);\n        this.center_meters = { x, y };\n\n        let z = this.tileZoom(this.zoom);\n        this.center_tile = Geo.tileForMeters([this.center_meters.x, this.center_meters.y], z);\n\n        this.bounds_meters = {\n            sw: {\n                x: this.center_meters.x - this.viewport_meters.x / 2,\n                y: this.center_meters.y - this.viewport_meters.y / 2\n            },\n            ne: {\n                x: this.center_meters.x + this.viewport_meters.x / 2,\n                y: this.center_meters.y + this.viewport_meters.y / 2\n            }\n        };\n\n        this.tile_manager.updateTilesForView();\n\n        this.trigger('move');\n        this.dirty = true;\n    }\n\n    findVisibleTileCoordinates({ buffer } = {}) {\n        if (!this.bounds_meters) {\n            return [];\n        }\n\n        let z = this.tileZoom(this.zoom);\n        let sw = Geo.tileForMeters([this.bounds_meters.sw.x, this.bounds_meters.sw.y], z);\n        let ne = Geo.tileForMeters([this.bounds_meters.ne.x, this.bounds_meters.ne.y], z);\n        buffer = buffer || 0;\n\n        let coords = [];\n        for (let x = sw.x - buffer; x <= ne.x + buffer; x++) {\n            for (let y = ne.y - buffer; y <= sw.y + buffer; y++) {\n                coords.push({ x, y, z });\n            }\n        }\n        return coords;\n    }\n\n    // Remove tiles too far outside of view\n    pruneTileCoordinatesForView(border_buffer = 2) {\n        if (!this.viewReady()) {\n            return;\n        }\n\n        // Remove tiles that are a specified # of tiles outside of the viewport border\n        let border_tiles = [\n            Math.ceil((Math.floor(this.css_size.width / Geo.tile_size) + 2) / 2),\n            Math.ceil((Math.floor(this.css_size.height / Geo.tile_size) + 2) / 2)\n        ];\n        let style_zoom = this.tileZoom(this.zoom);\n\n        this.tile_manager.removeTiles(tile => {\n            // Ignore visible tiles\n            if (tile.visible) {\n                return false;\n            }\n\n            // Discard if too far from current zoom\n            let zdiff = tile.coords.z - style_zoom;\n            if (Math.abs(zdiff) > this.preserve_tiles_within_zoom) {\n                return true;\n            }\n\n            // Handle tiles at different zooms\n            let ztrans = Math.pow(2, zdiff);\n            let coords = {\n                x: Math.floor(tile.coords.x / ztrans),\n                y: Math.floor(tile.coords.y / ztrans)\n            };\n\n            // Discard tiles outside an area surrounding the viewport\n            if (Math.abs(coords.x - this.center_tile.x) - border_tiles[0] > border_buffer) {\n                log.trace(`Scene: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${style_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            else if (Math.abs(coords.y - this.center_tile.y) - border_tiles[1] > border_buffer) {\n                log.trace(`Scene: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${style_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            return false;\n        });\n    }\n\n    resizeMap(width, height) {\n        this.dirty = true;\n\n        this.css_size = { width: width, height: height };\n        this.device_size = {\n            width: Math.round(this.css_size.width * Utils.device_pixel_ratio),\n            height: Math.round(this.css_size.height * Utils.device_pixel_ratio)\n        };\n        this.view_aspect = this.css_size.width / this.css_size.height;\n        this.updateBounds();\n\n        if (this.canvas) {\n            this.canvas.style.width = this.css_size.width + 'px';\n            this.canvas.style.height = this.css_size.height + 'px';\n            this.canvas.width = this.device_size.width;\n            this.canvas.height = this.device_size.height;\n\n            if (this.gl) {\n                this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n                this.gl.viewport(0, 0, this.canvas.width, this.canvas.height);\n            }\n        }\n    }\n\n    // Request scene be redrawn at next animation loop\n    requestRedraw() {\n        this.dirty = true;\n    }\n\n    // Redraw scene immediately - don't wait for animation loop\n    // Use sparingly, but for cases where you need the closest possible sync with other UI elements,\n    // such as other, non-WebGL map layers (e.g. Leaflet raster layers, markers, etc.)\n    immediateRedraw() {\n        this.dirty = true;\n        this.update();\n    }\n\n    renderLoop () {\n        this.render_loop_active = true; // only let the render loop instantiate once\n\n        if (this.initialized) {\n            // Render the scene\n            this.update();\n        }\n\n        // Request the next frame if not scheduled to stop\n        if (!this.render_loop_stop) {\n            window.requestAnimationFrame(this.renderLoop.bind(this));\n        }\n        else {\n            this.render_loop_stop = false;\n            this.render_loop_active = false;\n        }\n    }\n\n    // Setup the render loop\n    setupRenderLoop() {\n        if (!this.render_loop_active) {\n            setTimeout(() => { this.renderLoop(); }, 0); // delay start by one tick\n        }\n    }\n\n    update() {\n        this.tile_manager.loadQueuedCoordinates();\n\n        // Render on demand\n        var will_render = !(\n            this.dirty === false ||\n            this.initialized === false ||\n            this.updating > 0 ||\n            this.viewReady() === false\n        );\n\n        // Pre-render loop hook\n        if (typeof this.preUpdate === 'function') {\n            this.preUpdate(will_render);\n        }\n\n        // Bail if no need to render\n        if (!will_render) {\n            return false;\n        }\n        this.dirty = false; // subclasses can set this back to true when animation is needed\n\n        // Render the scene\n        this.render();\n\n        // Post-render loop hook\n        if (typeof this.postUpdate === 'function') {\n            this.postUpdate(will_render);\n        }\n\n        // Redraw every frame if animating\n        if (this.animated === true) {\n            this.dirty = true;\n        }\n\n        this.frame++;\n        log.trace('Scene.render()');\n        return true;\n    }\n\n    render() {\n        var gl = this.gl;\n\n        // Map transforms\n        if (!this.center_meters) {\n            return;\n        }\n\n        // Update styles, camera, lights\n        this.camera.update();\n        Object.keys(this.active_styles).forEach(i => this.styles[i].update());\n        Object.keys(this.lights).forEach(i => this.lights[i].update());\n\n        // Renderable tile list\n        this.renderable_tiles = this.tile_manager.getRenderableTiles();\n        this.renderable_tiles_count = this.renderable_tiles.length;\n\n        // Render main pass\n        this.render_count = this.renderPass();\n\n        // Render selection pass (if needed)\n        if (this.selection.pendingRequests()) {\n            if (this.panning) {\n                return;\n            }\n\n            this.selection.bind();                  // switch to FBO\n            this.renderPass(\n                'selection_program',                // render w/alternate program\n                { allow_alpha_blend: false });\n            this.selection.read();                  // read results from selection buffer\n\n            // Reset to screen buffer\n            gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n            gl.viewport(0, 0, this.canvas.width, this.canvas.height);\n        }\n\n        if (this.render_count !== this.last_render_count) {\n            this.getFeatureSelectionMapSize().then(size => {\n                log.info(`Scene: rendered ${this.render_count} primitives (${size} features in selection map)`);\n            }, () => {}); // no op when promise rejects (only print last response)\n        }\n        this.last_render_count = this.render_count;\n\n        return true;\n    }\n\n    // Render all active styles, grouped by blend/depth type (opaque, overlay, etc.) and by program (style)\n    // Called both for main render pass, and for secondary passes like selection buffer\n    renderPass(program_key = 'program', { allow_alpha_blend } = {}) {\n        let styles;\n        let count = 0; // how many primitives were rendered\n\n        // optionally force alpha off (e.g. for selection pass)\n        allow_alpha_blend = (allow_alpha_blend == null) ? true : allow_alpha_blend;\n\n        this.clearFrame({ clear_color: true, clear_depth: true });\n\n        // Opaque styles: depth test on, depth write on, blending off\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'opaque');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: true, alpha_blend: false });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Transparent styles: depth test off, depth write on, custom blending\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'add');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: (allow_alpha_blend && 'add') });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'multiply');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: (allow_alpha_blend && 'multiply') });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Inlay styles: depth test on, depth write off, blending on\n        styles = Object.keys(this.styles).filter(s => this.styles[s].blend === 'inlay');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: allow_alpha_blend });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Overlay styles: depth test off, depth write off, blending on\n        styles = Object.keys(this.styles).filter(s => this.styles[s].blend === 'overlay');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: false, depth_write: false, alpha_blend: allow_alpha_blend });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        return count;\n    }\n\n    renderStyles(styles, program_key) {\n        let count = 0;\n        for (let style of styles) {\n            let program = this.styles[style][program_key];\n            if (!program || !program.compiled) {\n                continue;\n            }\n            count += this.renderStyle(style, program);\n        }\n        return count;\n    }\n\n    renderStyle(style, program) {\n        var first_for_style = true;\n        var render_count = 0;\n\n        // Render tile GL geometries\n        for (var t in this.renderable_tiles) {\n            var tile = this.renderable_tiles[t];\n\n            if (tile.meshes[style] != null) {\n                // Setup style if encountering for first time this frame\n                // (lazy init, not all styles will be used in all screen views; some styles might be defined but never used)\n                if (first_for_style === true) {\n                    first_for_style = false;\n\n                    program.use();\n                    this.styles[style].setup();\n\n                    // TODO: don't set uniforms when they haven't changed\n                    program.uniform('2f', 'u_resolution', this.device_size.width, this.device_size.height);\n                    program.uniform('1f', 'u_time', ((+new Date()) - this.start_time) / 1000);\n                    program.uniform('3f', 'u_map_position', this.center_meters.x, this.center_meters.y, this.zoom);\n                    // Math.floor(this.zoom) + (Math.log((this.zoom % 1) + 1) / Math.LN2 // scale fractional zoom by log\n                    program.uniform('1f', 'u_meters_per_pixel', this.meters_per_pixel);\n                    program.uniform('1f', 'u_device_pixel_ratio', Utils.device_pixel_ratio);\n\n                    // Normal matrix - transforms surface normals into view space\n                    // this matrix is constant since the view doesn't rotate for now\n                    mat3.normalFromMat4(this.normalMatrix32, this.modelViewMatrix32);\n                    program.uniform('Matrix3fv', 'u_normalMatrix', false, this.normalMatrix32);\n\n                    this.camera.setupProgram(program);\n                    for (let i in this.lights) {\n                        this.lights[i].setupProgram(program);\n                    }\n                }\n\n                // TODO: calc these once per tile (currently being needlessly re-calculated per-tile-per-style)\n\n                // Tile origin\n                program.uniform('3f', 'u_tile_origin', tile.min.x, tile.min.y, tile.style_zoom);\n\n                // Model matrix - transform tile space into world space (meters, absolute mercator position)\n                mat4.identity(this.modelMatrix);\n                mat4.translate(this.modelMatrix, this.modelMatrix, vec3.fromValues(tile.min.x, tile.min.y, 0));\n                mat4.scale(this.modelMatrix, this.modelMatrix, vec3.fromValues(tile.span.x / Geo.tile_scale, -1 * tile.span.y / Geo.tile_scale, 1)); // scale tile local coords to meters\n                mat4.copy(this.modelMatrix32, this.modelMatrix);\n                program.uniform('Matrix4fv', 'u_model', false, this.modelMatrix32);\n\n                // Model view matrix - transform tile space into view space (meters, relative to camera)\n                mat4.multiply(this.modelViewMatrix32, this.camera.viewMatrix, this.modelMatrix);\n                program.uniform('Matrix4fv', 'u_modelView', false, this.modelViewMatrix32);\n\n                // Render tile\n                tile.meshes[style].render();\n                render_count += tile.meshes[style].geometry_count;\n            }\n        }\n\n        return render_count;\n    }\n\n    clearFrame({ clear_color, clear_depth } = {}) {\n        if (!this.initialized) {\n            return;\n        }\n\n        // Defaults\n        clear_color = (clear_color === false) ? false : true; // default true\n        clear_depth = (clear_depth === false) ? false : true; // default true\n\n        // Reset frame state\n        let gl = this.gl;\n\n        if (clear_color) {\n            gl.clearColor(...this.background.color);\n        }\n\n        if (clear_depth) {\n            gl.depthMask(true); // always clear depth if requested, even if depth write will be turned off\n        }\n\n        if (clear_color || clear_depth) {\n            let mask = (clear_color && gl.COLOR_BUFFER_BIT) | (clear_depth && gl.DEPTH_BUFFER_BIT);\n            gl.clear(mask);\n        }\n    }\n\n    setRenderState({ depth_test, depth_write, cull_face, alpha_blend } = {}) {\n        if (!this.initialized) {\n            return;\n        }\n\n        // Defaults\n        // TODO: when we abstract out support for multiple render passes, these can be per-pass config options\n        depth_test = (depth_test === false) ? false : true;         // default true\n        depth_write = (depth_write === false) ? false : true;       // default true\n        cull_face = (cull_face === false) ? false : true;           // default true\n        alpha_blend = (alpha_blend != null) ? alpha_blend : false;  // default false\n\n        // Reset frame state\n        let gl = this.gl;\n\n        RenderState.depth_test.set({ depth_test: depth_test, depth_func: gl.LEQUAL });\n        RenderState.depth_write.set({ depth_write: depth_write });\n        RenderState.culling.set({ cull: cull_face, face: gl.BACK });\n\n        if (alpha_blend) {\n            // Traditional blending\n            if (alpha_blend === true) {\n                RenderState.blending.set({ blend: true, src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA });\n            }\n            // Additive blending\n            else if (alpha_blend === 'add') {\n                RenderState.blending.set({ blend: true, src: gl.ONE, dst: gl.ONE });\n            }\n            // Multiplicative blending\n            else if (alpha_blend === 'multiply') {\n                RenderState.blending.set({ blend: true, src: gl.ZERO, dst: gl.SRC_COLOR });\n            }\n        }\n        else {\n            RenderState.blending.set({ blend: false, src: null, dst: null} );\n        }\n    }\n\n    // Request feature selection at given pixel. Runs async and returns results via a promise.\n    getFeatureAt(pixel) {\n        if (!this.initialized) {\n            log.debug(\"Scene.getFeatureAt() called before scene was initialized\");\n            return Promise.resolve();\n        }\n\n        // Point scaled to [0..1] range\n        var point = {\n            x: pixel.x * Utils.device_pixel_ratio / this.device_size.width,\n            y: pixel.y * Utils.device_pixel_ratio / this.device_size.height\n        };\n\n        this.dirty = true; // need to make sure the scene re-renders for these to be processed\n        return this.selection.getFeatureAt(point);\n    }\n\n    // Rebuild geometry, without re-parsing the config or re-compiling styles\n    // TODO: detect which elements need to be refreshed/rebuilt (stylesheet changes, etc.)\n    rebuild() {\n        return this.rebuildGeometry();\n    }\n\n    // Rebuild all tiles\n    rebuildGeometry() {\n        return new Promise((resolve, reject) => {\n            // Skip rebuild if already in progress\n            if (this.building) {\n                // Queue up to one rebuild call at a time, only save last request\n                if (this.building.queued && this.building.queued.reject) {\n                    // notify previous request that it did not complete\n                    log.debug('Scene.rebuildGeometry: request superceded by a newer call');\n                    this.building.queued.resolve(false); // false flag indicates rebuild request was superceded\n                }\n\n                // Save queued request\n                this.building.queued = { resolve, reject };\n                log.trace(`Scene.rebuildGeometry(): queuing request`);\n                return;\n            }\n\n            // Track tile build state\n            this.building = { resolve, reject };\n\n            // Profiling\n            if (this.debug.profile.geometry_build) {\n                this._profile('rebuildGeometry');\n            }\n\n            // Update config (in case JS objects were manipulated directly)\n            this.syncConfigToWorker();\n            StyleManager.compile(this.updateActiveStyles(), this); // only recompile newly active styles\n            this.resetFeatureSelection();\n            this.resetTime();\n\n            // Rebuild visible tiles, sorted from center\n            let build = [];\n            this.tile_manager.forEachTile((tile) => {\n                if (tile.visible) {\n                    build.push(tile);\n                }\n                else {\n                    this.tile_manager.removeTile(tile.key);\n                }\n            });\n            this.tile_manager.buildTiles(build);\n        }).then(() => {\n            // Profiling\n            if (this.debug.profile.geometry_build) {\n                this._profileEnd('rebuildGeometry');\n            }\n        });\n    }\n\n    // Tile manager finished building tiles\n    tileManagerBuildDone() {\n        if (this.building) {\n            log.info(`Scene: build geometry finished`);\n            if (this.building.resolve) {\n                this.building.resolve(true);\n            }\n\n            // Another rebuild queued?\n            var queued = this.building.queued;\n            this.building = null;\n            if (queued) {\n                log.debug(`Scene: starting queued rebuildGeometry() request`);\n                this.rebuildGeometry().then(queued.resolve, queued.reject);\n            }\n        }\n    }\n\n    /**\n       Load (or reload) the scene config\n       @return {Promise}\n    */\n    loadScene(config_source = null, config_path = null) {\n        this.config_source = config_source || this.config_source;\n\n        if (typeof this.config_source === 'string') {\n            this.config_path = config_path || Utils.pathForURL(this.config_source);\n        }\n        else {\n            this.config_path = null;\n        }\n\n        return SceneLoader.loadScene(this.config_source, this.config_path).then(config => {\n            this.config = config;\n            this.trigger('load', { config: this.config });\n            return this.config;\n        });\n    }\n\n    loadDataSources() {\n        for (var name in this.config.sources) {\n            let source = this.config.sources[name];\n            this.sources[name] = DataSource.create(Object.assign({}, source, {name}));\n\n            if (!this.sources[name]) {\n                delete this.sources[name];\n                log.warn(`Scene: could not create data source`, source);\n                this.trigger('warning', { type: 'sources', source, message: `Could not create data source` });\n            }\n        }\n    }\n\n    // Load all textures in the scene definition\n    loadTextures() {\n        return Texture.createFromObject(this.gl, this.config.textures);\n    }\n\n    // Called (currently manually) after styles are updated in stylesheet\n    updateStyles() {\n        if (!this.initialized && !this.initializing) {\n            throw new Error('Scene.updateStyles() called before scene was initialized');\n        }\n\n        // (Re)build styles from config\n        StyleManager.init();\n        this.styles = StyleManager.build(this.config.styles, this);\n\n        // Optionally set GL context (used when initializing or re-initializing GL resources)\n        for (var style of Utils.values(this.styles)) {\n            style.setGL(this.gl);\n        }\n\n        // Find & compile active styles\n        this.updateActiveStyles();\n        StyleManager.compile(Object.keys(this.active_styles), this);\n\n        this.dirty = true;\n    }\n\n    updateActiveStyles() {\n        // Make a set of currently active styles (used in a draw rule)\n        // Note: doesn't actually check if any geometry matches the rule, just that the style is potentially renderable\n        let prev_styles = Object.keys(this.active_styles || {});\n        this.active_styles = {};\n        var animated = false; // is any active style animated?\n        for (var rule of Utils.recurseValues(this.config.layers)) {\n            if (rule.draw) {\n                for (let [name, group] of Utils.entries(rule.draw)) {\n                    // TODO: warn on non-object draw group\n                    if (typeof group === 'object' && group.visible !== false) {\n                        let style_name = group.style || name;\n                        let styles = [style_name];\n\n                        // optional additional outline style\n                        if (group.outline && group.outline.style) {\n                            styles.push(group.outline.style);\n                        }\n\n                        styles = styles.filter(x => this.styles[x]).forEach(style_name => {\n                            let style = this.styles[style_name];\n                            if (style) {\n                                this.active_styles[style_name] = true;\n                                if (style.animated) {\n                                    animated = true;\n                                }\n                            }\n                        });\n                    }\n                }\n            }\n        }\n\n        // Use explicitly set scene animation flag if defined, otherwise turn on animation\n        // if there are any animated styles\n        this.animated = this.config.scene.animated !== undefined ? this.config.scene.animated : animated;\n\n        // Compile newly active styles\n        return Object.keys(this.active_styles).filter(s => prev_styles.indexOf(s) === -1);\n    }\n\n    // Create camera\n    createCamera() {\n        let active_camera = this._active_camera;\n        if (active_camera) {\n            this.camera = Camera.create(active_camera, this, this.config.cameras[this._active_camera]);\n\n            // TODO: replace this and move all position info to camera\n            this.camera.updateScene();\n        }\n    }\n\n    // Get active camera - for public API\n    getActiveCamera() {\n        return this._active_camera;\n    }\n\n    // Set active camera and recompile - for public API\n    setActiveCamera(name) {\n        this._active_camera = name;\n        this.updateConfig();\n        return this._active_camera;\n    }\n\n    // Internal management of active camera\n    get _active_camera() {\n        if (this.config && this.config.cameras) {\n            for (var name in this.config.cameras) {\n                if (this.config.cameras[name].active) {\n                    return name;\n                }\n            }\n        }\n    }\n\n    set _active_camera(name) {\n        var prev = this._active_camera;\n\n        // Set new active camera\n        if (this.config.cameras[name]) {\n            this.config.cameras[name].active = true;\n\n            // Clear previously active camera\n            if (prev && prev !== name && this.config.cameras[prev]) {\n                delete this.config.cameras[prev].active;\n            }\n        }\n    }\n\n    // Create lighting\n    createLights() {\n        this.lights = {};\n        for (let i in this.config.lights) {\n            if (!this.config.lights[i] || typeof this.config.lights[i] !== 'object') {\n                continue;\n            }\n            let light = this.config.lights[i];\n            light.name = i.replace('-', '_'); // light names are injected in shaders, can't have hyphens\n            light.visible = (light.visible === false) ? false : true;\n            if (light.visible) {\n                this.lights[light.name] = Light.create(this, light);\n            }\n        }\n        Light.inject(this.lights);\n    }\n\n    // Set background color\n    setBackground() {\n        let bg = this.config.scene.background;\n        this.background = {};\n        if (bg && bg.color) {\n            this.background.color = StyleParser.parseColor(bg.color);\n        }\n        if (!this.background.color) {\n            this.background.color = [0, 0, 0, 1]; // default background to black\n        }\n    }\n\n    // Update scene config, and optionally rebuild geometry\n    updateConfig({ rebuild } = {}) {\n        this.generation++;\n        this.updating++;\n        this.config.scene = this.config.scene || {};\n        this.createCamera();\n        this.createLights();\n        this.loadDataSources();\n        this.loadTextures();\n        this.setBackground();\n        this.updateBounds();\n\n        // TODO: detect changes to styles? already (currently) need to recompile anyway when camera or lights change\n        this.updateStyles();\n        this.syncConfigToWorker();\n        if (rebuild) {\n            return this.rebuildGeometry().then(() => this.updating--);\n        }\n        else {\n            this.updating--;\n            return Promise.resolve();\n        }\n    }\n\n    // Serialize config and send to worker\n    syncConfigToWorker() {\n        // Tell workers we're about to rebuild (so they can update styles, etc.)\n        this.config_serialized = Utils.serializeWithFunctions(this.config);\n        this.workers.forEach(worker => {\n            WorkerBroker.postMessage(worker, 'updateConfig', {\n                config: this.config_serialized,\n                generation: this.generation\n            });\n        });\n    }\n\n    resetFeatureSelection() {\n        if (!this.selection) {\n            this.selection = new FeatureSelection(this.gl, this.workers);\n        }\n        else if (this.workers) {\n            this.workers.forEach(worker => WorkerBroker.postMessage(worker, 'resetFeatureSelection'));\n        }\n    }\n\n    // Gets the current feature selection map size across all workers. Returns a promise.\n    getFeatureSelectionMapSize() {\n        if (this.fetching_selection_map) {\n            return Promise.reject();\n        }\n        this.fetching_selection_map = true;\n\n        return Promise\n            .all(this.workers.map(worker => WorkerBroker.postMessage(worker, 'getFeatureSelectionMapSize')))\n            .then(sizes => {\n                this.fetching_selection_map = false;\n                return sizes.reduce((a, b) => a + b);\n            });\n    }\n\n    // Reset internal clock, mostly useful for consistent experience when changing styles/debugging\n    resetTime() {\n        this.start_time = +new Date();\n    }\n\n\n    // Stats/debug/profiling methods\n\n    // Log messages pass through from web workers\n    workerLogMessage(event) {\n        if (event.data.type !== 'log') {\n            return;\n        }\n\n        var { worker_id, level, msg } = event.data;\n\n        if (log[level]) {\n            log[level](`worker ${worker_id}:`,  ...msg);\n        }\n        else {\n            log.error(`Scene.workerLogMessage: unrecognized log level ${level}`);\n        }\n    }\n\n    // Profile helpers, issues a profile on main thread & all workers\n    _profile(name) {\n        console.profile(`main thread: ${name}`);\n        this.workers.forEach(w => WorkerBroker.postMessage(w, 'profile', name));\n    }\n\n    _profileEnd(name) {\n        console.profileEnd(`main thread: ${name}`);\n        this.workers.forEach(w => WorkerBroker.postMessage(w, 'profileEnd', name));\n    }\n\n    // Rebuild geometry a given # of times and print average, min, max timings\n    _timeRebuild (num = 1) {\n        let times = [];\n        let cycle = () => {\n            let start = +new Date();\n            this.rebuild().then(() => {\n                times.push(+new Date() - start);\n\n                if (times.length < num) {\n                    cycle();\n                }\n                else {\n                    let avg = ~~(times.reduce((a, b) => a + b) / times.length);\n                    log.info(`Profiled rebuild ${num} times: ${avg} avg (${Math.min(...times)} min, ${Math.max(...times)} max)`);\n                }\n            });\n        };\n        cycle();\n    }\n\n}\n\n// Static methods/state\n\nScene.create = function (config, options = {}) {\n    return new Scene(config, options);\n};\n","import Utils from './utils/utils';\nimport GLSL from './gl/glsl';\n// import {mergeObjects} from './styles/rule';\nimport {StyleManager} from './styles/style_manager';\n\nvar SceneLoader;\n\nexport default SceneLoader = {\n\n    // Load scenes definitions from URL & proprocess\n    loadScene(url, path = null) {\n        return SceneLoader.loadSceneRecursive(url, path).then(SceneLoader.finalize);\n    },\n\n    // Loads scene files from URL, recursively loading 'included' scenes\n    // Optional *initial* path only (won't be passed to recursive 'include' calls)\n    // Useful for loading resources in base scene file from a separate location\n    // (e.g. in Tangram Play, when modified local scene should still refer to original resource URLs)\n    loadSceneRecursive(url, path = null) {\n        if (!url) {\n            return Promise.resolve({});\n        }\n\n        if (typeof url === 'string') {\n            path = path || Utils.pathForURL(url);\n        }\n\n        return Utils.loadResource(url).then(config => {\n            return StyleManager.loadRemoteStyles(config.styles, path).\n                then(styles => StyleManager.loadShaderBlocks(styles, path)). // TODO: deprecate remote shader blocks?\n                then(() => {\n                    // accept single-string or array\n                    // if (typeof config.include === 'string') {\n                    //     config.include = [config.include];\n                    // }\n\n                    // if (!Array.isArray(config.include)) {\n                        SceneLoader.normalize(config, path);\n                        return config;\n                    // }\n\n                    // Collect URLs of scenes to include\n                    // let includes = [];\n                    // for (let url of config.include) {\n                    //     includes.push(Utils.addBaseURL(url, path));\n                    // }\n                    // delete config.include; // don't want to merge this property\n\n                    // return Promise.\n                    //     all(includes.map(url => SceneLoader.loadSceneRecursive(url))).\n                    //     then(configs => {\n                    //         config = mergeObjects({}, ...configs, config);\n                    //         SceneLoader.normalize(config, path);\n                    //         return config;\n                    //     });\n                });\n        });\n    },\n\n    // Normalize properties that should be adjust within each local scene file (usually by path)\n    normalize(config, path) {\n        SceneLoader.normalizeDataSources(config, path);\n        SceneLoader.normalizeTextures(config, path);\n        return config;\n    },\n\n    // Expand paths for data source\n    normalizeDataSources(config, path) {\n        config.sources = config.sources || {};\n\n        for (let source of  Utils.values(config.sources)) {\n            source.url = Utils.addBaseURL(source.url, path);\n        }\n\n        return config;\n    },\n\n    // Expand paths and centralize texture definitions for a scene object\n    normalizeTextures(config, path) {\n        config.textures = config.textures || {};\n\n        if (config.styles) {\n            for (let [style_name, style] of Utils.entries(config.styles)) {\n                if (style.texture) {\n                    // Texture by URL, expand relative to scene file\n                    if (typeof style.texture === 'string' && !config.textures[style.texture]) {\n                        style.texture = Utils.addBaseURL(style.texture, path);\n                    }\n                    // Texture by object, move it to the global scene texture set and give it a default name\n                    else if (typeof style.texture === 'object') {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = style.texture;\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                }\n\n                // If style has texture uniforms, expand texture URLs relative to scene file\n                if (style.shaders && style.shaders.uniforms) {\n                    for (let {type, value, key, uniforms} of GLSL.parseUniforms(style.shaders.uniforms)) {\n                        if (type === 'sampler2D' && !config.textures[value]) {\n                            uniforms[key] = Utils.addBaseURL(value, path);\n                        }\n                    }\n                }\n\n                // If style has material, expand texture URLs relative to scene file\n                if (style.material) {\n                    for (let prop of ['emission', 'ambient', 'diffuse', 'specular', 'normal']) {\n                        if (style.material[prop] != null &&\n                            style.material[prop].texture &&\n                            !config.textures[style.material[prop].texture]) {\n                            style.material[prop].texture = Utils.addBaseURL(style.material[prop].texture, path);\n                        }\n                    }\n                }\n            }\n        }\n\n        // Add path to textures\n        if (config.textures) {\n            for (let texture of Utils.values(config.textures)) {\n                texture.url = Utils.addBaseURL(texture.url, path);\n            }\n        }\n\n        return config;\n    },\n\n    // Normalize some scene-wide settings that apply to the final, merged scene\n    finalize(config) {\n        // Assign ids to data sources\n        let source_id = 0;\n        for (let source in config.sources) {\n            config.sources[source].id = source_id++;\n        }\n\n        // If only one camera specified, set it as default\n        config.cameras = config.cameras || {};\n        if (config.camera) {\n            config.cameras.default = config.camera;\n        }\n\n        // If no cameras specified, create one\n        if (Object.keys(config.cameras).length === 0) {\n            config.cameras.default = {};\n        }\n\n        // If no camera set as active, use first one\n        let active = false;\n        for (let camera of Utils.values(config.cameras)) {\n            if (camera.active) {\n                active = true;\n                break;\n            }\n        }\n\n        if (!active) {\n            config.cameras[Object.keys(config.cameras)[0]].active = true;\n        }\n\n        // Ensure top-level properties\n        config.lights = config.lights || {};\n        config.styles = config.styles || {};\n\n        return config;\n    }\n\n};\n","/*jshint worker: true*/\nimport Utils from './utils/utils';\nimport WorkerBroker from './utils/worker_broker'; // jshint ignore:line\nimport Tile from './tile';\nimport DataSource from './sources/data_source';\nimport FeatureSelection from './selection';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport {parseRules} from './styles/rule';\nimport Texture from './gl/texture';\n\nexport var SceneWorker = self;\n\n// Worker functionality will only be defined in worker thread\nUtils.isWorkerThread && Object.assign(self, {\n\n    FeatureSelection,\n\n    sources: {\n        tiles: {},\n        objects: {}\n    },\n    styles: {},\n    rules: {},\n    layers: {},\n    tiles: {},\n    objects: {},\n    config: {},\n\n    // Initialize worker\n    init (worker_id, num_workers, device_pixel_ratio) {\n        self._worker_id = worker_id;\n        self.num_workers = num_workers;\n        Utils.device_pixel_ratio = device_pixel_ratio;\n        FeatureSelection.setPrefix(self._worker_id);\n        return worker_id;\n    },\n\n    // Starts a config refresh\n    updateConfig ({ config, generation }) {\n        self.config = null;\n        config = JSON.parse(config);\n\n        self.generation = generation;\n        self.styles = null;\n\n        // Data block functions are not macro'ed and wrapped like the rest of the style functions are\n        // TODO: probably want a cleaner way to exclude these\n        for (var layer in config.layers) {\n            config.layers[layer].data = Utils.stringsToFunctions(config.layers[layer].data);\n        }\n\n        // Create data sources\n        config.sources = Utils.stringsToFunctions(StyleParser.expandMacros(config.sources));\n        for (var name in config.sources) {\n            let source = DataSource.create(Object.assign(config.sources[name], {name}));\n            if (!source) {\n                continue;\n            }\n\n            if (source.tiled) {\n                self.sources.tiles[name] = source;\n            }\n            else {\n                // Distribute object sources across workers\n                if (source.id % self.num_workers === self._worker_id) {\n                    // Load source if not cached\n                    self.sources.objects[name] = source;\n                    if (!self.objects[source.name]) {\n                        self.objects[source.name] = {};\n                        source.load(self.objects[source.name]);\n                    }\n                }\n            }\n        }\n\n        // Expand styles\n        self.config = Utils.stringsToFunctions(StyleParser.expandMacros(config), StyleParser.wrapFunction);\n        self.styles = StyleManager.build(self.config.styles, { generation: self.generation });\n\n        // Parse each top-level layer as a separate rule tree\n        // TODO: find a more graceful way to incorporate this\n\n        self.rules = parseRules(self.config.layers);\n\n        // Sync tetxure info from main thread\n        self.syncing_textures = self.syncTextures();\n\n        // Return promise for when config refresh finishes\n        self.configuring = self.syncing_textures.then(() => {\n            Utils.log('debug', `updated config`);\n        });\n    },\n\n    // Returns a promise that fulfills when config refresh is finished\n    awaitConfiguration () {\n        return self.configuring;\n    },\n\n    // Build a tile: load from tile source if building for first time, otherwise rebuild with existing data\n    buildTile ({ tile }) {\n        // Tile cached?\n        if (self.tiles[tile.key] != null) {\n            // Already loading?\n            if (self.tiles[tile.key].loading === true) {\n                return;\n            }\n        }\n\n        // Update tile cache\n        tile = self.tiles[tile.key] = Object.assign(self.tiles[tile.key] || {}, tile);\n\n        // Update config (styles, etc.), then build tile\n        return self.awaitConfiguration().then(() => {\n            // First time building the tile\n            if (tile.loaded !== true) {\n\n                return new Promise((resolve, reject) => {\n\n                    tile.loading = true;\n                    tile.loaded = false;\n                    tile.error = null;\n\n                    self.loadTileSourceData(tile).then(() => {\n                        // Warn and continue on data source error\n                        if (tile.source_data.error) {\n                            Utils.log('warn', `tile load error(s) for ${tile.key}: ${tile.source_data.error}`);\n                        }\n\n                        tile.loading = false;\n                        tile.loaded = true;\n                        Tile.buildGeometry(tile, self.config.layers, self.rules, self.styles).then(keys => {\n                            resolve({ tile: Tile.slice(tile, keys) });\n                        });\n                    }).catch((error) => {\n                        tile.loading = false;\n                        tile.loaded = false;\n                        tile.error = error.toString();\n                        Utils.log('error', `tile load error for ${tile.key}: ${error.stack}`);\n\n                        resolve({ tile: Tile.slice(tile) });\n                    });\n                });\n            }\n            // Tile already loaded, just rebuild\n            else {\n                Utils.log('trace', `used worker cache for tile ${tile.key}`);\n\n                // Build geometry\n                return Tile.buildGeometry(tile, self.config.layers, self.rules, self.styles).then(keys => {\n                    return { tile: Tile.slice(tile, keys) };\n                });\n            }\n        });\n    },\n\n    // Load this tile's data source\n    loadTileSourceData (tile) {\n        return self.sources.tiles[tile.source].load(tile);\n    },\n\n    // Remove tile\n    removeTile (key) {\n        var tile = self.tiles[key];\n\n        if (tile != null) {\n            // Cancel if loading\n            if (tile.loading === true) {\n                Utils.log('trace', `cancel tile load for ${key}`);\n                tile.loading = false;\n            }\n\n            Tile.cancel(tile);\n\n            // Remove from cache\n            FeatureSelection.clearTile(key);\n            delete self.tiles[key];\n            Utils.log('trace', `remove tile from cache for ${key}`);\n        }\n    },\n\n    // Get a feature from the selection map\n    getFeatureSelection ({ id, key } = {}) {\n        var selection = FeatureSelection.map[key];\n\n        return {\n            id: id,\n            feature: (selection && selection.feature)\n        };\n    },\n\n    // Resets the feature selection state\n    resetFeatureSelection () {\n        FeatureSelection.reset();\n    },\n\n    // Selection map size for this worker\n    getFeatureSelectionMapSize () {\n        return FeatureSelection.getMapSize();\n    },\n\n    // Texture info needs to be synced from main thread\n    syncTextures () {\n        // We're only syncing the textures that have sprites defined, since these are (currently) the only ones we\n        // need info about for geometry construction (e.g. width/height, which we only know after the texture loads)\n        let textures = [];\n        if (self.config.textures) {\n            for (let [texname, texture] of Utils.entries(self.config.textures)) {\n                if (texture.sprites) {\n                    textures.push(texname);\n                }\n            }\n        }\n\n        Utils.log('trace', 'sync textures to worker:', textures);\n        if (textures.length > 0) {\n            return Texture.syncTexturesToWorker(textures);\n        }\n        return Promise.resolve();\n    },\n\n    // Profiling helpers\n    profile (name) {\n        console.profile(`worker ${self._worker_id}: ${name}`);\n    },\n\n    profileEnd (name) {\n        console.profileEnd(`worker ${self._worker_id}: ${name}`);\n    }\n\n});\n","import Texture from './gl/texture';\nimport WorkerBroker from './utils/worker_broker';\n\nexport default class FeatureSelection {\n\n    constructor(gl, workers) {\n        this.gl = gl;\n        this.workers = workers; // pool of workers to request feature look-ups from, keyed by id\n        this.init();\n    }\n\n    init() {\n        // Selection state tracking\n        this.requests = {}; // pending selection requests\n        this.feature = null; // currently selected feature\n        this.read_delay = 5; // delay time from selection render to framebuffer sample, to avoid CPU/GPU sync lock\n        this.read_delay_timer = null; // current timer (setTimeout) for delayed selection reads\n\n        this.pixel = new Uint8Array(4);\n        this.pixel32 = new Float32Array(this.pixel.buffer);\n\n        // Frame buffer for selection\n        // TODO: initiate lazily in case we don't need to do any selection\n        this.fbo = this.gl.createFramebuffer();\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, this.fbo);\n        this.fbo_size = { width: 256, height: 256 }; // TODO: make configurable / adaptive based on canvas size\n        this.fbo_size.aspect = this.fbo_size.width / this.fbo_size.height;\n\n        // Texture for the FBO color attachment\n        var fbo_texture = new Texture(this.gl, 'selection_fbo');\n        fbo_texture.setData(this.fbo_size.width, this.fbo_size.height, null, { filtering: 'nearest' });\n        this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER, this.gl.COLOR_ATTACHMENT0, this.gl.TEXTURE_2D, fbo_texture.texture, 0);\n\n        // Renderbuffer for the FBO depth attachment\n        var fbo_depth_rb = this.gl.createRenderbuffer();\n        this.gl.bindRenderbuffer(this.gl.RENDERBUFFER, fbo_depth_rb);\n        this.gl.renderbufferStorage(this.gl.RENDERBUFFER, this.gl.DEPTH_COMPONENT16, this.fbo_size.width, this.fbo_size.height);\n        this.gl.framebufferRenderbuffer(this.gl.FRAMEBUFFER, this.gl.DEPTH_ATTACHMENT, this.gl.RENDERBUFFER, fbo_depth_rb);\n\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n    }\n\n    destroy() {\n        if (this.gl && this.fbo) {\n            this.gl.deleteFramebuffer(this.fbo);\n            this.fbo = null;\n            this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n        }\n\n        // TODO: free texture?\n    }\n\n    bind() {\n        // Switch to FBO\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, this.fbo);\n        this.gl.viewport(0, 0, this.fbo_size.width, this.fbo_size.height);\n    }\n\n    // Request feature selection\n    // Runs asynchronously, schedules selection buffer to be updated\n    getFeatureAt(point) {\n        return new Promise((resolve, reject) => {\n            // Queue requests for feature selection, and they will be picked up by the render loop\n            this.selection_request_id = (this.selection_request_id + 1) || 0;\n            this.requests[this.selection_request_id] = {\n                type: 'point',\n                id: this.selection_request_id,\n                point,\n                resolve\n            };\n        });\n    }\n\n    // Any pending selection requests\n    pendingRequests() {\n        return this.requests;\n    }\n\n    // Read pending results from the selection buffer. Called after rendering to selection buffer.\n    read() {\n        // Delay reading the pixel result from the selection buffer to avoid CPU/GPU sync lock.\n        // Calling readPixels synchronously caused a massive performance hit, presumably since it\n        // forced this function to wait for the GPU to finish rendering and retrieve the texture contents.\n        if (this.read_delay_timer != null) {\n            clearTimeout(this.read_delay_timer);\n        }\n        this.read_delay_timer = setTimeout(() => {\n            var gl = this.gl;\n\n            gl.bindFramebuffer(gl.FRAMEBUFFER, this.fbo);\n\n            for (var r in this.requests) {\n                var request = this.requests[r];\n\n                // This request was already sent to the worker, we're just awaiting its reply\n                if (request.sent) {\n                    continue;\n                }\n\n                // TODO: support other selection types, such as features within a box\n                if (request.type !== 'point') {\n                    continue;\n                }\n\n                // Check selection map against FBO\n                gl.readPixels(\n                    Math.floor(request.point.x * this.fbo_size.width),\n                    Math.floor((1 - request.point.y) * this.fbo_size.height),\n                    1, 1, gl.RGBA, gl.UNSIGNED_BYTE, this.pixel);\n                var feature_key = (this.pixel[0] + (this.pixel[1] << 8) + (this.pixel[2] << 16) + (this.pixel[3] << 24)) >>> 0;\n\n                // If feature found, ask appropriate web worker to lookup feature\n                var worker_id = this.pixel[3];\n                if (worker_id !== 255) { // 255 indicates an empty selection buffer pixel\n                    if (this.workers[worker_id] != null) {\n                        WorkerBroker.postMessage(\n                            this.workers[worker_id],\n                            'getFeatureSelection',\n                            { id: request.id, key: feature_key })\n                        .then(message => {\n                            this.finishRead(message);\n                        });\n                    }\n                }\n                // No feature found, but still need to resolve promise\n                else {\n                    this.finishRead({ id: request.id, feature: null });\n                }\n\n                request.sent = true;\n            }\n\n            gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n\n        }, this.read_delay);\n    }\n\n    // Called on main thread when a web worker finds a feature in the selection buffer\n    finishRead (message) {\n        var request = this.requests[message.id];\n        if (!request) {\n            throw new Error(\"FeatureSelection.finishRead() called without any message\");\n        }\n\n        var feature = message.feature;\n        var changed = false;\n        if ((feature != null && this.feature == null) ||\n            (feature == null && this.feature != null) ||\n            (feature != null && this.feature != null && feature.id !== this.feature.id)) {\n            changed = true;\n        }\n\n        this.feature = feature; // store the most recently selected feature\n\n        // Resolve the request\n        request.resolve({ feature, changed, request });\n        delete this.requests[message.id]; // done processing this request\n    }\n\n\n    // Selection map generation\n    // Each worker will create its own independent, 'local' selection map\n\n    // Create a unique 32-bit color to identify a feature\n    // Workers independently create/modify selection colors in their own threads, but we also\n    // need the main thread to know where each feature color originated. To accomplish this,\n    // we partition the map by setting the 4th component (alpha channel) to the worker's id.\n    static makeEntry(tile) {\n        // 32-bit color key\n        this.map_entry++;\n        var ir = this.map_entry & 255;\n        var ig = (this.map_entry >> 8) & 255;\n        var ib = (this.map_entry >> 16) & 255;\n        var ia = this.map_prefix;\n        var r = ir / 255;\n        var g = ig / 255;\n        var b = ib / 255;\n        var a = ia / 255;\n        var key = (ir + (ig << 8) + (ib << 16) + (ia << 24)) >>> 0; // need unsigned right shift to convert to positive #\n\n        this.map[key] = {\n            color: [r, g, b, a],\n        };\n        this.map_size++;\n\n        this.tiles[tile.key] = this.tiles[tile.key] || [];\n        this.tiles[tile.key].push(key);\n\n        return this.map[key];\n    }\n\n    static makeColor(feature, tile) {\n        var selector = this.makeEntry(tile);\n        selector.feature = {\n            id: feature.id,\n            properties: feature.properties,\n            tile: tile.key\n        };\n\n        return selector.color;\n    }\n\n    static reset() {\n        this.tiles = {};\n        this.map = {};\n        this.map_size = 0;\n        this.map_entry = 0;\n    }\n\n    static clearTile(key) {\n        if (Array.isArray(this.tiles[key])) {\n            this.tiles[key].forEach(k => delete this.map[k]);\n            this.map_size -= this.tiles[key].length;\n            delete this.tiles[key];\n        }\n    }\n\n    static getMapSize() {\n        return this.map_size;\n    }\n\n    static setPrefix(prefix) {\n        this.map_prefix = prefix;\n    }\n\n}\n\n// Static properties\nFeatureSelection.map = {};   // this will be unique per module instance (so unique per worker)\nFeatureSelection.tiles = {}; // selection keys, by tile\nFeatureSelection.map_size = 0;\nFeatureSelection.map_entry = 0;\nFeatureSelection.map_prefix = 0; // set by worker to worker id #\nFeatureSelection.defaultColor = [0, 0, 0, 1];\n","/*jshint worker: true */\nimport Geo from '../geo';\nimport {MethodNotImplemented} from '../utils/errors';\nimport Utils from '../utils/utils';\n\nexport default class DataSource {\n\n    constructor (source) {\n        this.id = source.id;\n        this.name = source.name;\n        this.url = source.url;\n        this.pad_scale = source.pad_scale || 0.0005; // scale tile up by small factor to cover seams\n        this.enforce_winding = source.enforce_winding || false; // whether to enforce winding order\n\n        // Optional function to transform source data\n        this.transform = source.transform;\n        if (typeof this.transform === 'function') {\n            this.transform.bind(this);\n        }\n\n        // Optional additional data to pass to the transform function\n        this.extra_data = source.extra_data;\n\n        // Optional additional scripts made available to the transform function\n        if (typeof importScripts === 'function' && source.scripts) {\n            source.scripts.forEach(function(s, si) {\n                try {\n                    importScripts(s);\n                    Utils.log('info', 'DataSource: loaded library: ' + s);\n                }\n                catch (e) {\n                    Utils.log('error', 'DataSource: failed to load library: ' + s);\n                    Utils.log('error', e);\n                }\n            });\n        }\n\n        // overzoom will apply for zooms higher than this\n        this.max_zoom = Math.min(source.max_zoom || Geo.max_zoom, Geo.max_zoom);\n    }\n\n    // Create a tile source by type, factory-style\n    static create (source) {\n        if (DataSource.types[source.type]) {\n            return new DataSource.types[source.type](source);\n        }\n    }\n\n    // Mercator projection\n    static projectData (source) {\n        var timer = +new Date();\n        for (var t in source.layers) {\n            var num_features = source.layers[t].features.length;\n            for (var f=0; f < num_features; f++) {\n                var feature = source.layers[t].features[f];\n                Geo.transformGeometry(feature.geometry, coord => {\n                    var [x, y] = Geo.latLngToMeters(coord);\n                    coord[0] = x;\n                    coord[1] = y;\n                });\n            }\n        }\n\n        if (source.debug !== undefined) {\n            source.debug.projection = +new Date() - timer;\n        }\n    }\n\n    /**\n     Re-scale geometries within each source to internal tile units\n    */\n    static scaleData (source, {coords: {z}, min, max}) {\n        for (var t in source.layers) {\n            var num_features = source.layers[t].features.length;\n            for (var f=0; f < num_features; f++) {\n                var feature = source.layers[t].features[f];\n                Geo.transformGeometry(feature.geometry, coord => {\n                    coord[0] = (coord[0] - min.x) * Geo.units_per_meter[z];\n                    coord[1] = (coord[1] - min.y) * Geo.units_per_meter[z] * -1; // flip coords positive\n                });\n            }\n        }\n    }\n\n    load(dest) {\n        dest.source_data = {};\n        dest.source_data.layers = {};\n        dest.pad_scale = this.pad_scale;\n\n        return this._load(dest).then((dest) => {\n            // Post-processing\n            for (let layer in dest.source_data.layers) {\n                let data = dest.source_data.layers[layer];\n                if (data && data.features) {\n                    data.features.forEach(feature => {\n                        Geo.transformGeometry(feature.geometry, coord => {\n                            // Flip Y coords\n                            coord[1] = -coord[1];\n\n                            // Slightly scale up tile to cover seams\n                            if (this.pad_scale) {\n                                coord[0] = Math.round(coord[0] * (1 + this.pad_scale) - (Geo.tile_scale * this.pad_scale/2));\n                                coord[1] = Math.round(coord[1] * (1 + this.pad_scale) - (Geo.tile_scale * this.pad_scale/2));\n                            }\n                        });\n\n                        // Optionally enforce winding order since not all data sources guarantee it\n                        if (this.enforce_winding) {\n                            Geo.enforceWinding(feature.geometry, 'CCW');\n                        }\n                    });\n                }\n            }\n        });\n    }\n\n    // Sub-classes must implement\n    _load(dest) {\n        throw new MethodNotImplemented('_load');\n    }\n\n    // Register a new data source type, under a type name\n    static register(type_class, type_name) {\n        if (!type_class || !type_name) {\n            return;\n        }\n\n        DataSource.types[type_name] = type_class;\n    }\n\n}\n\nDataSource.types = {}; // set of supported data source classes, referenced by type name\n\n\n/*** Generic network loading source - abstract class ***/\n\nexport class NetworkSource extends DataSource {\n\n    constructor (source) {\n        super(source);\n        this.response_type = \"\"; // use to set explicit XHR type\n    }\n\n    _load (dest) {\n        // super.load(dest);\n\n        let url = this.formatUrl(dest);\n\n        let source_data = dest.source_data;\n        source_data.url = url;\n        dest.debug = dest.debug || {};\n        dest.debug.network = +new Date();\n\n        return new Promise((resolve, reject) => {\n            source_data.error = null;\n            // For testing network errors\n            // var promise = Utils.io(url, 60 * 100, this.response_type);\n            // if (Math.random() < .7) {\n            //     promise = Promise.reject(Error('fake data source error'));\n            // }\n            // promise.then((body) => {\n            let promise = Utils.io(url, 60 * 1000, this.response_type);\n            source_data.request = promise.request;\n\n            promise.then((body) => {\n                dest.debug.response_size = body.length || body.byteLength;\n                dest.debug.network = +new Date() - dest.debug.network;\n                dest.debug.parsing = +new Date();\n                this.parseSourceData(dest, source_data, body);\n                dest.debug.parsing = +new Date() - dest.debug.parsing;\n                resolve(dest);\n            }).catch((error) => {\n                source_data.error = error.toString();\n                resolve(dest); // resolve request but pass along error\n            });\n        });\n    }\n\n    // Sub-classes must implement:\n\n    formatUrl (dest) {\n        throw new MethodNotImplemented('formatUrl');\n    }\n\n    parseSourceData (dest, source, reponse) {\n        throw new MethodNotImplemented('parseSourceData');\n    }\n}\n\n\n/*** Generic network tile loading - abstract class ***/\n\nexport class NetworkTileSource extends NetworkSource {\n\n    constructor (source) {\n        super(source);\n\n        this.tiled = true;\n        this.url_hosts = null;\n        var host_match = this.url.match(/{s:\\[([^}+]+)\\]}/);\n        if (host_match != null && host_match.length > 1) {\n            this.url_hosts = host_match[1].split(',');\n            this.next_host = 0;\n        }\n    }\n\n    formatUrl(tile) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n        var url = this.url.replace('{x}', coords.x).replace('{y}', coords.y).replace('{z}', coords.z);\n\n        if (this.url_hosts != null) {\n            url = url.replace(/{s:\\[([^}+]+)\\]}/, this.url_hosts[this.next_host]);\n            this.next_host = (this.next_host + 1) % this.url_hosts.length;\n        }\n        return url;\n    }\n\n    // Checks for the x/y/z tile pattern in URL template\n    urlHasTilePattern(url) {\n        return url &&\n            url.search('{x}') > -1 &&\n            url.search('{y}') > -1 &&\n            url.search('{z}') > -1;\n    }\n\n}\n","import DataSource, {NetworkSource, NetworkTileSource} from './data_source';\nimport Geo from '../geo';\n\n// For tiling GeoJSON client-side\nimport geojsonvt from 'geojson-vt';\n\n\n/**\n Mapzen/OSM.US-style GeoJSON vector tiles\n @class GeoJSONTileSource\n*/\nexport class GeoJSONTileSource extends NetworkTileSource {\n\n    constructor(source) {\n        super(source);\n\n        // Check for URL tile pattern, if not found, treat as standalone GeoJSON/TopoJSON object\n        if (!this.urlHasTilePattern(this.url)) {\n            // Check instance type from parent class\n            if (this instanceof GeoJSONTileSource) {\n                // Replace instance type\n                return new GeoJSONSource(source);\n            }\n            else {\n                // Pass back to parent class to instantiate\n                return null;\n            }\n        }\n        return this;\n    }\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        this.prepareGeoJSON(data, tile, source);\n    }\n\n    prepareGeoJSON (data, tile, source) {\n        // Apply optional data transform\n        if (typeof this.transform === 'function') {\n            data = this.transform(data, source);\n        }\n\n        source.layers = GeoJSONSource.prototype.getLayers(data);\n\n        // A \"synthetic\" tile that adjusts the tile min anchor to account for tile longitude wrapping\n        let anchor = {\n            coords: tile.coords,\n            min: Geo.metersForTile(Geo.wrapTile(tile.coords, { x: true }))\n        };\n\n        DataSource.projectData(source); // mercator projection\n        DataSource.scaleData(source, anchor); // re-scale from meters to local tile coords\n    }\n\n}\n\n\n/**\n GeoJSON standalone (non-tiled) source\n Uses geojson-vt split into tiles client-side\n*/\n\nexport class GeoJSONSource extends NetworkSource {\n\n    constructor(source) {\n        super(source);\n        this.tiled = true;\n        this.load_data = null;\n        this.tile_indexes = {}; // geojson-vt tile indices, by layer name\n        this.max_zoom = Math.max(this.max_zoom || 0, 15); // TODO: max zoom < 15 causes artifacts/no-draw at 20, investigate\n        this.pad_scale = 0; // we don't want padding on auto-tiled sources\n        this.enforce_winding = (source.enforce_winding === false) ? false : true; // default on, can be forced off\n    }\n\n    _load(dest) {\n        if (!this.load_data) {\n            this.load_data = super._load({ source_data: { layers: {} } }).then(data => {\n                let layers = data.source_data.layers;\n                for (let layer_name in layers) {\n                    this.tile_indexes[layer_name] = geojsonvt(layers[layer_name], {\n                        maxZoom: this.max_zoom,  // max zoom to preserve detail on\n                        tolerance: 3, // simplification tolerance (higher means simpler)\n                        extent: Geo.tile_scale, // tile extent (both width and height)\n                        buffer: 0     // tile buffer on each side\n                    });\n                }\n\n                this.loaded = true;\n                return data;\n            });\n        }\n\n        return this.load_data.then(() => {\n            for (let layer_name in this.tile_indexes) {\n                dest.source_data.layers[layer_name] = this.getTileFeatures(dest, layer_name);\n            }\n            return dest;\n        });\n    }\n\n    getTileFeatures(tile, layer_name) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n\n        // request a particular tile\n        let t = this.tile_indexes[layer_name].getTile(coords.z, coords.x, coords.y);\n\n        // Convert from MVT-style JSON struct to GeoJSON\n        let collection;\n        if (t && t.features) {\n            collection = {\n                type: 'FeatureCollection',\n                features: []\n            };\n\n            for (let feature of t.features) {\n\n                // Copy geometry (don't want to modify internal geojson-vt data)\n                let geom = feature.geometry.map(ring =>\n                    ring.map(coord => [coord[0], coord[1]])\n                );\n\n                let type;\n                if (feature.type === 1) {\n                    type = 'MultiPoint';\n                }\n                else if (feature.type === 2) {\n                    type = 'MultiLineString';\n                }\n                else if (feature.type === 3) {\n                    type = 'MultiPolygon';\n                    geom = this.decodeMultiPolygon(geom); // un-flatten rings\n                }\n                else {\n                    continue;\n                }\n\n                let f = {\n                    type: 'Feature',\n                    geometry: {\n                        type,\n                        coordinates: geom\n                    },\n                    properties: feature.tags\n                };\n\n                collection.features.push(f);\n            }\n        }\n\n        return collection;\n    }\n\n    // Decode multipolygons, which are encoded as a single set of rings\n    // Outer rings are wound CCW, inner are CW\n    // A CCW ring indicates the start of a new polygon\n    decodeMultiPolygon (geom) {\n        let polys = [];\n        let poly = [];\n        for (let ring of geom) {\n            let winding = Geo.ringWinding(ring);\n            if (winding === 'CCW' && poly.length > 0) {\n                polys.push(poly);\n                poly = [];\n            }\n            poly.push(ring);\n        }\n        if (poly.length > 0) {\n            polys.push(poly);\n        }\n        return polys;\n    }\n\n    formatUrl (dest) {\n        return this.url;\n    }\n\n    parseSourceData (tile, source, response) {\n        source.layers = this.getLayers(JSON.parse(response));\n    }\n\n    // Detect single or multiple layers in returned data\n    getLayers (data) {\n        if (data.type === 'Feature' || data.type === 'FeatureCollection') {\n            return { _default: data };\n        }\n        else {\n            return data;\n        }\n    }\n\n}\n\nDataSource.register(GeoJSONTileSource, 'GeoJSON');      // prefered shorter name\nDataSource.register(GeoJSONTileSource, 'GeoJSONTiles'); // for backwards-compatibility\n","import DataSource, {NetworkTileSource} from './data_source';\n\nimport Pbf from 'pbf';\nimport {VectorTile, VectorTileFeature} from 'vector-tile';\n\n/**\n Mapbox Vector Tile format\n @class MVTSource\n*/\nexport class MVTSource extends NetworkTileSource {\n\n    constructor (source) {\n        super(source);\n        this.response_type = \"arraybuffer\"; // binary data\n    }\n\n    parseSourceData (tile, source, response) {\n        // Convert Mapbox vector tile to GeoJSON\n        var data = new Uint8Array(response);\n        var buffer = new Pbf(data);\n        source.data = new VectorTile(buffer);\n        source.layers = this.toGeoJSON(source.data);\n        delete source.data; // comment out to save raw data for debugging\n    }\n\n    // Loop through layers/features using Mapbox lib API, convert to GeoJSON features\n    // Returns an object with keys for each layer, e.g. { layer: geojson }\n    toGeoJSON (tile) {\n        var layers = {};\n        for (var l in tile.layers) {\n            var layer = tile.layers[l];\n            var layer_geojson = {\n                type: 'FeatureCollection',\n                features: []\n            };\n\n            for (var f=0; f < layer.length; f++) {\n                var feature = layer.feature(f);\n                var feature_geojson = {\n                    type: 'Feature',\n                    geometry: {},\n                    properties: feature.properties\n                };\n\n                var geometry = feature_geojson.geometry;\n                var coordinates = feature.loadGeometry();\n                for (var r=0; r < coordinates.length; r++) {\n                    var ring = coordinates[r];\n                    for (var c=0; c < ring.length; c++) {\n                        ring[c] = [\n                            ring[c].x,\n                            ring[c].y\n                        ];\n                    }\n                }\n                geometry.coordinates = coordinates;\n\n                if (VectorTileFeature.types[feature.type] === 'Point') {\n                    geometry.type = 'Point';\n                    geometry.coordinates = geometry.coordinates[0][0];\n                }\n                else if (VectorTileFeature.types[feature.type] === 'LineString') {\n                    if (coordinates.length === 1) {\n                        geometry.type = 'LineString';\n                        geometry.coordinates = geometry.coordinates[0];\n                    }\n                    else {\n                        geometry.type = 'MultiLineString';\n                    }\n                }\n                else if (VectorTileFeature.types[feature.type] === 'Polygon') {\n                    geometry.type = 'Polygon';\n                }\n\n                layer_geojson.features.push(feature_geojson);\n            }\n            layers[l] = layer_geojson;\n        }\n        return layers;\n    }\n\n}\n\nDataSource.register(MVTSource, 'MVT');\n","import DataSource from './data_source';\nimport {GeoJSONSource, GeoJSONTileSource} from './geojson';\n\nimport topojson from 'topojson';\n\n\n/**\n Mapzen/OSM.US-style TopoJSON vector tiles\n @class TopoJSONTileSource\n*/\nexport class TopoJSONTileSource extends GeoJSONTileSource {\n\n    constructor(source) {\n        let _this = super(source);\n\n        // Replace with non-tiled source if tiled source failed to instantiate\n        if (_this !== this) {\n            return new TopoJSONSource(source);\n        }\n    }\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        data = TopoJSONSource.prototype.toGeoJSON(data);\n        this.prepareGeoJSON(data, tile, source);\n    }\n\n}\n\n\n/**\n TopoJSON standalone (non-tiled) source\n Uses geojson-vt split into tiles client-side\n*/\n\nexport class TopoJSONSource extends GeoJSONSource {\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        data = this.toGeoJSON(data);\n        source.layers = this.getLayers(data);\n    }\n\n    toGeoJSON (data) {\n        // Single layer\n        if (data.objects &&\n            Object.keys(data.objects).length === 1) {\n            let layer = Object.keys(data.objects)[0];\n            data = topojson.feature(data, data.objects[layer]);\n        }\n        // Multiple layers\n        else {\n            let layers = {};\n            for (let key in data.objects) {\n                layers[key] = topojson.feature(data, data.objects[key]);\n            }\n            data = layers;\n        }\n        return data;\n    }\n\n}\n\nDataSource.register(TopoJSONTileSource, 'TopoJSON');        // prefered shorter name\nDataSource.register(TopoJSONTileSource, 'TopoJSONTiles');   // for backwards-compatibility\n\n","// Geometry building functions\n\nimport Vector from '../vector';\nimport Geo from '../geo';\n\nimport earcut from 'earcut';\n\nvar Builders;\nexport default Builders = {};\n\nBuilders.debug = false;\n\nBuilders.tile_bounds = [\n    { x: 0, y: 0},\n    { x: Geo.tile_scale, y: -Geo.tile_scale } // TODO: correct for flipped y-axis?\n];\n\n// Re-scale UVs from [0, 1] range to a smaller area within the image\nBuilders.scaleTexcoordsToSprite = function (uv, area_origin, area_size, tex_size) {\n    var area_origin_y = tex_size[1] - area_origin[1] - area_size[1];\n    var suv = [];\n    suv[0] = (uv[0] * area_size[0] + area_origin[0]) / tex_size[0];\n    suv[1] = (uv[1] * area_size[1] + area_origin_y) / tex_size[1];\n    return suv;\n};\n\nBuilders.getTexcoordsForSprite = function (area_origin, area_size, tex_size) {\n    return [\n        Builders.scaleTexcoordsToSprite([0, 0], area_origin, area_size, tex_size),\n        Builders.scaleTexcoordsToSprite([1, 1], area_origin, area_size, tex_size)\n    ];\n};\n\n// Tesselate a flat 2D polygon\n// x & y coordinates will be set as first two elements of provided vertex_template\nBuilders.buildPolygons = function (\n    polygons,\n    vertex_data, vertex_template,\n    { texcoord_index, texcoord_scale, texcoord_normalize }) {\n\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n    }\n\n    var num_polygons = polygons.length;\n    for (var p=0; p < num_polygons; p++) {\n        var polygon = polygons[p];\n\n        // Find polygon extents to calculate UVs, fit them to the axis-aligned bounding box\n        if (texcoord_index) {\n            var [min_x, min_y, max_x, max_y] = Geo.findBoundingBox(polygon);\n            var span_x = max_x - min_x;\n            var span_y = max_y - min_y;\n            var scale_u = (max_u - min_u) / span_x;\n            var scale_v = (max_v - min_v) / span_y;\n        }\n\n        // Tessellate\n        var vertices = Builders.triangulatePolygon(polygon);\n\n        // Add vertex data\n        var num_vertices = vertices.length;\n        for (var v=0; v < num_vertices; v++) {\n            var vertex = vertices[v];\n            vertex_template[0] = vertex[0];\n            vertex_template[1] = vertex[1];\n\n            // Add UVs\n            if (texcoord_index) {\n                vertex_template[texcoord_index + 0] = ((vertex[0] - min_x) * scale_u + min_u) * texcoord_normalize;\n                vertex_template[texcoord_index + 1] = ((vertex[1] - min_y) * scale_v + min_v) * texcoord_normalize;\n            }\n\n            vertex_data.addVertex(vertex_template);\n        }\n    }\n};\n\n// Tesselate and extrude a flat 2D polygon into a simple 3D model with fixed height and add to GL vertex buffer\nBuilders.buildExtrudedPolygons = function (\n    polygons,\n    z, height, min_height,\n    vertex_data, vertex_template,\n    normal_index,\n    normal_normalize,\n    { texcoord_index, texcoord_scale, texcoord_normalize }) {\n\n    // Top\n    var min_z = z + (min_height || 0);\n    var max_z = z + height;\n    vertex_template[2] = max_z;\n    Builders.buildPolygons(polygons, vertex_data, vertex_template, { texcoord_index, texcoord_scale, texcoord_normalize });\n\n    // Walls\n    // Fit UVs to wall quad\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n        var texcoords = [\n            [min_u, max_v],\n            [min_u, min_v],\n            [max_u, min_v],\n\n            [max_u, min_v],\n            [max_u, max_v],\n            [min_u, max_v]\n        ];\n    }\n\n    var num_polygons = polygons.length;\n    for (var p=0; p < num_polygons; p++) {\n        var polygon = polygons[p];\n\n        for (var q=0; q < polygon.length; q++) {\n            var contour = polygon[q];\n\n            for (var w=0; w < contour.length - 1; w++) {\n                // Two triangles for the quad formed by each vertex pair, going from bottom to top height\n                var wall_vertices = [\n                    // Triangle\n                    [contour[w+1][0], contour[w+1][1], max_z],\n                    [contour[w+1][0], contour[w+1][1], min_z],\n                    [contour[w][0], contour[w][1], min_z],\n                    // Triangle\n                    [contour[w][0], contour[w][1], min_z],\n                    [contour[w][0], contour[w][1], max_z],\n                    [contour[w+1][0], contour[w+1][1], max_z]\n                ];\n\n                // Calc the normal of the wall from up vector and one segment of the wall triangles\n                var normal = Vector.cross(\n                    [0, 0, 1],\n                    Vector.normalize([contour[w+1][0] - contour[w][0], contour[w+1][1] - contour[w][1], 0])\n                );\n\n                // Update vertex template with current surface normal\n                vertex_template[normal_index + 0] = normal[0] * normal_normalize;\n                vertex_template[normal_index + 1] = normal[1] * normal_normalize;\n                vertex_template[normal_index + 2] = normal[2] * normal_normalize;\n\n                for (var wv=0; wv < wall_vertices.length; wv++) {\n                    vertex_template[0] = wall_vertices[wv][0];\n                    vertex_template[1] = wall_vertices[wv][1];\n                    vertex_template[2] = wall_vertices[wv][2];\n\n                    if (texcoord_index) {\n                        vertex_template[texcoord_index + 0] = texcoords[wv][0] * texcoord_normalize;\n                        vertex_template[texcoord_index + 1] = texcoords[wv][1] * texcoord_normalize;\n                    }\n\n                    vertex_data.addVertex(vertex_template);\n                }\n            }\n        }\n    }\n};\n\n// Build tessellated triangles for a polyline\nBuilders.buildPolylines = function (\n    lines,\n    width,\n    vertex_data, vertex_template,\n    {\n        closed_polygon,\n        remove_tile_edges,\n        tile_edge_tolerance,\n        texcoord_index,\n        texcoord_scale,\n        texcoord_normalize,\n        scaling_index,\n        scaling_normalize,\n        join, cap\n    }) {\n\n    var cornersOnCap = (cap === \"square\") ? 2 : ((cap === \"round\") ? 3 : 0);  // Butt is the implicit default\n    var trianglesOnJoin = (join === \"bevel\") ? 1 : ((join === \"round\") ? 3 : 0);  // Miter is the implicit default\n\n    // Build variables\n    texcoord_normalize = texcoord_normalize || 1;\n    var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n\n    // Values that are constant for each line and are passed to helper functions\n    var constants = {\n        vertex_data,\n        vertex_template,\n        halfWidth: width/2,\n        vertices: [],\n        scaling_index,\n        scaling_normalize,\n        scalingVecs: scaling_index && [],\n        texcoord_index,\n        texcoords: texcoord_index && [],\n        texcoord_normalize,\n        min_u, min_v, max_u, max_v,\n        nPairs: 0\n    };\n\n    for (var ln = 0; ln < lines.length; ln++) {\n        var line = lines[ln];\n        var lineSize = line.length;\n\n        // Ignore non-lines\n        if (lineSize < 2) {\n            continue;\n        }\n\n        //  Initialize variables\n        var coordPrev = [0, 0], // Previous point coordinates\n            coordCurr = [0, 0], // Current point coordinates\n            coordNext = [0, 0]; // Next point coordinates\n\n        var normPrev = [0, 0],  // Right normal to segment between previous and current m_points\n            normCurr = [0, 0],  // Right normal at current point, scaled for miter joint\n            normNext = [0, 0];  // Right normal to segment between current and next m_points\n\n        var isPrev = false,\n            isNext = true;\n\n        // Add vertices to buffer according to their index\n        indexPairs(constants);\n\n        // Do this with the rest (except the last one)\n        for (let i = 0; i < lineSize ; i++) {\n\n            // There is a next one?\n            isNext = i+1 < lineSize;\n\n            if (isPrev) {\n                // If there is a previous one, copy the current (previous) values on *Prev\n                coordPrev = coordCurr;\n                normPrev = Vector.normalize(Vector.perp(coordPrev, line[i]));\n            } else if (i === 0 && closed_polygon === true) {\n                // If it's the first point and is a closed polygon\n\n                var needToClose = true;\n                if (remove_tile_edges) {\n                    if(Builders.isOnTileEdge(line[i], line[lineSize-2], { tolerance: tile_edge_tolerance })) {\n                        needToClose = false;\n                    }\n                }\n\n                if (needToClose) {\n                    coordPrev = line[lineSize-2];\n                    normPrev = Vector.normalize(Vector.perp(coordPrev, line[i]));\n                    isPrev = true;\n                }\n            }\n\n            // Assign current coordinate\n            coordCurr = line[i];\n\n            if (isNext) {\n                coordNext = line[i+1];\n            } else if (closed_polygon === true) {\n                // If it's the last point in a closed polygon\n                coordNext = line[1];\n                isNext = true;\n            }\n\n            if (isNext) {\n                // If it's not the last one get next coordinates and calculate the right normal\n\n                normNext = Vector.normalize(Vector.perp(coordCurr, coordNext));\n                if (remove_tile_edges) {\n                    if (Builders.isOnTileEdge(coordCurr, coordNext, { tolerance: tile_edge_tolerance })) {\n                        normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                        if (isPrev) {\n                            addVertexPair(coordCurr, normCurr, i/lineSize, constants);\n                            constants.nPairs++;\n\n                            // Add vertices to buffer acording their index\n                            indexPairs(constants);\n                        }\n                        isPrev = false;\n                        continue;\n                    }\n                }\n            }\n\n            //  Compute current normal\n            if (isPrev) {\n                //  If there is a PREVIOUS ...\n                if (isNext) {\n                    // ... and a NEXT ONE, compute previous and next normals (scaled by the angle with the last prev)\n                    normCurr = Vector.normalize(Vector.add(normPrev, normNext));\n                    var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n                    normCurr = Vector.mult(normCurr,scale*scale);\n                } else {\n                    // ... and there is NOT a NEXT ONE, copy the previous next one (which is the current one)\n                    normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                }\n            } else {\n                // If there is NO PREVIOUS ...\n                if (isNext) {\n                    // ... and a NEXT ONE,\n                    normNext = Vector.normalize(Vector.perp(coordCurr, coordNext));\n                    normCurr = normNext;\n                } else {\n                    // ... and NO NEXT ONE, nothing to do (without prev or next one this is just a point)\n                    continue;\n                }\n            }\n\n            if (isPrev || isNext) {\n                // If it's the BEGINNING of a LINE\n                if (i === 0 && !isPrev && !closed_polygon) {\n                    addCap(coordCurr, normCurr, cornersOnCap, true, constants);\n                }\n\n                // If it's a JOIN\n                if(trianglesOnJoin !== 0 && isPrev && isNext) {\n                    addJoin([coordPrev, coordCurr, coordNext],\n                            [normPrev,normCurr, normNext],\n                            i/lineSize, trianglesOnJoin,\n                            constants);\n                } else {\n                    addVertexPair(coordCurr, normCurr, i/(lineSize-1), constants);\n                }\n\n                if (isNext) {\n                   constants.nPairs++;\n                }\n\n                isPrev = true;\n            }\n        }\n\n        // Add vertices to buffer according to their index\n        indexPairs(constants);\n\n         // If it's the END of a LINE\n        if(!closed_polygon) {\n            addCap(coordCurr, normCurr, cornersOnCap , false, constants);\n        }\n    }\n};\n\n// Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertex(coord, normal, uv, { halfWidth, vertices, scalingVecs, texcoords }) {\n    if (scalingVecs) {\n        //  a. If scaling is on add the vertex (the currCoord) and the scaling Vecs (normals pointing where to extrude the vertices)\n        vertices.push(coord);\n        scalingVecs.push(normal);\n    } else {\n        //  b. Add the extruded vertices\n        vertices.push([coord[0] + normal[0] * halfWidth,\n                       coord[1] + normal[1] * halfWidth]);\n    }\n\n    // c) Add UVs if they are enabled\n    if (texcoords) {\n        texcoords.push(uv);\n    }\n}\n\n//  Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertexPair (coord, normal, v_pct, constants) {\n    addVertex(coord, normal, [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v], constants);\n    addVertex(coord, Vector.neg(normal), [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v], constants);\n}\n\n//  Tessalate a FAN geometry between points A       B\n//  using their normals from a center        \\ . . /\n//  and interpolating their UVs               \\ p /\n//                                             \\./\n//                                              C\nfunction addFan (coord, nA, nC, nB, uA, uC, uB, signed, numTriangles, constants) {\n\n    if (numTriangles < 1) {\n        return;\n    }\n\n    // Add previous vertices to buffer and clear the buffers and index pairs\n    // because we are going to add more triangles.\n    indexPairs(constants);\n\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n\n    var angle_delta = Vector.dot(nA, nB);\n    if (angle_delta < -1) {\n        angle_delta = -1;\n    }\n    angle_delta = Math.acos(angle_delta)/numTriangles;\n\n    if (!signed) {\n        angle_delta *= -1;\n    }\n\n    var uvCurr = Vector.set(uA);\n    var uv_delta = Vector.div(Vector.sub(uB,uA), numTriangles);\n\n    //  Add the FIRST and CENTER vertex\n    //  The triangles will be composed in a FAN style around it\n    addVertex(coord, nC, uC, constants);\n\n    //  Add first corner\n    addVertex(coord, normCurr, uA, constants);\n\n    // Iterate through the rest of the corners\n    for (var t = 0; t < numTriangles; t++) {\n        normPrev = Vector.normalize(normCurr);\n        normCurr = Vector.rot( Vector.normalize(normCurr), angle_delta);     //  Rotate the extrusion normal\n\n        if (numTriangles === 4 && (t === 0 || t === numTriangles - 2)) {\n            var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n            normCurr = Vector.mult(normCurr, scale*scale);\n        }\n\n        uvCurr = Vector.add(uvCurr,uv_delta);\n\n        addVertex(coord, normCurr, uvCurr, constants);      //  Add computed corner\n    }\n\n    for (var i = 0; i < numTriangles; i++) {\n        if (signed) {\n            addIndex(i+2, constants);\n            addIndex(0, constants);\n            addIndex(i+1, constants);\n        } else {\n            addIndex(i+1, constants);\n            addIndex(0, constants);\n            addIndex(i+2, constants);\n        }\n    }\n\n    // Clear the buffer\n    constants.vertices = [];\n    if (constants.scalingVecs) {\n        constants.scalingVecs = [];\n    }\n    if (constants.texcoords) {\n        constants.texcoords = [];\n    }\n}\n\n//  Add special joins (not miter) types that require FAN tessellations\n//  Using http://www.codeproject.com/Articles/226569/Drawing-polylines-by-tessellation as reference\nfunction addJoin (coords, normals, v_pct, nTriangles, constants) {\n\n    var T = [Vector.set(normals[0]), Vector.set(normals[1]), Vector.set(normals[2])];\n    var signed = Vector.signed_area(coords[0], coords[1], coords[2]) > 0;\n\n    var nA = T[0],              // normal to point A (aT)\n        nC = Vector.neg(T[1]),  // normal to center (-vP)\n        nB = T[2];              // normal to point B (bT)\n\n    var uA = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v],\n        uC = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v],\n        uB = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n\n    if (signed) {\n        addVertex(coords[1], nA, uA, constants);\n        addVertex(coords[1], nC, uC, constants);\n    } else {\n        nA = Vector.neg(T[0]);\n        nC = T[1];\n        nB = Vector.neg(T[2]);\n        uA = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        uC = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        uB = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        addVertex(coords[1], nC, uC, constants);\n        addVertex(coords[1], nA, uA, constants);\n    }\n\n    addFan(coords[1], nA, nC, nB, uA, uC, uB, signed, nTriangles, constants);\n\n    if (signed) {\n        addVertex(coords[1], nB, uB, constants);\n        addVertex(coords[1], nC, uC, constants);\n    } else {\n        addVertex(coords[1], nC, uC, constants);\n        addVertex(coords[1], nB, uB, constants);\n    }\n}\n\n//  Function to add the vertex need for line caps,\n//  because re-use the buffers needs to be at the end\nfunction addCap (coord, normal, numCorners, isBeginning, constants) {\n\n    if (numCorners < 1) {\n        return;\n    }\n\n    // UVs\n    var uvA = [constants.min_u,constants.min_v],                        // Beginning angle UVs\n        uvC = [constants.min_u+(constants.max_u-constants.min_u)/2, constants.min_v],   // center point UVs\n        uvB = [constants.max_u,constants.min_v];                        // Ending angle UVs\n\n    if (!isBeginning) {\n        uvA = [constants.min_u,constants.max_v],                        // Begining angle UVs\n        uvC = [constants.min_u+(constants.max_u-constants.min_u)/2, constants.max_v],   // center point UVs\n        uvB = [constants.max_u,constants.max_v];\n    }\n\n    addFan( coord,\n            Vector.neg(normal), [0, 0], normal,\n            uvA, uvC, uvB,\n            isBeginning, numCorners*2, constants);\n}\n\n// Add a vertex based on the index position into the VBO (internal method for polyline builder)\nfunction addIndex (index, { vertex_data, vertex_template, halfWidth, vertices, scaling_index, scaling_normalize, scalingVecs, texcoord_index, texcoords, texcoord_normalize }) {\n    // Prevent access to undefined vertices\n    if (index >= vertices.length) {\n        return;\n    }\n\n    // set vertex position\n    vertex_template[0] = vertices[index][0];\n    vertex_template[1] = vertices[index][1];\n\n    // set UVs\n    if (texcoord_index) {\n        vertex_template[texcoord_index + 0] = texcoords[index][0] * texcoord_normalize;\n        vertex_template[texcoord_index + 1] = texcoords[index][1] * texcoord_normalize;\n    }\n\n    // set Scaling vertex (X, Y normal direction + Z halfwidth as attribute)\n    if (scaling_index) {\n        vertex_template[scaling_index + 0] = scalingVecs[index][0] * scaling_normalize;\n        vertex_template[scaling_index + 1] = scalingVecs[index][1] * scaling_normalize;\n        vertex_template[scaling_index + 2] = halfWidth;\n    }\n\n    //  Add vertex to VBO\n    vertex_data.addVertex(vertex_template);\n}\n\n// Add the index vertex to the VBO and clean the buffers\nfunction indexPairs (constants) {\n    // Add vertices to buffer acording their index\n    for (var i = 0; i < constants.nPairs; i++) {\n        addIndex(2*i+2, constants);\n        addIndex(2*i+1, constants);\n        addIndex(2*i+0, constants);\n\n        addIndex(2*i+2, constants);\n        addIndex(2*i+3, constants);\n        addIndex(2*i+1, constants);\n    }\n\n    constants.nPairs = 0;\n\n    // Clean the buffer\n    constants.vertices = [];\n    if (constants.scalingVecs) {\n        constants.scalingVecs = [];\n    }\n    if (constants.texcoords) {\n        constants.texcoords = [];\n    }\n}\n\n// Build a billboard sprite quad centered on a point. Sprites are intended to be drawn in screenspace, and have\n// properties for width, height, angle, and a scale factor that can be used to interpolate the screenspace size\n// of a sprite between two zoom levels.\nBuilders.buildQuadsForPoints = function (points, vertex_data, vertex_template,\n    { texcoord_index, position_index, shape_index, offset_index },\n    { quad, quad_scale, offset, angle, texcoord_scale, texcoord_normalize }) {\n    let w2 = quad[0] / 2;\n    let h2 = quad[1] / 2;\n    let scaling = [\n        [-w2, -h2],\n        [w2, -h2],\n        [w2, h2],\n\n        [-w2, -h2],\n        [w2, h2],\n        [-w2, h2]\n    ];\n\n    let texcoords;\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n\n        let [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n        texcoords = [\n            [min_u, min_v],\n            [max_u, min_v],\n            [max_u, max_v],\n\n            [min_u, min_v],\n            [max_u, max_v],\n            [min_u, max_v]\n        ];\n    }\n\n    let num_points = points.length;\n    for (let p=0; p < num_points; p++) {\n        let point = points[p];\n\n        for (let pos=0; pos < 6; pos++) {\n            // Add texcoords\n            if (texcoord_index) {\n                vertex_template[texcoord_index + 0] = texcoords[pos][0] * texcoord_normalize;\n                vertex_template[texcoord_index + 1] = texcoords[pos][1] * texcoord_normalize;\n            }\n\n            vertex_template[position_index + 0] = point[0];\n            vertex_template[position_index + 1] = point[1];\n\n            vertex_template[shape_index + 0] = scaling[pos][0];\n            vertex_template[shape_index + 1] = scaling[pos][1];\n            vertex_template[shape_index + 2] = angle;\n            vertex_template[shape_index + 3] = quad_scale;\n\n            vertex_template[offset_index + 0] = offset[0];\n            vertex_template[offset_index + 1] = offset[1];\n\n            vertex_data.addVertex(vertex_template);\n        }\n    }\n};\n\n\n/* Utility functions */\n\n// Triangulation using earcut\n// https://github.com/mapbox/earcut\nBuilders.triangulatePolygon = function (contours)\n{\n    return earcut(contours);\n};\n\n// Tests if a line segment (from point A to B) is nearly coincident with the edge of a tile\nBuilders.isOnTileEdge = function (pa, pb, options) {\n    options = options || {};\n\n    var tolerance_function = options.tolerance_function || Builders.valuesWithinTolerance;\n    var tolerance = options.tolerance || 1;\n    var tile_min = Builders.tile_bounds[0];\n    var tile_max = Builders.tile_bounds[1];\n    var edge = null;\n\n    if (tolerance_function(pa[0], tile_min.x, tolerance) && tolerance_function(pb[0], tile_min.x, tolerance)) {\n        edge = 'left';\n    }\n    else if (tolerance_function(pa[0], tile_max.x, tolerance) && tolerance_function(pb[0], tile_max.x, tolerance)) {\n        edge = 'right';\n    }\n    else if (tolerance_function(pa[1], tile_min.y, tolerance) && tolerance_function(pb[1], tile_min.y, tolerance)) {\n        edge = 'top';\n    }\n    else if (tolerance_function(pa[1], tile_max.y, tolerance) && tolerance_function(pb[1], tile_max.y, tolerance)) {\n        edge = 'bottom';\n    }\n    return edge;\n};\n\nBuilders.valuesWithinTolerance = function (a, b, tolerance) {\n    tolerance = tolerance || 1;\n    return (Math.abs(a - b) < tolerance);\n};\n","// Line rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport {StyleManager} from '../style_manager';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\n\nexport var Lines = Object.create(Style);\n\nObject.assign(Lines, {\n    name: 'lines',\n    built_in: true,\n    vertex_shader_key: 'styles/polygons/polygons_vertex', // re-use polygon shaders\n    fragment_shader_key: 'styles/polygons/polygons_fragment',\n    selection: true, // turn feature selection on\n\n    init() {\n        Style.init.apply(this, arguments);\n\n        // Basic attributes, others can be added (see texture UVs below)\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_extrude', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Tell the shader we want a order in vertex attributes, and to extrude lines\n        this.defines.TANGRAM_LAYER_ORDER = true;\n        this.defines.TANGRAM_EXTRUDE_LINES = true;\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // Optional texture UVs\n        if (this.texcoords) {\n            this.defines.TANGRAM_TEXTURE_COORDS = true;\n\n            // Add vertex attribute for UVs only when needed\n            attribs.push({ name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true });\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        let inner_width = rule_style.width && StyleParser.cacheDistance(rule_style.width, context);\n        if (!inner_width) {\n            return;\n        }\n        style.width = inner_width * context.units_per_meter;\n\n        // Smoothly interpolate line width between zooms: get scale factor to next zoom\n        // Adjust by factor of 2 because tile units are zoom-dependent (a given value is twice as\n        // big in world space at the next zoom than at the previous)\n        context.zoom ++;\n        context.units_per_meter *= 2;\n        let next_width = StyleParser.cacheDistance(rule_style.next_width, context);\n        style.next_width = Utils.scaleInt16(next_width * context.units_per_meter / style.width, 256);\n        context.zoom--;\n        context.units_per_meter /= 2; // reset to original scale\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return null;\n        }\n\n        // height defaults to feature height, but extrude style can dynamically adjust height by returning a number or array (instead of a boolean)\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z || 0, context)) || StyleParser.defaults.z;\n        style.height = feature.properties.height || StyleParser.defaults.height;\n        style.extrude = rule_style.extrude;\n        if (style.extrude) {\n            if (typeof style.extrude === 'function') {\n                style.extrude = style.extrude(context);\n            }\n\n            if (typeof style.extrude === 'number') {\n                style.height = style.extrude;\n            }\n            else if (Array.isArray(style.extrude)) {\n                style.height = style.extrude[1];\n            }\n        }\n\n        // Raise line height if extruded\n        if (style.extrude && style.height) {\n            style.z += style.height;\n        }\n\n        style.cap = rule_style.cap;\n        style.join = rule_style.join;\n        style.tile_edges = rule_style.tile_edges;\n\n        // Construct an outline style\n        style.outline = style.outline || {};\n        if (rule_style.outline && rule_style.outline.color && rule_style.outline.width) {\n            let outline_width = StyleParser.cacheDistance(rule_style.outline.width, context) * 2;\n\n            context.zoom ++;\n            context.units_per_meter *= 2;\n            let outline_next_width = StyleParser.cacheDistance(rule_style.outline.next_width, context) * 2;\n            context.zoom--;\n            context.units_per_meter /= 2; // reset to original scale\n\n            // Maintain consistent outline width around the inner line\n            style.outline.width = { value: outline_width + inner_width };\n            style.outline.next_width = { value: outline_next_width + next_width };\n\n            style.outline.color = rule_style.outline.color;\n            style.outline.cap = rule_style.outline.cap || rule_style.cap;\n            style.outline.join = rule_style.outline.join || rule_style.join;\n            style.outline.style = rule_style.outline.style || this.name;\n\n            // Explicitly defined outline order, or inherited from inner line\n            if (rule_style.outline.order) {\n                style.outline.order = this.parseOrder(rule_style.outline.order, context);\n            }\n            else {\n                style.outline.order = style.order;\n            }\n\n            // Don't let outline be above inner line\n            if (style.outline.order > style.order) {\n                style.outline.order = style.order;\n            }\n\n            // Outlines are always at half-layer intervals to avoid conflicting with inner lines\n            style.outline.order -= 0.5;\n\n            style.outline.preprocessed = true; // signal that we've already wrapped properties in cache objects\n        }\n        else {\n            style.outline.color = null;\n            style.outline.width = null;\n        }\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.width = draw.width && { value: draw.width };\n        draw.next_width = draw.width && { value: draw.width.value };\n        draw.z = draw.z && { value: draw.z };\n\n        if (draw.outline) {\n            draw.outline.color = draw.outline.color && { value: draw.outline.color };\n            draw.outline.width = draw.outline.width && { value: draw.outline.width };\n            draw.outline.next_width = draw.outline.width && { value: draw.outline.width.value };\n        }\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let i = 0;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = style.z || 0;\n\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.vertex_template[i++] = style.order;\n\n        // extrusion vector\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n\n        // scaling to previous and next zoom\n        this.vertex_template[i++] = style.next_width;\n\n        // color\n        this.vertex_template[i++] = style.color[0] * 255;\n        this.vertex_template[i++] = style.color[1] * 255;\n        this.vertex_template[i++] = style.color[2] * 255;\n        this.vertex_template[i++] = style.color[3] * 255;\n\n        // selection color\n        if (this.selection) {\n            this.vertex_template[i++] = style.selection_color[0] * 255;\n            this.vertex_template[i++] = style.selection_color[1] * 255;\n            this.vertex_template[i++] = style.selection_color[2] * 255;\n            this.vertex_template[i++] = style.selection_color[3] * 255;\n        }\n\n        // Add texture UVs to template only if needed\n        if (this.texcoords) {\n            this.vertex_template[i++] = 0;\n            this.vertex_template[i++] = 0;\n        }\n\n        return this.vertex_template;\n    },\n\n    buildLines(lines, style, vertex_data, context, options) {\n        var vertex_template = this.makeVertexTemplate(style);\n\n        // Main line\n        if (style.color && style.width) {\n            Builders.buildPolylines(\n                lines,\n                style.width,\n                vertex_data,\n                vertex_template,\n                {\n                    cap: style.cap,\n                    join: style.join,\n                    scaling_index: this.vertex_layout.index.a_extrude,\n                    scaling_normalize: Utils.scaleInt16(1, 256), // scale extrusion normals to signed shorts w/256 unit basis\n                    texcoord_index: this.vertex_layout.index.a_texcoord,\n                    texcoord_scale: this.texcoord_scale,\n                    texcoord_normalize: 65535, // scale UVs to unsigned shorts\n                    closed_polygon: options && options.closed_polygon,\n                    remove_tile_edges: !style.tile_edges && options && options.remove_tile_edges,\n                    tile_edge_tolerance: Geo.tile_scale * context.tile.pad_scale * 4\n                }\n            );\n        }\n\n        // Outline\n         if (style.outline && style.outline.color && style.outline.width) {\n            var outline_style = StyleManager.styles[style.outline.style];\n            if (outline_style) {\n                outline_style.addFeature(context.feature, style.outline, context);\n            }\n        }\n    },\n\n    buildPolygons(polygons, style, vertex_data, context) {\n        // Render polygons as individual lines\n        for (let p=0; p < polygons.length; p++) {\n            this.buildLines(polygons[p], style, vertex_data, context, { closed_polygon: true, remove_tile_edges: true });\n        }\n    }\n\n});\n","// Point rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\nimport Texture from '../../gl/texture';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\nimport Vector from '../../vector';\n\nimport log from 'loglevel';\n\nexport var Points = Object.create(Style);\n\nObject.assign(Points, {\n    name: 'points',\n    built_in: true,\n    selection: true, // turn feature selection on\n    blend: 'overlay', // overlays drawn on top of all other styles, with blending\n\n    init(options = {}) {\n        Style.init.apply(this, arguments);\n\n        // Base shaders\n        this.vertex_shader_key = 'styles/points/points_vertex';\n        this.fragment_shader_key = 'styles/points/points_fragment';\n\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_shape', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true },\n            { name: 'a_offset', size: 2, type: gl.SHORT, normalized: true },\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // If we're not rendering as overlay, we need a layer attribute\n        if (this.blend !== 'overlay') {\n            this.defines.TANGRAM_LAYER_ORDER = true;\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n\n        if (this.texture) {\n            this.defines.TANGRAM_POINT_TEXTURE = true;\n            this.shaders.uniforms = this.shaders.uniforms || {};\n            this.shaders.uniforms.u_texture = this.texture;\n        }\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n        let tile = context.tile.key;\n\n        style.color = this.parseColor(rule_style.color, context);\n\n        // require color or texture\n        if (!style.color && !this.texture) {\n            return null;\n        }\n\n        let sprite = style.sprite = rule_style.sprite;\n        if (typeof sprite === 'function') {\n            sprite = sprite(context);\n        }\n        style.sprite_default = rule_style.sprite_default; // optional fallback if 'sprite' not found\n\n        // if point has texture and sprites, require a valid sprite to draw\n        if (this.texture && Texture.textures[this.texture] && Texture.textures[this.texture].sprites) {\n            if (!sprite && !style.sprite_default) {\n                return;\n            }\n            else if (!Texture.textures[this.texture].sprites[sprite]) {\n                // If sprite not found, check for default sprite\n                if (style.sprite_default) {\n                    sprite = style.sprite_default;\n                    if (!Texture.textures[this.texture].sprites[sprite]) {\n                        log.warn(`Style: in style '${this.name}', could not find default sprite '${sprite}' for texture '${this.texture}'`);\n                        return;\n                    }\n                }\n                else {\n                    log.warn(`Style: in style '${this.name}', could not find sprite '${sprite}' for texture '${this.texture}'`);\n                    return;\n                }\n            }\n        }\n\n        // points can be placed off the ground\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n\n        // point style only supports sizes in pixel units, so unit conversion flag is off\n        style.size = rule_style.size || { value: [32, 32] };\n        style.size = StyleParser.cacheDistance(style.size, context, 'pixels');\n\n        // scale size to 16-bit signed int, with a max allowed width + height of 128 pixels\n        style.size = [\n            Math.min((style.size[0] || style.size), 256),\n            Math.min((style.size[1] || style.size), 256)\n        ];\n\n        style.size[0] *= Utils.device_pixel_ratio;\n        style.size[1] *= Utils.device_pixel_ratio;\n\n        style.angle = rule_style.angle || 0;\n        if (typeof style.angle === 'function') {\n            style.angle = style.angle(context);\n        }\n\n        // factor by which point scales from current zoom level to next zoom level\n        style.scale = rule_style.scale || 1;\n\n        // to store bbox by tiles\n        style.tile = tile;\n\n        // polygons rendering as points will render each individual polygon point by default, but\n        // rendering a single point at the polygon's centroid can be enabled\n        style.centroid = rule_style.centroid;\n\n        // Sets texcoord scale if needed (e.g. for sprite sub-area)\n        if (this.texture && sprite) {\n            this.texcoord_scale = Texture.getSpriteTexcoords(this.texture, sprite);\n        } else {\n            this.texcoord_scale = null;\n        }\n\n        // Offset applied to point in screen space\n        style.offset = rule_style.offset || [0, 0];\n        style.offset[0] = parseInt(style.offset[0]);\n        style.offset[1] = parseInt(style.offset[1]);\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.z = draw.z && { value: draw.z };\n        draw.size = draw.size && { value: draw.size };\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let color = style.color || StyleParser.defaults.color;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.fillVertexTemplate('a_position', 0, { size: 2 });\n        this.fillVertexTemplate('a_position', style.z || 0, { size: 1, offset: 2 });\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.fillVertexTemplate('a_position', style.order || 0, { size: 1, offset: 3 });\n\n        // scaling vector - (x, y) components per pixel, z = angle, w = scaling factor\n        this.fillVertexTemplate('a_shape', 0, { size: 4 });\n\n        // texture coords\n        this.fillVertexTemplate('a_texcoord', 0, { size: 2 });\n\n        // offsets\n        this.fillVertexTemplate('a_offset', 0, { size: 2 });\n\n        // color\n        this.fillVertexTemplate('a_color', Vector.mult(color, 255), { size: 4 });\n\n        // selection color\n        if (this.selection) {\n            this.fillVertexTemplate('a_selection_color', Vector.mult(style.selection_color, 255), { size: 4 });\n        }\n\n        return this.vertex_template;\n    },\n\n    buildQuad (points, size, angle, vertex_data, vertex_template, offset) {\n        Builders.buildQuadsForPoints(\n            points,\n            vertex_data,\n            vertex_template,\n            {\n                texcoord_index: this.vertex_layout.index.a_texcoord,\n                position_index: this.vertex_layout.index.a_position,\n                shape_index: this.vertex_layout.index.a_shape,\n                offset_index: this.vertex_layout.index.a_offset\n            },\n            {\n                quad: [ Utils.scaleInt16(size[0], 256), Utils.scaleInt16(size[1], 256) ],\n                quad_scale: Utils.scaleInt16(1, 256),\n                offset: Vector.mult(offset, Utils.device_pixel_ratio),\n                angle: Utils.scaleInt16(angle, 360),\n                texcoord_scale: this.texcoord_scale,\n                texcoord_normalize: 65535\n            }\n        );\n    },\n\n    buildPoints (points, style, vertex_data) {\n        if (!style.size) {\n            return;\n        }\n\n        this.buildQuad(points, style.size, style.angle, vertex_data, this.makeVertexTemplate(style), style.offset);\n    },\n\n    buildPolygons(polygons, style, vertex_data) {\n        // Render polygons as individual points, or centroid\n        if (!style.centroid) {\n            for (let poly=0; poly < polygons.length; poly++) {\n                let polygon = polygons[poly];\n                for (let r=0; r < polygon.length; r++) {\n                    this.buildPoints(polygon[r], style, vertex_data);\n                }\n            }\n        }\n        else {\n            let centroid = Geo.multiCentroid(polygons);\n            this.buildPoints([centroid], style, vertex_data);\n        }\n    },\n\n    buildLines(lines, style, vertex_data) {\n        // Render lines as individual points\n        for (let ln=0; ln < lines.length; ln++) {\n            this.buildPoints(lines[ln], style, vertex_data);\n        }\n    }\n\n});\n","// Polygon rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\n\nexport var Polygons = Object.create(Style);\n\nObject.assign(Polygons, {\n    name: 'polygons',\n    built_in: true,\n    vertex_shader_key: 'styles/polygons/polygons_vertex',\n    fragment_shader_key: 'styles/polygons/polygons_fragment',\n    selection: true, // turn feature selection on\n\n    init() {\n        Style.init.apply(this, arguments);\n\n        // Basic attributes, others can be added (see texture UVs below)\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_normal', size: 3, type: gl.BYTE, normalized: true }, // gets padded to 4-bytes\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Tell the shader we have a normal and order attributes\n        this.defines.TANGRAM_NORMAL_ATTRIBUTE = true;\n        this.defines.TANGRAM_LAYER_ORDER = true;\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // Optional texture UVs\n        if (this.texcoords) {\n            this.defines.TANGRAM_TEXTURE_COORDS = true;\n\n            // Add vertex attribute for UVs only when needed\n            attribs.push({ name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true });\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return null;\n        }\n\n        // height defaults to feature height, but extrude style can dynamically adjust height by returning a number or array (instead of a boolean)\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n        style.height = feature.properties.height || StyleParser.defaults.height;\n        style.min_height = feature.properties.min_height || StyleParser.defaults.min_height;\n        style.extrude = rule_style.extrude;\n        if (style.extrude) {\n            if (typeof style.extrude === 'function') {\n                style.extrude = style.extrude(context);\n            }\n\n            if (typeof style.extrude === 'number') {\n                style.height = style.extrude;\n            }\n            else if (Array.isArray(style.extrude)) {\n                style.min_height = style.extrude[0];\n                style.height = style.extrude[1];\n            }\n        }\n\n        // style.outline = style.outline || {};\n        // if (rule_style.outline) {\n        //     style.outline.color = StyleParser.parseColor(rule_style.outline.color, context);\n        //     style.outline.width = StyleParser.parseDistance(rule_style.outline.width, context);\n        //     style.outline.tile_edges = rule_style.outline.tile_edges;\n        //     style.outline.cap = rule_style.outline.cap || rule_style.cap;\n        //     style.outline.join = rule_style.outline.join || rule_style.join;\n        // }\n        // else {\n        //     style.outline.color = null;\n        //     style.outline.width = null;\n        //     style.outline.tile_edges = false;\n        // }\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.z = draw.z && { value: draw.z };\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let i = 0;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = style.z || 0;\n\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.vertex_template[i++] = style.order;\n\n        // normal\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 1 * 127;\n\n        // color\n        this.vertex_template[i++] = style.color[0] * 255;\n        this.vertex_template[i++] = style.color[1] * 255;\n        this.vertex_template[i++] = style.color[2] * 255;\n        this.vertex_template[i++] = style.color[3] * 255;\n\n        // selection color\n        if (this.selection) {\n            this.vertex_template[i++] = style.selection_color[0] * 255;\n            this.vertex_template[i++] = style.selection_color[1] * 255;\n            this.vertex_template[i++] = style.selection_color[2] * 255;\n            this.vertex_template[i++] = style.selection_color[3] * 255;\n        }\n\n        // Add texture UVs to template only if needed\n        if (this.texcoords) {\n            this.vertex_template[i++] = 0;\n            this.vertex_template[i++] = 0;\n        }\n\n        return this.vertex_template;\n    },\n\n    buildPolygons(polygons, style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let texcoords = {\n            texcoord_index: this.vertex_layout.index.a_texcoord,\n            texcoord_scale: this.texcoord_scale,\n            texcoord_normalize: 65535 // scale UVs to unsigned shorts\n        };\n\n        // Extruded polygons (e.g. 3D buildings)\n        if (style.extrude && style.height) {\n            Builders.buildExtrudedPolygons(\n                polygons,\n                style.z, style.height, style.min_height,\n                vertex_data, vertex_template,\n                this.vertex_layout.index.a_normal,\n                127, // scale normals to signed bytes\n                texcoords\n            );\n        }\n        // Regular polygons\n        else {\n            Builders.buildPolygons(\n                polygons,\n                vertex_data, vertex_template,\n                texcoords\n            );\n        }\n    }\n\n});\n","import {match} from 'match-feature';\nimport log from 'loglevel';\n\nexport const whiteList = ['filter', 'draw', 'visible', 'data', 'properties'];\n\nexport let ruleCache = {};\n\nfunction cacheKey (rules) {\n    var k = rules[0].id;\n    for (var i=1; i < rules.length; i++) {\n        k += '/' + rules[i].id;\n    }\n    return k;\n}\n\nexport function mergeTrees(matchingTrees, key, context) {\n    var draw = {},\n        draws,\n        // order = [],\n        // order_draws = [],\n        treeDepth = 0,\n        x, t;\n\n    // Visible by default\n    draw.visible = true;\n\n    // Find deepest tree\n    for (t = 0; t < matchingTrees.length; t++) {\n        if (matchingTrees[t].length > treeDepth) {\n            treeDepth = matchingTrees[t].length;\n        }\n    }\n\n    // No rules to parse\n    if (treeDepth === 0) {\n        return null;\n    }\n\n    // Iterate trees in parallel\n    for (x = 0; x < treeDepth; x++) {\n        draws = matchingTrees.map(tree => tree[x] && tree[x][key]);\n        if (draws.length === 0) {\n            continue;\n        }\n\n        // Property-specific logic\n        // for (i=0; i < draws.length; i++) {\n        //     if (!draws[i]) {\n        //         continue;\n        //     }\n\n        //     // Collect unique orders (don't add the order multiple times for the smae draw rule)\n        //     if (draws[i].order !== undefined) {\n        //         if (order_draws.indexOf(draws[i]) === -1) {\n        //             order.push(draws[i].order);\n        //             order_draws.push(draws[i]);\n        //         }\n        //     }\n        // }\n\n        // Merge remaining draw objects\n        mergeObjects(draw, ...draws);\n    }\n\n    // Short-circuit if not visible\n    if (draw.visible === false) {\n        return null;\n    }\n\n    // Sum all orders\n    // Note: temporarily commenting out, will revisit with new scene file syntax\n    // if (order.length > 0) {\n    //     // Order can be cached if it is all numeric\n    //     if (order.length === 1 && typeof order[0] === 'number') {\n    //         order = order[0];\n    //     }\n    //     else if (order.every(v => typeof v === 'number')) {\n    //         order = calculateOrder(order, context); // TODO: use StyleParser.calculateOrder\n    //     }\n    //     draw.order = order;\n    // }\n\n    return draw;\n}\n\n\nclass Rule {\n\n    constructor({name, parent, draw, visible, filter, properties}) {\n        this.id = Rule.id++;\n        this.parent = parent;\n        this.name = name;\n        this.draw = draw;\n        this.filter = filter;\n        this.visible = visible !== undefined ? visible : (this.parent && this.parent.visible);\n        this.properties = properties !== undefined ? properties : (this.parent && this.parent.properties);\n\n        // Denormalize properties to draw groups\n        if (this.draw) {\n            for (let group in this.draw) {\n                if (this.properties !== undefined) {\n                    this.draw[group].properties = this.properties;\n                }\n            }\n        }\n\n        this.buildFilter();\n        this.buildDraw();\n    }\n\n    buildDraw() {\n        this.calculatedDraw = calculateDraw(this);\n    }\n\n    buildFilter() {\n        var type = typeof this.filter;\n        if (type === 'object') {\n            this.filter = match(this.filter);\n        }\n    }\n\n    toJSON() {\n        return {\n            name: this.name,\n            draw: this.draw\n        };\n    }\n\n}\n\nRule.id = 0;\n\n\nexport class RuleLeaf extends Rule {\n    constructor({name, parent, draw, visible, filter, properties}) {\n        super({name, parent, draw, visible, filter, properties});\n    }\n\n}\n\nexport class RuleTree extends Rule {\n    constructor({name, parent, draw, visible, rules, filter, properties}) {\n        super({name, parent, draw, visible, filter, properties});\n        this.rules = rules || [];\n    }\n\n    addRule(rule) {\n        this.rules.push(rule);\n    }\n\n    buildDrawGroups(context) {\n        let rules  = [];\n        //TODO, should this function take a RuleTree\n        matchFeature(context, [this], rules);\n\n        if (rules.length > 0) {\n            let cache_key = cacheKey(rules);\n\n            // Only evaluate each rule combination once (undefined means not yet evaluated,\n            // null means evaluated with no draw object)\n            if (ruleCache[cache_key] === undefined) {\n                // Visible?\n                if (rules.some(x => x.visible === false)) {\n                    ruleCache[cache_key] = null;\n                }\n                else {\n                    // Find all the unique draw blocks for this rule tree\n                    let draw_rules = rules.map(x => x && x.calculatedDraw);\n                    let draw_keys = {};\n\n                    for (let rule of draw_rules) {\n                        if (!rule) {\n                            continue;\n                        }\n                        for (let group of rule) {\n                            for (let key in group) {\n                                draw_keys[key] = true;\n                            }\n                        }\n                    }\n\n                    // Calculate each draw group\n                    for (let draw_key in draw_keys) {\n                        ruleCache[cache_key] = ruleCache[cache_key] || {};\n                        ruleCache[cache_key][draw_key] = mergeTrees(draw_rules, draw_key, context);\n\n                        // Only save the ones that weren't null\n                        if (!ruleCache[cache_key][draw_key]) {\n                            delete ruleCache[cache_key][draw_key];\n                        }\n                        else {\n                            ruleCache[cache_key][draw_key].key = cache_key + '/' + draw_key;\n                        }\n                    }\n\n                    // No rules evaluated\n                    if (ruleCache[cache_key] && Object.keys(ruleCache[cache_key]).length === 0) {\n                        ruleCache[cache_key] = null;\n                    }\n                }\n            }\n            return ruleCache[cache_key];\n        }\n    }\n\n}\n\nfunction isWhiteListed(key) {\n    return whiteList.indexOf(key) > -1;\n}\n\nfunction isEmpty(obj) {\n    return Object.keys(obj).length === 0;\n}\n\nexport function walkUp(rule, cb) {\n\n    if (rule.parent) {\n        walkUp(rule.parent, cb);\n    }\n\n    cb(rule);\n}\n\nexport function walkDown(rule, cb) {\n\n    if (rule.rules) {\n        rule.rules.forEach((r) => {\n            walkDown(r, cb);\n        });\n    }\n\n    cb(rule);\n}\n\nexport function groupProps(obj) {\n    let whiteListed = {}, nonWhiteListed = {};\n\n    for (let key in obj) {\n        if (isWhiteListed(key)) {\n            whiteListed[key] = obj[key];\n        } else {\n            nonWhiteListed[key] = obj[key];\n        }\n    }\n    return [whiteListed, nonWhiteListed];\n}\n\nexport function calculateDraw(rule) {\n\n    let draw  = [];\n\n    if (rule.parent) {\n        let cs = rule.parent.calculatedDraw || [];\n        draw.push(...cs);\n    }\n\n    draw.push(rule.draw);\n    return draw;\n}\n\nexport function mergeObjects(newObj, ...sources) {\n\n    for (let source of sources) {\n        if (!source) {\n            continue;\n        }\n        for (let key in source) {\n            let value = source[key];\n            if (typeof value === 'object' && !Array.isArray(value)) {\n                newObj[key] = mergeObjects(newObj[key] || {}, value);\n            } else {\n                newObj[key] = value;\n            }\n        }\n\n    }\n    return newObj;\n}\n\nexport function calculateOrder(orders, context = null, defaultOrder = 0) {\n    let sum = defaultOrder;\n\n    for (let order of orders) {\n        if (typeof order === 'function') {\n            order = order(context);\n        } else {\n            order = parseFloat(order);\n        }\n\n        if (!order || isNaN(order)) {\n            continue;\n        }\n        sum += order;\n    }\n    return sum;\n}\n\n\nexport function parseRuleTree(name, rule, parent) {\n\n    let properties = {name, parent};\n    let [whiteListed, nonWhiteListed] = groupProps(rule);\n    let empty = isEmpty(nonWhiteListed);\n    let Create;\n\n    if (empty && parent != null) {\n        Create = RuleLeaf;\n    } else {\n        Create = RuleTree;\n    }\n\n    let r = new Create(Object.assign(properties, whiteListed));\n\n    if (parent) {\n        parent.addRule(r);\n    }\n\n    if (!empty) {\n        for (let key in nonWhiteListed) {\n            let property = nonWhiteListed[key];\n            if (typeof property === 'object') {\n                parseRuleTree(key, property, r);\n            } else {\n                log.warn('Rule property must be an object: ', name, rule, property);\n            }\n        }\n\n    }\n\n    return r;\n}\n\n\nexport function parseRules(rules) {\n    let ruleTrees = {};\n\n    for (let key in rules) {\n        let rule = rules[key];\n        ruleTrees[key] = parseRuleTree(key, rule);\n    }\n\n    return ruleTrees;\n}\n\n\nfunction doesMatch(filter, context) {\n    return ((typeof filter === 'function' && filter(context)) || (filter == null));\n}\n\nexport function matchFeature(context, rules, collectedRules) {\n    let matched = false;\n    let childMatched = false;\n\n    if (rules.length === 0) { return; }\n\n    for (let r=0; r < rules.length; r++) {\n        let current = rules[r];\n        context.properties = current.properties;\n\n        if (current instanceof RuleLeaf) {\n\n            if (doesMatch(current.filter, context)) {\n                matched = true;\n                collectedRules.push(current);\n            }\n\n        } else if (current instanceof RuleTree) {\n            if (doesMatch(current.filter, context)) {\n                matched = true;\n\n                childMatched = matchFeature(\n                    context,\n                    current.rules,\n                    collectedRules\n                );\n\n                if (!childMatched) {\n                    collectedRules.push(current);\n                }\n            }\n        }\n\n        context.properties = null;\n    }\n\n    return matched;\n}\n","// Rendering styles\n\nimport {StyleParser} from './style_parser';\nimport FeatureSelection from '../selection';\nimport ShaderProgram from '../gl/shader_program';\nimport VBOMesh from '../gl/vbo_mesh';\nimport Material from '../material';\nimport Light from '../light';\nimport {MethodNotImplemented} from '../utils/errors';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\n\nimport log from 'loglevel';\n\n// Base class\n\nexport var Style = {\n    init ({ generation } = {}) {\n        if (!this.isBuiltIn()) {\n            this.built_in = false; // explicitly set to false to avoid any confusion\n        }\n\n        this.generation = generation;               // scene generation id this style was created for\n        this.defines = (this.hasOwnProperty('defines') && this.defines) || {}; // #defines to be injected into the shaders\n        this.shaders = (this.hasOwnProperty('shaders') && this.shaders) || {}; // shader customization (uniforms, defines, blocks, etc.)\n        this.selection = this.selection || false;   // flag indicating if this style supports feature selection\n        this.compiling = false;                     // programs are currently compiling\n        this.compiled = false;                      // programs are finished compiling\n        this.program = null;                        // GL program reference (for main render pass)\n        this.selection_program = null;              // GL program reference for feature selection render pass\n        this.feature_style = {};                    // style for feature currently being parsed, shared to lessen GC/memory thrash\n        this.vertex_template = [];                  // shared single-vertex template, filled out by each style\n        this.tile_data = {};\n        this.feature_options = {};\n\n        // Default world coords to wrap every 100,000 meters, can turn off by setting this to 'false'\n        this.defines.TANGRAM_WORLD_POSITION_WRAP = 100000;\n\n        // Blending\n        this.blend = this.blend || 'opaque';        // default: opaque styles are drawn first, without blending\n        this.defines[`TANGRAM_BLEND_${this.blend.toUpperCase()}`] = true;\n\n        // If the style defines its own material, replace the inherited material instance\n        if (!(this.material instanceof Material)) {\n            if (!Material.isValid(this.material)) {\n                this.material = StyleParser.defaults.material;\n            }\n            this.material = new Material(this.material);\n        }\n        this.material.inject(this);\n\n        // Set lighting mode: fragment, vertex, or none (specified as 'false')\n        Light.setMode(this.lighting, this);\n\n        this.initialized = true;\n    },\n\n    destroy () {\n        if (this.program) {\n            this.program.destroy();\n            this.program = null;\n        }\n\n        if (this.selection_program) {\n            this.selection_program.destroy();\n            this.selection_program = null;\n        }\n\n        this.gl = null;\n        this.initialized = false;\n    },\n\n    reset () {\n    },\n\n    isBuiltIn () {\n        return this.hasOwnProperty('built_in') && this.built_in;\n    },\n\n    fillVertexTemplate(attribute, value, { size, offset }) {\n        offset = (offset === undefined) ? 0 : offset;\n\n        let index = this.vertex_layout.index[attribute];\n        if (index === undefined) {\n            log.warn(`Style: in style '${this.name}', no index found in vertex layout for attribute '${attribute}'`);\n            return;\n        }\n\n        for (let i = 0; i < size; ++i) {\n            let v = value.length > i ? value[i] : value;\n            this.vertex_template[index + i + offset] = v;\n        }\n    },\n\n    /*** Style parsing and geometry construction ***/\n\n    // Returns an object to hold feature data (for a tile or other object)\n    startData (tile) {\n        this.tile_data[tile] = {\n            vertex_data: null,\n            uniforms: null\n        };\n        return this.tile_data[tile];\n    },\n\n    // Finalizes an object holding feature data (for a tile or other object)\n    endData (tile) {\n        var tile_data = this.tile_data[tile];\n        if (tile_data && tile_data.vertex_data) {\n            // Only keep final byte buffer\n            tile_data.vertex_data.end();\n            tile_data.vertex_data = tile_data.vertex_data.buffer;\n        }\n        this.tile_data[tile] = null;\n        return Promise.resolve(tile_data);\n    },\n\n    // Has mesh data for a given tile?\n    hasDataForTile (tile) {\n        return this.tile_data[tile] != null;\n    },\n\n    addFeature (feature, rule, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile.key);\n        }\n\n        let style = this.parseFeature(feature, rule, context);\n\n        // Skip feature?\n        if (!style) {\n            return;\n        }\n\n        // First feature in this render style?\n        if (!this.tile_data[tile.key].vertex_data) {\n            this.tile_data[tile.key].vertex_data = this.vertex_layout.createVertexData();\n        }\n\n        this.buildGeometry(feature.geometry, style, this.tile_data[tile.key].vertex_data, context);\n    },\n\n    buildGeometry (geometry, style, vertex_data, context) {\n        if (geometry.type === 'Polygon') {\n            this.buildPolygons([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiPolygon') {\n            this.buildPolygons(geometry.coordinates, style, vertex_data, context);\n        }\n        else if (geometry.type === 'LineString') {\n            this.buildLines([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiLineString') {\n            this.buildLines(geometry.coordinates, style, vertex_data, context);\n        }\n        else if (geometry.type === 'Point') {\n            this.buildPoints([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiPoint') {\n            this.buildPoints(geometry.coordinates, style, vertex_data, context);\n        }\n    },\n\n    parseFeature (feature, rule_style, context) {\n        try {\n            var style = this.feature_style;\n\n            // Preprocess first time\n            if (!rule_style.preprocessed) {\n                this.preprocess(rule_style);\n                rule_style.preprocessed = true;\n            }\n\n            // Calculate order if it was not cached\n            style.order = this.parseOrder(rule_style.order, context);\n\n            // Feature selection (only if style supports it)\n            var selectable = false;\n            style.interactive = rule_style.interactive;\n            if (this.selection) {\n                if (typeof style.interactive === 'function') {\n                    selectable = style.interactive(context);\n                }\n                else {\n                    selectable = style.interactive;\n                }\n            }\n\n            // If feature is marked as selectable\n            if (selectable) {\n                style.selection_color = FeatureSelection.makeColor(feature, context.tile);\n            }\n            else {\n                style.selection_color = FeatureSelection.defaultColor;\n            }\n\n            // Subclass implementation\n            style = this._parseFeature(feature, rule_style, context);\n\n            return style;\n        }\n        catch(error) {\n            log.error('Style.parseFeature: style parsing error', feature, style, error);\n        }\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        throw new MethodNotImplemented('_parseFeature');\n    },\n\n    preprocess () {},\n\n    // Parse an order value\n    parseOrder (order, context) {\n        // Calculate order if it was not cached\n        if (typeof order !== 'number') {\n            return StyleParser.calculateOrder(order, context);\n        }\n        return order;\n    },\n\n    // Parse a color of choose a default if acceptable, return undefined if color missing\n    parseColor(color, context) {\n        // Need either a color, or a shader block for 'color' or 'filter'\n        if (color) {\n            return StyleParser.cacheColor(color, context);\n        }\n        else if (this.shaders.blocks.color || this.shaders.blocks.filter) {\n            return StyleParser.defaults.color;\n        }\n    },\n\n    // Build functions are no-ops until overriden\n    buildPolygons () {},\n    buildLines () {},\n    buildPoints () {},\n\n\n    /*** GL state and rendering ***/\n\n    setGL (gl) {\n        this.gl = gl;\n    },\n\n    makeMesh (vertex_data, { uniforms } = {}) {\n        return new VBOMesh(this.gl, vertex_data, this.vertex_layout, { uniforms });\n    },\n\n    compile () {\n        if (!this.gl) {\n            throw(new Error(`style.compile(): skipping for ${this.name} because no GL context`));\n        }\n\n        if (this.compiling) {\n            throw(new Error(`style.compile(): skipping for ${this.name} because style is already compiling`));\n        }\n        this.compiling = true;\n        this.compiled = false;\n\n        // Build defines & for selection (need to create a new object since the first is stored as a reference by the program)\n        var defines = this.buildDefineList();\n        if (this.selection) {\n            var selection_defines = Object.assign({}, defines);\n            selection_defines.TANGRAM_FEATURE_SELECTION = true;\n        }\n\n        // Get any custom code blocks, uniform dependencies, etc.\n        var blocks = (this.shaders && this.shaders.blocks);\n        var block_scopes = (this.shaders && this.shaders.block_scopes);\n        var uniforms = (this.shaders && this.shaders.uniforms);\n\n        // accept a single extension, or an array of extensions\n        var extensions = (this.shaders && this.shaders.extensions);\n        if (typeof extensions === 'string') {\n            extensions = [extensions];\n        }\n\n        // Create shaders\n        try {\n            this.program = new ShaderProgram(\n                this.gl,\n                shaderSources[this.vertex_shader_key],\n                shaderSources[this.fragment_shader_key],\n                {\n                    name: this.name,\n                    defines,\n                    uniforms,\n                    blocks,\n                    block_scopes,\n                    extensions\n                }\n            );\n            this.program.compile();\n\n            if (this.selection) {\n                this.selection_program = new ShaderProgram(\n                    this.gl,\n                    shaderSources[this.vertex_shader_key],\n                    shaderSources['gl/shaders/selection_fragment'],\n                    {\n                        name: (this.name + ' (selection)'),\n                        defines: selection_defines,\n                        uniforms,\n                        blocks,\n                        block_scopes,\n                        extensions\n                    }\n                );\n                this.selection_program.compile();\n            }\n            else {\n                this.selection_program = null;\n            }\n        }\n        catch(error) {\n            this.compiling = false;\n            this.compiled = false;\n            throw(new Error(`style.compile(): style ${this.name} error:`, error));\n        }\n\n        this.compiling = false;\n        this.compiled = true;\n    },\n\n    // Add a shader block\n    addShaderBlock (key, block, scope = null) {\n        this.shaders.blocks = this.shaders.blocks || {};\n        this.shaders.blocks[key] = this.shaders.blocks[key] || [];\n        this.shaders.blocks[key].push(block);\n\n        this.shaders.block_scopes = this.shaders.block_scopes || {};\n        this.shaders.block_scopes[key] = this.shaders.block_scopes[key] || [];\n        this.shaders.block_scopes[key].push(scope);\n    },\n\n    // Remove all shader blocks for key\n    removeShaderBlock (key) {\n        if (this.shaders.blocks) {\n            this.shaders.blocks[key] = null;\n        }\n    },\n\n    replaceShaderBlock (key, block, scope = null) {\n        this.removeShaderBlock(key);\n        this.addShaderBlock(key, block, scope);\n    },\n\n    /** TODO: could probably combine and generalize this with similar method in ShaderProgram\n     * (list of define objects that inherit from each other)\n     */\n    buildDefineList () {\n        // Add any custom defines to built-in style defines\n        var defines = {}; // create a new object to avoid mutating a prototype value that may be shared with other styles\n        if (this.defines != null) {\n            for (var d in this.defines) {\n                defines[d] = this.defines[d];\n            }\n        }\n        if (this.shaders != null && this.shaders.defines != null) {\n            for (d in this.shaders.defines) {\n                defines[d] = this.shaders.defines[d];\n            }\n        }\n        return defines;\n\n    },\n\n    // Setup any GL state for rendering\n    setup () {\n        this.setUniforms();\n        this.material.setupProgram(ShaderProgram.current);\n    },\n\n    // Set style uniforms on currently bound program\n    setUniforms () {\n        var program = ShaderProgram.current;\n        if (!program) {\n            return;\n        }\n\n        program.setUniforms(this.shaders && this.shaders.uniforms, true); // reset texture unit to 0\n    },\n\n    update () {\n        // Style-specific animation\n        // if (typeof this.animation === 'function') {\n        //     this.animation();\n        // }\n    }\n};\n","// Manage rendering styles\n\nimport Utils from '../utils/utils';\nimport ShaderProgram from '../gl/shader_program';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\nimport {Style} from './style';\nimport {mergeObjects} from './rule';\n\nimport log from 'loglevel';\n\nexport var StyleManager = {};\nexport var Styles = {};\nexport var BaseStyles = {};\n\nStyleManager.styles = Styles;\n\n// Set the base object used to instantiate styles\nStyleManager.baseStyle = Style;\n\n// Global configuration for all styles\nStyleManager.init = function () {\n    if (StyleManager.initialized) {\n        return;\n    }\n\n    ShaderProgram.removeBlock('global');\n\n    // Layer re-ordering function\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/layer_order']);\n\n    // Feature selection global\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/selection_globals']);\n\n    // World position wrapping\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/world_position_wrap']);\n\n    // Feature selection vertex shader support\n    ShaderProgram.replaceBlock('feature-selection-vertex', shaderSources['gl/shaders/selection_vertex']);\n\n    // assume min 16-bit depth buffer, in practice uses 14-bits, 1 extra bit to handle virtual half-layers\n    // for outlines (inserted in between layers), another extra bit to prevent precision loss\n    ShaderProgram.defines.TANGRAM_LAYER_DELTA = 1 / (1 << 14);\n\n    StyleManager.initialized = true;\n};\n\n// Destroy all styles for a given GL context\nStyleManager.destroy = function (gl) {\n    Object.keys(Styles).forEach((_name) => {\n        var style = Styles[_name];\n        if (style.gl === gl) {\n            log.trace(`StyleManager.destroy: destroying render style ${style.name}`);\n\n            if (!style.isBuiltIn()) {\n                StyleManager.remove(style.name);\n            }\n            style.destroy();\n        }\n    });\n};\n\n// Register a style\nStyleManager.register = function (style) {\n    Styles[style.name] = style;\n    BaseStyles[style.name] = style;\n};\n\n// Remove a style\nStyleManager.remove = function (name) {\n    delete Styles[name];\n};\n\n// Load style definitions from external URLs\nStyleManager.loadRemoteStyles = function (styles, base) {\n    // Collect URLs and modes to import from them\n    // This is done as a separate step becuase it is possible to import multiple modes from a single\n    // URL, and we want to avoid duplicate calls for the same file.\n    var urls = {};\n    for (var name in styles) {\n        var style = styles[name];\n        if (style.url) {\n            let url = style.url;\n            if (base) {\n                url = Utils.addBaseURL(url, base);\n            }\n\n            if (!urls[url]) {\n                urls[url] = [];\n            }\n\n            // Make a list of the styles to import for this URL\n            urls[url].push({\n                target_name: name,\n                source_name: style.name || name\n            });\n        }\n    }\n\n    // As each URL finishes loading, replace the target style(s)\n    return Promise.all(Object.keys(urls).map(url => {\n        return new Promise((resolve, reject) => {\n            Utils.loadResource(url).then((data) => {\n                // Mixin remote styles, within each remote file\n                // TODO: may not handle multiple levels of mixins, and will not handle nested remote files\n                for (var source_name in data) {\n                    let source_import = urls[url] && urls[url].find(s => s.source_name === source_name);\n                    if (source_import) {\n                        // use imported name if different from name in source file\n                        data[source_name].name = source_import.target_name;\n                    }\n                    else {\n                        data[source_name].name = source_name;\n                    }\n\n                    data[source_name] = StyleManager.mix(data[source_name], data);\n                }\n\n                // Add remote styles to local styles\n                for (var target of urls[url]) {\n                    if (data && data[target.source_name]) {\n                        styles[target.target_name] = data[target.source_name];\n                    }\n                    else {\n                        delete styles[target.target_name];\n                        return reject(new Error(`StyleManager.loadRemoteStyles: error importing style ${target.target_name}, could not find source style ${target.source_name} in ${url}`));\n                    }\n                }\n                resolve();\n\n                this.selection = false;\n            }).catch((error) => {\n                log.error(`StyleManager.loadRemoteStyles: error importing style(s) ${JSON.stringify(urls[url])} from ${url}`, error);\n            });\n        });\n    })).then(() => Promise.resolve(styles));\n};\n\n// Preload shader blocks from external URLs\nStyleManager.loadShaderBlocks = function (styles, base) {\n    if (!styles) {\n        return Promise.resolve({});\n    }\n    var queue = [];\n    for (var style of Utils.values(styles)) {\n        if (style.shaders && style.shaders.blocks) {\n            let _blocks = style.shaders.blocks;\n\n            for (let [key, block] of Utils.entries(style.shaders.blocks)) {\n                let _key = key;\n\n                // Array of blocks\n                if (Array.isArray(block)) {\n                    for (let b=0; b < block.length; b++) {\n                        if (typeof block[b] === 'object' && block[b].url) {\n                            let _index = b;\n                            let url = block[b].url;\n                            if (base) {\n                                url = Utils.addBaseURL(url, base);\n                            }\n\n                            queue.push(Utils.io(Utils.cacheBusterForUrl(url)).then((data) => {\n                                _blocks[_key][_index] = data;\n                            }).catch((error) => {\n                                log.error(`StyleManager.loadShaderBlocks: error loading shader block`, _blocks, _key, _index, error);\n                            }));\n                        }\n                    }\n                }\n                // Single block\n                else if (typeof block === 'object' && block.url) {\n                    let url = block.url;\n                    if (base) {\n                        url = Utils.addBaseURL(url, base);\n                    }\n\n                    queue.push(Utils.io(Utils.cacheBusterForUrl(url)).then((data) => {\n                        _blocks[_key] = data;\n                    }).catch((error) => {\n                        log.error(`StyleManager.loadShaderBlocks: error loading shader block`, _blocks, _key, error);\n                    }));\n                }\n            }\n        }\n    }\n    return Promise.all(queue).then(() => Promise.resolve(styles)); // TODO: add error\n};\n\nStyleManager.mix = function (style, styles) {\n    // Exit early if we have already applied mixins to this style\n    if (style.mixed) {\n        return style;\n    }\n\n    // Mixin sources, in order\n    let sources = [];\n    if (style.mix) {\n        if (Array.isArray(style.mix)) {\n            sources.push(...style.mix);\n        }\n        else {\n            sources.push(style.mix);\n        }\n        sources = sources.map(x => styles[x]).filter(x => x);\n    }\n    sources.push(style);\n\n    // Flags - OR'd, true if any style has it set\n    style.animated = sources.some(x => x && x.animated);\n    style.texcoords = sources.some(x => x && x.texcoords);\n\n    // Overwrites - last definition wins\n    style.base = sources.map(x => x.base).filter(x => x).pop();\n    style.lighting = sources.map(x => x.lighting).filter(x => x != null).pop();\n    style.texture = sources.map(x => x.texture).filter(x => x).pop();\n    if (sources.some(x => x.blend)) {\n        // only mix blend if explicitly set, otherwise let base style choose blending mode\n        style.blend = sources.map(x => x.blend).filter(x => x).pop();\n    }\n\n    // Merges - property-specific rules for merging values\n    style.defines = Object.assign({}, ...sources.map(x => x.defines).filter(x => x));\n    style.material = Object.assign({}, ...sources.map(x => x.material).filter(x => x));\n\n    let merge = sources.map(x => x.shaders).filter(x => x);\n    let shaders = {};\n    shaders.defines = Object.assign({}, ...merge.map(x => x.defines).filter(x => x));\n    shaders.uniforms = Object.assign({}, ...merge.map(x => x.uniforms).filter(x => x));\n\n    // Build a list of unique extensions\n    shaders.extensions = Object.keys(merge\n        .map(x => x.extensions)\n        .filter(x => x)\n        .reduce((prev, cur) => {\n            // single extension\n            if (typeof cur === 'string') {\n                prev[cur] = true;\n            }\n            // array of extensions\n            else {\n                cur.forEach(x => prev[x] = true);\n            }\n            return prev;\n        }, {}) || {}\n    );\n\n    // Mark all shader blocks for the target style as originating with its own name\n    if (style.shaders && style.shaders.blocks) {\n        style.shaders.block_scopes = style.shaders.block_scopes || {};\n        for (let [k, block] of Utils.entries(style.shaders.blocks)) {\n            style.shaders.block_scopes[k] = style.shaders.block_scopes[k] || [];\n            if (Array.isArray(block)) {\n                style.shaders.block_scopes[k].push(...block.map(() => style.name));\n            }\n            else {\n                style.shaders.block_scopes[k].push(style.name);\n            }\n        }\n    }\n\n    // Merge shader blocks, keeping track of which style each block originated from\n    for (let source of merge) {\n        if (!source.blocks) {\n            continue;\n        }\n\n        shaders.blocks = shaders.blocks || {};\n        shaders.block_scopes = shaders.block_scopes || {};\n\n        for (let [t, block] of Utils.entries(source.blocks)) {\n            let block_scope = source.block_scopes[t];\n\n            shaders.blocks[t] = shaders.blocks[t] || [];\n            shaders.block_scopes[t] = shaders.block_scopes[t] || [];\n\n            if (Array.isArray(block)) {\n                shaders.blocks[t].push(...block);\n                shaders.block_scopes[t].push(...block_scope);\n            }\n            else {\n                shaders.blocks[t].push(block);\n                shaders.block_scopes[t].push(block_scope);\n            }\n        }\n    }\n\n    style.shaders = shaders;\n    style.mixed = true; // track that we already applied mixins (avoid dupe work later)\n\n    return style;\n};\n\n// Create a new style\n// name: name of new style\n// config: properties of new style\n// styles: working set of styles being built (used for mixing in existing styles)\nStyleManager.create = function (name, config, styles = {}) {\n    let style = mergeObjects({}, config); // deep copy\n    style.name = name;\n\n    // Style mixins\n    style = StyleManager.mix(style, styles);\n\n    // Has base style?\n    // Only renderable (instantiated) styles should be included for run-time use\n    // Others are intermediary/abstract, used during style composition but not execution\n    if (style.base && BaseStyles[style.base]) {\n        Styles[name] = style = Object.assign(Object.create(BaseStyles[style.base]), style);\n    }\n\n    return style;\n};\n\n// Called to create and initialize styles\nStyleManager.build = function (styles, scene = {}) {\n    // Sort styles by dependency, then build them\n    let style_deps = Object.keys(styles).sort(\n        (a, b) => StyleManager.inheritanceDepth(a, styles) - StyleManager.inheritanceDepth(b, styles)\n    );\n\n    // Only keep built-in base styles\n    for (let sname in Styles) {\n        if (!BaseStyles[sname]) {\n            delete Styles[sname];\n        }\n        else {\n            Styles[sname].reset();\n        }\n    }\n\n    // Working set of styles being built\n    let ws = {};\n    for (let sname of style_deps) {\n        ws[sname] = StyleManager.create(sname, styles[sname], ws);\n    }\n\n    StyleManager.initStyles(scene);\n    return Styles;\n};\n\n// Initialize all styles\nStyleManager.initStyles = function (scene) {\n    // Initialize all\n    for (let sname in Styles) {\n        Styles[sname].init(scene);\n    }\n};\n\n// Given a style key in a set of styles to add, count the length of the inheritance chain\n// TODO: remove current (Styles) and future (styles) duplication, confusing\nStyleManager.inheritanceDepth = function (key, styles) {\n    let parents = 0;\n\n    while(true) {\n        let style = styles[key];\n        if (!style) {\n            // this is a scene def error, trying to extend a style that doesn't exist\n            break;\n        }\n\n        // Dependency chain ends when this style isn't mixing in any others\n        if (!style.mix) {\n            break;\n        }\n\n        // Traverse next parent style\n        parents++;\n\n        if (Array.isArray(style.mix)) {\n            // If multiple mixins, find the deepest one\n            parents += Math.max(...style.mix.map(s => {\n                // Trying to mix into itself!\n                if (key === s) {\n                    return;\n                }\n\n                return StyleManager.inheritanceDepth(s, styles);\n            }));\n            break;\n        }\n        else {\n            // Trying to mix into itself!\n            if (key === style.mix) {\n                break;\n            }\n\n            // If single mixin, continue loop up the tree\n            key = style.mix;\n        }\n    }\n    return parents;\n};\n\n// Compile all styles\nStyleManager.compile = function (keys, scene) {\n    keys = keys || Object.keys(Styles);\n    for (let key of keys) {\n        let style = Styles[key];\n        try {\n            style.compile();\n            log.trace(`StyleManager.compile(): compiled style ${key}`);\n        }\n        catch(error) {\n            log.error(`StyleManager.compile(): error compiling style ${key}:`, error);\n\n            scene.trigger('warning', {\n                type: 'styles',\n                message: `Error compiling style ${key}`,\n                style,\n                shader_errors: style.program && style.program.shader_errors\n            });\n        }\n    }\n\n    log.debug(`StyleManager.compile(): compiled all styles`);\n};\n\n// Get all styles with mesh data for a given tile\nStyleManager.stylesForTile = function (tile) {\n    let styles = [];\n    for (let s in Styles) {\n        if (Styles[s].hasDataForTile(tile)) {\n            styles.push(s);\n        }\n    }\n    return styles;\n};\n","import Utils from '../utils/utils';\nimport Geo from '../geo';\n\nimport parseCSSColor from 'csscolorparser';\nimport log from 'loglevel';\n\nexport var StyleParser = {};\n\n// Style macros\n\nStyleParser.expandMacros = function expandMacros (obj) {\n    for (var p in obj) {\n        var val = obj[p];\n\n        // Loop through object properties\n        if (typeof val === 'object') {\n            obj[p] = expandMacros(val);\n        }\n        // Convert strings back into functions\n        else if (typeof val === 'string') {\n            for (var m in StyleParser.macros) {\n                if (val.match(StyleParser.macros[m])) {\n                    var f;\n                    try {\n                        /*jshint ignore:start */\n                        eval('f = ' + val);\n                        /*jshint ignore:end */\n                        obj[p] = f;\n                        log.trace(`expanded macro ${val} to ${f}`);\n                        break;\n                    }\n                    catch (e) {\n                        // fall-back to original value if parsing failed\n                        obj[p] = val;\n                        log.trace(`failed to expand macro ${val}`);\n                    }\n                }\n            }\n        }\n    }\n\n    return obj;\n};\n\n// List of macros\nStyleParser.macros = [\n    'Style.color.pseudoRandomColor',\n    'Style.color.randomColor'\n];\n\n\n\nvar Style = {};\n\nStyle.color = {\n    // pseudo-random grayscale by geometry id\n    pseudoRandomGrayscale() {\n        var func = `function() {\n            var c = Math.max((parseInt(feature.id, 16) % 100) / 100, 0.4);\n            return [0.7 * c, 0.7 * c, 0.7 * c];\n        }`;\n        return func;\n    },\n\n    // pseudo-random color by geometry id\n    pseudoRandomColor() {\n        var func = `function() {\n            return [\n                0.7 * (parseInt(feature.id, 16) / 100 % 1),\n                0.7 * (parseInt(feature.id, 16) / 10000 % 1),\n                0.7 * (parseInt(feature.id, 16) / 1000000 % 1)\n            ];\n        }`;\n        return func;\n        // return `function() { return [0.7 * (parseInt(feature.id, 16) / 100 % 1), 0.7 * (parseInt(feature.id, 16) / 10000 % 1), 0.7 * (parseInt(feature.id, 16) / 1000000 % 1)]; }`;\n    },\n\n    // random color\n    randomColor() {\n        var func = `function() {\n            return [0.7 * Math.random(), 0.7 * Math.random(), 0.7 * Math.random()];\n        }`;\n        return func;\n    }\n};\n\n// Wraps style functions and provides a scope of commonly accessible data:\n// - feature: the 'properties' of the feature, e.g. accessed as 'feature.name'\n// - $zoom: the current map zoom level\n// - $geometry: the type of geometry, 'point', 'line', or 'polygon'\n// - $meters_per_pixel: conversion for meters/pixels at current map zoom\n// - properties: user-defined properties on the style-rule object in the stylesheet\nStyleParser.wrapFunction = function (func) {\n    var f = `function(context) {\n                var feature = context.feature.properties;\n                var $zoom = context.zoom;\n                var $geometry = context.geometry;\n                var $meters_per_pixel = context.meters_per_pixel;\n                var properties = context.properties;\n                return (${func}());\n            }`;\n    return f;\n};\n\n\n// Style parsing\n\n// Style defaults\nStyleParser.defaults = {\n    color: [1, 1, 1, 1],\n    width: 1,\n    size: 1,\n    extrude: false,\n    height: 20,\n    min_height: 0,\n    order: 0,\n    z: 0,\n    material: {\n        ambient: 1,\n        diffuse: 1\n    }\n};\n\n\n// A context object that is passed to style parsing functions to provide a scope of commonly used values\nStyleParser.getFeatureParseContext = function (feature, tile) {\n    return {\n        feature,\n        tile,\n        zoom: tile.style_zoom,\n        geometry: Geo.geometryType(feature.geometry.type),\n        meters_per_pixel: Geo.metersPerPixel(tile.coords.z),\n        units_per_meter: Geo.units_per_meter[tile.coords.z]\n    };\n};\n\nStyleParser.convertUnits = function(val, context, convert = 'meters') {\n    if (typeof val === 'string') {\n        var units = val.match(/([0-9.-]+)([a-z]+)/);\n        if (units && units.length === 3) {\n            val = parseFloat(units[1]);\n            units = units[2];\n        }\n\n        // Convert to meters\n        if (convert === 'meters') {\n            // Convert from pixels\n            if (units === 'px') {\n                val *= Geo.metersPerPixel(context.zoom);\n            }\n            // Convert from kilometers\n            else if (units === 'km') {\n                val *= 1000;\n            }\n        }\n    }\n    else if (Array.isArray(val)) {\n        // Array of arrays, e.g. zoom-interpolated stops\n        if (Array.isArray(val[0])) {\n            return val.map(v => { return [v[0], StyleParser.convertUnits(v[1], context, convert)]; });\n        }\n        // Array of values\n        else {\n            return val.map(v => { return StyleParser.convertUnits(v, context, convert); });\n        }\n    }\n    return val;\n};\n\n// Takes a distance cache object and returns a distance value for this zoom\n// (caching the result for future use)\n// { value: original, zoom: { z: meters }, dynamic: function(){...} }\nStyleParser.cacheDistance = function(val, context, convert = 'meters') {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.zoom && val.zoom[convert] && val.zoom[convert][context.zoom]) {\n        return val.zoom[convert][context.zoom];\n    }\n    else {\n        // Dynamic function-based\n        if (typeof val.value === 'function') {\n            val.dynamic = val.value;\n            let v = val.dynamic(context);\n            return v;\n        }\n        // Array of zoom-interpolated stops, e.g. [zoom, value] pairs\n        else {\n            // Calculate value for current zoom\n            val.zoom = val.zoom || {};\n            let zunits = val.zoom[convert] = val.zoom[convert] || {};\n\n            zunits[context.zoom] = StyleParser.convertUnits(val.value, context,\n                convert === 'meters' && 'meters'); // convert to meters\n            zunits[context.zoom] = Utils.interpolate(context.zoom, zunits[context.zoom]);\n\n            return zunits[context.zoom];\n        }\n    }\n};\n\n// Cache previously parsed color strings\nStyleParser.string_colors = {};\nStyleParser.colorForString = function(string) {\n    // Cached\n    if (StyleParser.string_colors[string]) {\n        return StyleParser.string_colors[string];\n    }\n\n    // Calculate and cache\n    let color = parseCSSColor.parseCSSColor(string);\n    if (color && color.length === 4) {\n        color[0] /= 255;\n        color[1] /= 255;\n        color[2] /= 255;\n        color[3] = 1;\n    }\n    else {\n        color = StyleParser.defaults.color;\n    }\n    StyleParser.string_colors[string] = color;\n    return color;\n};\n\n// Takes a color cache object and returns a color value for this zoom\n// (caching the result for future use)\n// { value: original, static: [r,g,b,a], zoom: { z: [r,g,b,a] }, dynamic: function(){...} }\nStyleParser.cacheColor = function(val, context = {}) {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        v[3] = v[3] || 1; // default alpha\n        return v;\n    }\n    else if (val.static) {\n        return val.static;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) {\n        return val.zoom[context.zoom];\n    }\n    else {\n        // Dynamic function-based color\n        if (typeof val.value === 'function') {\n            val.dynamic = val.value;\n            let v = val.dynamic(context);\n            v[3] = v[3] || 1; // default alpha\n            return v;\n        }\n        // Single string color\n        else if (typeof val.value === 'string') {\n            val.static = StyleParser.colorForString(val.value);\n            return val.static;\n        }\n        // Array of zoom-interpolated stops, e.g. [zoom, color] pairs\n        else if (Array.isArray(val.value) && Array.isArray(val.value[0])) {\n            if (!val.zoom) {\n                val.zoom = {};\n                // Parse any string colors inside stops\n                for (let i=0; i < val.value.length; i++) {\n                    let v = val.value[i];\n                    if (typeof v[1] === 'string') {\n                        v[1] = StyleParser.colorForString(v[1]);\n                    }\n                }\n            }\n\n            // Calculate color for current zoom\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value);\n            val.zoom[context.zoom][3] = val.zoom[context.zoom][3] || 1; // default alpha\n            return val.zoom[context.zoom];\n        }\n        // Single array color\n        else {\n            val.static = val.value;\n            val.static[3] = val.static[3] || 1; // default alpha\n            return val.static;\n        }\n    }\n};\n\nStyleParser.parseColor = function(val, context = {}) {\n    if (typeof val === 'function') {\n        val = val(context);\n    }\n\n    // Parse CSS-style colors\n    // TODO: change all colors to use 0-255 range internally to avoid dividing and then re-multiplying in geom builder\n    if (typeof val === 'string') {\n        val = parseCSSColor.parseCSSColor(val);\n        if (val && val.length === 4) {\n            val[0] /= 255;\n            val[1] /= 255;\n            val[2] /= 255;\n        }\n        else {\n            val = null;\n        }\n    }\n    else if (Array.isArray(val) && Array.isArray(val[0])) {\n        // Array of zoom-interpolated stops, e.g. [zoom, color] pairs\n        for (let i=0; i < val.length; i++) {\n            let v = val[i];\n            if (typeof v[1] === 'string') {\n                var vc = parseCSSColor.parseCSSColor(v[1]);\n                if (vc && vc.length === 4) {\n                    vc[0] /= 255;\n                    vc[1] /= 255;\n                    vc[2] /= 255;\n                    v[1] = vc;\n                }\n            }\n        }\n    }\n\n    if (context.zoom) {\n        val = Utils.interpolate(context.zoom, val);\n    }\n\n    // Defaults\n    if (val) {\n        // alpha\n        if (!val[3]) {\n            val[3] = 1;\n        }\n    }\n    else {\n        val = [0, 0, 0, 1];\n    }\n\n    return val;\n};\n\n// Order is summed from top to bottom in the style hierarchy:\n// each child order value is added to the parent order value\nStyleParser.calculateOrder = function(order, context) {\n    if (typeof order === 'function') {\n        order = order(context);\n    }\n    else if (Array.isArray(order)) {\n        order = order.reduce((sum, order) => {\n            order = order || StyleParser.defaults.order;\n            if (typeof order === 'function') {\n                order = order(context);\n            }\n            else if (typeof order === 'string') {\n                order = context.feature.properties[order];\n            }\n            else {\n                order = parseFloat(order);\n            }\n\n            if (!order || isNaN(order)) {\n                return sum;\n            }\n            return sum + order;\n        }, 0);\n    }\n    else if (typeof order === 'string') {\n        if (context.feature.properties[order]) {\n            order = context.feature.properties[order];\n        }\n        else {\n            order = parseFloat(order);\n        }\n    }\n\n    return order;\n};\n","import Utils from '../../utils/utils';\nimport {StyleParser} from '../style_parser';\n\nexport default class FeatureLabel {\n\n    constructor (feature, rule, context, text, tile, default_font_style) {\n        this.text = text;\n        this.feature = feature;\n        this.tile_key = tile.key;\n        this.style = this.constructFontStyle(rule, context, default_font_style);\n        this.style_key = this.constructStyleKey(this.style);\n    }\n\n    getHash () {\n        let str = this.tile_key + this.style_key + this.text;\n        return Utils.hashString(str);\n    }\n\n    constructFontStyle (rule, context, default_font_style) {\n        let style = {};\n        rule.font = rule.font || default_font_style;\n\n        // Use fill if specified, or default\n        style.fill = (rule.font.fill && Utils.toCanvasColor(StyleParser.parseColor(rule.font.fill, context))) || default_font_style.fill;\n\n        // Use stroke if specified\n        if (rule.font.stroke && rule.font.stroke.color) {\n            style.stroke = Utils.toCanvasColor(StyleParser.parseColor(rule.font.stroke.color));\n            style.stroke_width = rule.font.stroke.width || default_font_style.stroke.width;\n        }\n\n        // Font properties are modeled after CSS names:\n        // - family: Helvetica, Futura, etc.\n        // - size: in pt, px, or em\n        // - style: normal, italic, oblique\n        // - weight: normal, bold, etc.\n        // - transform: capitalize, uppercase, lowercase\n        style.style = rule.font.style || default_font_style.style;\n        style.weight = rule.font.weight || default_font_style.weight;\n        style.family = rule.font.family || default_font_style.family;\n        style.transform = rule.font.transform;\n\n        let size = rule.font.size || rule.font.typeface || default_font_style.size; // TODO: 'typeface' legacy syntax, deprecate\n        let size_regex = /([0-9]*\\.)?[0-9]+(px|pt|em|%)/g;\n        let ft_size = (size.match(size_regex) || [])[0];\n        let size_kind = ft_size.replace(/([0-9]*\\.)?[0-9]+/g, '');\n\n        // TODO: improve pt/em conversion\n        style.px_logical_size = Utils.toPixelSize(ft_size.replace(/([a-z]|%)/g, ''), size_kind);\n        style.px_size = style.px_logical_size * Utils.device_pixel_ratio;\n        style.stroke_width *= Utils.device_pixel_ratio;\n        style.size = size.replace(size_regex, style.px_size + \"px\");\n\n        if (rule.font.typeface) { // 'typeface' legacy syntax, deprecate\n            style.font_css = rule.font.typeface.replace(size_regex, style.px_size + \"px\");\n        }\n        else {\n            style.font_css = this.fontCSS(style);\n        }\n\n        return style;\n    }\n\n    // Build CSS-style font string (to set Canvas draw state)\n    fontCSS ({ style, weight, size, family }) {\n        return [style, weight, size, family]\n            .filter(x => x) // remove null props\n            .join(' ');\n    }\n\n    // A key for grouping all labels of the same text style (e.g. same Canvas state, to minimize state changes)\n    constructStyleKey ({ style, weight, family, size, fill, stroke, stroke_width, transform, typeface }) {\n        return [style, weight, family, size, fill, stroke, stroke_width, transform, typeface].join('/'); // typeface for legacy\n    }\n\n    // Called before rasterization\n    static applyTextTransform (text, transform) {\n        if (transform === 'capitalize') {\n            return text.replace(/\\w\\S*/g, function (txt) {\n                return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();\n            });\n        }\n        else if (transform === 'uppercase') {\n            return text.toUpperCase();\n        }\n        else if (transform === 'lowercase') {\n            return text.toLowerCase();\n        }\n        return text;\n    }\n\n}\n","/*global Label */\n\nimport boxIntersect from 'box-intersect';\nimport Utils from '../../utils/utils';\nimport OBB from '../../utils/obb';\n\nexport default class Label {\n\n    constructor (text, size, options) {\n        Object.assign(this, {\n            text,\n            size,\n            options,\n            position: null,\n            aabb: null,\n        });\n    }\n\n    occluded (aabbs) {\n        let intersect = false;\n\n        // Broadphase\n        if (aabbs.length > 0) {\n            boxIntersect([this.aabb], aabbs, (i, j) => {\n                // Narrow phase\n                if (OBB.intersect(this.aabb.obb, aabbs[j].obb)) {\n                    intersect = true;\n                    return true;\n                }\n            });\n        }\n\n        // No collision on aabb\n        if (!intersect) {\n            aabbs.push(this.aabb);\n        }\n\n        return intersect;\n    }\n\n    // checks whether the label is within the tile boundaries\n    inTileBounds () {\n        let min = [ this.aabb[0], this.aabb[1] ];\n        let max = [ this.aabb[2], this.aabb[3] ];\n\n        if (!Utils.pointInTile(min) || !Utils.pointInTile(max)) {\n            return false;\n        }\n\n        return true;\n    }\n\n    // whether the label should be discarded\n    // 1. try to keep the label in tile if the label (to avoid collision over tile for now)\n    // 2. if 1. -> keep a minimal distance between the label\n    // 3. if 2. -> perfom occlusion\n    discard (aabbs) {\n        let discard = false;\n\n        // perform specific styling rule, should we keep the label in tile bounds?\n        if (this.options.keep_in_tile) {\n            let in_tile = this.inTileBounds();\n\n            if (!in_tile && this.options.move_in_tile) {\n                // can we move?\n                discard = this.moveInTile();\n            } else if (!in_tile) {\n                // we didn't want to move at all,\n                // just discard since we're out of tile bounds\n                return true;\n            }\n        }\n\n        // should we discard? if not, just make occlusion test\n        return discard || this.occluded(aabbs);\n    }\n}\n","import LabelPoint from './label_point';\nimport LabelLine from './label_line';\nimport Geo from '../../geo';\n\nvar LabelBuilder;\nexport default LabelBuilder = {};\n\nLabelBuilder.buildFromGeometry = function (text, size, geometry, options) {\n    let labels = [];\n\n    if (geometry.type === \"LineString\") {\n        let lines = geometry.coordinates;\n\n        labels.push(new LabelLine(text, size, lines, options));\n    } else if (geometry.type === \"MultiLineString\") {\n        let lines = geometry.coordinates;\n\n        for (let i = 0; i < lines.length; ++i) {\n            let line = lines[i];\n            labels.push(new LabelLine(text, size, line, options));\n        }\n    } else if (geometry.type === \"Point\") {\n        labels.push(new LabelPoint(text, geometry.coordinates, size, options));\n    } else if (geometry.type === \"MultiPoint\") {\n        let points = geometry.coordinates;\n\n        for (let i = 0; i < points.length; ++i) {\n            let point = points[i];\n            labels.push(new LabelPoint(text, point, size, options));\n        }\n    } else if (geometry.type === \"Polygon\") {\n        let centroid = Geo.centroid(geometry.coordinates[0]);\n        labels.push(new LabelPoint(text, centroid, size, options));\n    } else if (geometry.type === \"MultiPolygon\") {\n        let centroid = Geo.multiCentroid(geometry.coordinates);\n        labels.push(new LabelPoint(text, centroid, size, options));\n    }\n\n    return labels;\n};\n","import Vector from '../../vector';\nimport Label from './label';\nimport OBB from '../../utils/obb';\n\nexport default class LabelLine extends Label {\n\n    constructor (text, size, lines, options) {\n        super(text, size, options);\n\n        this.segment_index = 0;\n        this.lines = lines;\n        this.update();\n    }\n\n    update () {\n        let segment = this.currentSegment();\n        this.angle = this.computeAngle();\n        this.position = [(segment[0][0] + segment[1][0]) / 2, (segment[0][1] + segment[1][1]) / 2];\n        this.aabb = this.computeAABB();\n    }\n\n    moveNextSegment () {\n        if (this.segment_index + 1 >= this.lines.length - 1) {\n            return false;\n        }\n\n        this.segment_index++;\n        this.update();\n\n        return true;\n    }\n\n    computeAngle () {\n        let segment = this.currentSegment();\n        let p0p1 = Vector.sub(segment[0], segment[1]);\n\n        p0p1 = Vector.normalize(p0p1);\n\n        let PI_2 = Math.PI / 2;\n        let theta = Math.atan2(p0p1[0], p0p1[1]) + PI_2;\n\n        if (theta > PI_2 || theta < -PI_2) {\n            theta += Math.PI;\n        }\n        theta %= Math.PI * 2;\n\n        return theta;\n    }\n\n    fitToSegment (should_fit = true) {\n        if (!should_fit) {\n            return true;\n        }\n\n        let segment = this.currentSegment();\n        let p0p1 = Vector.sub(segment[0], segment[1]);\n        let length = Vector.length(p0p1);\n\n        let label_length = this.size.text_size[0] * this.options.units_per_pixel;\n\n        if (label_length > length) {\n            // an exceed heurestic of 100% would let the label fit in any cases\n            let exceed = (1 - (length / label_length)) * 100;\n            return exceed < this.options.line_exceed;\n        }\n\n        return label_length < length;\n    }\n\n    currentSegment () {\n        let p1 = this.lines[this.segment_index];\n        let p2 = this.lines[this.segment_index + 1];\n\n        return [ p1, p2 ];\n    }\n\n    computeAABB () {\n        let upp = this.options.units_per_pixel;\n        let width = (this.size.text_size[0] + this.options.buffer[0] * 2) * upp;\n        let height = (this.size.text_size[1] + this.options.buffer[1] * 2) * upp;\n\n        // apply offset, x positive, y pointing down\n        let offset = Vector.rot(this.options.offset, this.angle);\n        let p = [\n            this.position[0] + (offset[0] * upp),\n            this.position[1] - (offset[1] * upp)\n        ];\n\n        // the angle of the obb is negative since it's the tile system y axis is pointing down\n        let obb = new OBB(p[0], p[1], -this.angle, width, height);\n        let aabb = obb.getExtent();\n        aabb.obb = obb;\n\n        return aabb;\n    }\n\n    moveInTile () {\n        let in_tile = false;\n        let fits_to_segment = this.fitToSegment();\n\n        // move this label until we found a line we can fit in\n        while (!in_tile && !fits_to_segment) {\n            if (!this.moveNextSegment()) {\n                // we can't move further in this line\n                break;\n            }\n\n            in_tile = this.inTileBounds();\n            fits_to_segment = this.fitToSegment();\n        }\n\n        return !in_tile || !fits_to_segment;\n    }\n\n    discard (aabbs) {\n        if (this.lines && !this.fitToSegment()) {\n            while (!this.fitToSegment()) {\n                if (!this.moveNextSegment()) {\n                    return true;\n                }\n            }\n        }\n\n        return super.discard(aabbs);\n    }\n\n}\n","export default class LabelOptions {\n\n    constructor ({ units_per_pixel, offset, line_exceed, move_in_tile, keep_in_tile, buffer }) {\n        this.buffer = buffer|| [0, 0];\n        this.keep_in_tile = (keep_in_tile != null) ? keep_in_tile : true;\n        this.move_in_tile = (move_in_tile != null) ? move_in_tile : true;\n        this.offset = offset || [0, 0];\n        this.line_exceed = (line_exceed != null) ? line_exceed : 80;\n        this.units_per_pixel = units_per_pixel;\n    }\n\n}\n","import Label from './label';\nimport Geo from '../../geo';\nimport OBB from '../../utils/obb';\n\nexport default class LabelPoint extends Label {\n\n    constructor (text, position, size, options) {\n        super(text, size, options);\n\n        this.position = position;\n        this.update();\n    }\n\n    update() {\n        this.aabb = this.computeAABB();\n    }\n\n    computeAABB () {\n        let width = (this.size.text_size[0] + this.options.buffer[0] * 2) * this.options.units_per_pixel;\n        let height = (this.size.text_size[1] + this.options.buffer[1] * 2) * this.options.units_per_pixel;\n\n        // apply offset, x positive, y pointing down\n        let p = [\n            this.position[0] + (this.options.offset[0] * this.options.units_per_pixel),\n            this.position[1] - (this.options.offset[1] * this.options.units_per_pixel)\n        ];\n\n        let obb = new OBB(p[0], p[1], 0, width, height);\n        let aabb = obb.getExtent();\n        aabb.obb = obb;\n\n        return aabb;\n    }\n\n    moveInTile () {\n        let updated = false;\n\n        if (this.aabb[0] < 0) {\n            this.position[0] += -this.aabb[0];\n            updated = true;\n        }\n\n        if (this.aabb[2] >= Geo.tile_scale) {\n            this.position[0] -= this.aabb[2] - Geo.tile_scale + 1;\n            updated = true;\n        }\n\n        if (this.aabb[3] > 0) {\n            this.position[1] -= this.aabb[3];\n            updated = true;\n        }\n\n        if (this.aabb[1] <= -Geo.tile_scale) {\n            this.position[1] -= this.aabb[1] + Geo.tile_scale - 1;\n            updated = true;\n        }\n\n        if (updated) {\n            this.aabb = this.computeAABB();\n        }\n\n        return !this.inTileBounds();\n    }\n\n}\n","// Text rendering style\n\nimport Builders from '../builders';\nimport Texture from '../../gl/texture';\nimport WorkerBroker from '../../utils/worker_broker';\nimport Utils from '../../utils/utils';\nimport {Points} from '../points/points';\nimport LabelBuilder from './label_builder';\nimport FeatureLabel from './feature_label';\nimport LabelOptions from './label_options';\nimport {StyleParser} from '../style_parser';\n\nimport log from 'loglevel';\n\nexport let TextStyle = Object.create(Points);\n\nObject.assign(TextStyle, {\n    name: 'text',\n    super: Points,\n    built_in: true,\n    selection: false, // no feature selection for text by default\n\n    init() {\n\n        this.super.init.apply(this, arguments);\n\n        // Provide a hook for this object to be called from worker threads\n        this.main_thread_target = 'TextStyle-' + this.name;\n        if (Utils.isMainThread) {\n            WorkerBroker.addTarget(this.main_thread_target, this);\n        }\n\n        // Point style (parent class) requires texturing to be turned on\n        // (labels are always drawn with textures)\n        this.defines.TANGRAM_POINT_TEXTURE = true;\n\n        // Manually un-multiply alpha, because Canvas text rasterization is pre-multiplied\n        // See https://github.com/tangrams/tangram/issues/179\n        this.defines.TANGRAM_UNMULTIPLY_ALPHA = true;\n\n        // default font style\n        this.default_font_style = {\n            style: 'normal',\n            weight: null,\n            size: '12px',\n            family: 'Helvetica',\n            fill: 'white'\n        };\n\n        this.reset();\n    },\n\n    reset() {\n        this.super.reset.call(this);\n        this.texts = {}; // unique texts, keyed by tile\n        this.textures = {};\n        this.canvas = {};\n        this.aabbs = {};\n        this.features = {};\n        this.feature_labels = {};\n        this.feature_style_key = {};\n    },\n\n    // Called on main thread to release tile-specific resources\n    freeTile (tile) {\n        delete this.texts[tile];\n        delete this.textures[tile];\n        delete this.canvas[tile];\n        delete this.aabbs[tile];\n        // cleanup stored features for this tile\n        for (let key in this.features) {\n            let features = this.features[key];\n            for (let i = 0; i < features.length; ++i) {\n                if (features[i].tile_key === tile) {\n                    delete features[i];\n                }\n            }\n            if (Object.keys(features).length === 0) {\n                delete this.features[key];\n            }\n        }\n        delete this.feature_labels[tile];\n        delete this.feature_style_key[tile];\n    },\n\n    // Set font style params for canvas drawing\n    setFont (tile, { font_css, fill, stroke, stroke_width, px_size, px_logical_size }) {\n        this.px_size = parseInt(px_size);\n        this.px_logical_size = parseInt(px_logical_size);\n        this.text_buffer = 8; // pixel padding around text\n        let ctx = this.canvas[tile].context;\n\n        ctx.font = font_css;\n        if (stroke) {\n            ctx.strokeStyle = stroke;\n            ctx.lineWidth = stroke_width;\n        }\n        else {\n            ctx.strokeStyle = null;\n            ctx.lineWidth = 0;\n        }\n        ctx.fillStyle = fill;\n        ctx.miterLimit = 2;\n    },\n\n    // Width and height of text based on current font style\n    textSize (text, tile, transform) {\n        let str = FeatureLabel.applyTextTransform(text, transform);\n        let ctx = this.canvas[tile].context;\n        let px_size = this.px_size;\n        let px_logical_size = this.px_logical_size;\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n\n        let str_width = ctx.measureText(str).width;\n        let text_size = [\n            str_width / Utils.device_pixel_ratio,\n            this.px_size / Utils.device_pixel_ratio\n        ];\n\n        let texture_text_size = [\n            Math.ceil(str_width) + buffer * 2,\n            this.px_size + buffer * 2\n        ];\n\n        return { text_size, texture_text_size, px_size, px_logical_size };\n    },\n\n    // Draw text at specified location, adjusting for buffer and baseline\n    drawText (text, [x, y], tile, stroke, transform) {\n        let str = FeatureLabel.applyTextTransform(text, transform);\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n        if (stroke) {\n            this.canvas[tile].context.strokeText(str, x + buffer, y + buffer + this.px_size);\n        }\n        this.canvas[tile].context.fillText(str, x + buffer, y + buffer + this.px_size);\n    },\n\n    setTextureTextPositions (texts) {\n        // Find widest label and sum of all label heights\n        let widest = 0, height = 0;\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                let size = text_info.size.texture_text_size;\n\n                text_info.position = [0, height];\n\n                if (size[0] > widest) {\n                    widest = size[0];\n                }\n\n                height += size[1];\n            }\n        }\n\n        return [ widest, height ];\n    },\n\n    getTextSizes (tile, texts) {\n        // create a canvas\n        if(!this.canvas[tile]) {\n            let canvas = document.createElement('canvas');\n            this.canvas[tile] = {\n                canvas: canvas,\n                context: canvas.getContext('2d')\n            };\n        }\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_style = text_infos[text].text_style;\n                // update text sizes\n                this.setFont(tile, text_style); // TODO: only set once above\n                text_infos[text].size = this.textSize(text, tile, text_style.transform);\n            }\n        }\n\n        return Promise.resolve(texts);\n    },\n\n    rasterize (tile, texts, texture_size) {\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let info = text_infos[text];\n\n                this.setFont(tile, info.text_style); // TODO: only set once above\n                this.drawText(text, info.position, tile, info.text_style.stroke, info.text_style.transform);\n\n                info.texcoords = Builders.getTexcoordsForSprite(\n                    info.position,\n                    info.size.texture_text_size,\n                    texture_size\n                );\n            }\n        }\n    },\n\n    // Called on main thread from worker, to create atlas of labels for a tile\n    addTexts (tile, texts) {\n        if (!this.canvas[tile]) {\n            return Promise.resolve({});\n        }\n\n        let texture_size = this.setTextureTextPositions(texts);\n        let context = this.canvas[tile].context;\n\n        log.trace(`text summary for tile ${tile}: fits in ${texture_size[0]}x${texture_size[1]}px`);\n\n        // update the canvas \"context\"\n        this.canvas[tile].canvas.width = texture_size[0];\n        this.canvas[tile].canvas.height = texture_size[1];\n        context.clearRect(0, 0, texture_size[0], texture_size[1]);\n\n        // create a texture\n        let texture = 'labels-' + tile + '-' + (TextStyle.texture_id++);\n        this.textures[tile] = new Texture(this.gl, texture);\n\n        // ask for rasterization for the text set\n        this.rasterize(tile, texts, texture_size);\n\n        this.textures[tile].setCanvas(this.canvas[tile].canvas, {\n            filtering: 'linear',\n            UNPACK_PREMULTIPLY_ALPHA_WEBGL: true\n        });\n\n        // we don't need tile canvas/texture once it has been copied to to GPU\n        delete this.textures[tile];\n        delete this.canvas[tile];\n\n        return Promise.resolve({ texts, texture });\n    },\n\n    // Override\n    startData (tile) {\n        let tile_data = this.super.startData.apply(this, arguments);\n        tile_data.queue = [];\n        return tile_data;\n    },\n\n    createLabels (tile, texts) {\n        let labels_priorities = {};\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                text_info.ref = 0;\n\n                let hash = Utils.hashString(tile + style + text);\n\n                if (!this.features[hash]) {\n                    continue;\n                }\n\n                let label_features = this.features[hash];\n\n                for (let i = 0; i < label_features.length; ++i) {\n                    let label_feature = label_features[i];\n                    let feature = label_feature.feature;\n                    let options = new LabelOptions({\n                        units_per_pixel: text_info.units_per_pixel,\n                        offset: text_info.offset,\n                        buffer: text_info.buffer,\n                        line_exceed: text_info.line_exceed\n                    });\n\n                    let labels = LabelBuilder.buildFromGeometry(text, text_info.size, feature.geometry, options);\n\n                    for (let i = 0; i < labels.length; ++i) {\n                        let label = labels[i];\n                        let area = label.area;\n\n                        labels_priorities[text_info.priority] = labels_priorities[text_info.priority] || [];\n                        labels_priorities[text_info.priority].push({ style, feature, label, area });\n                    }\n                }\n            }\n        }\n\n        // sort by area size if defined\n        for (let p = 0; p < labels_priorities.length; ++p) {\n            if (!labels_priorities[p]) {\n                continue;\n            }\n\n            labels_priorities[p].sort((e1, e2) => {\n                if (e1.area && e2.area) {\n                    return e1.area < e2.area;\n                } else {\n                    return false;\n                }\n            });\n        }\n\n        return labels_priorities;\n    },\n\n    discardLabels (tile, labels, texts) {\n        this.aabbs[tile] = [];\n        this.feature_labels[tile] = new Map();\n\n        // Process labels by priority\n        let priorities = Object.keys(labels).sort((a, b) => a - b);\n        for (let priority of priorities) {\n            if (!labels[priority]) {\n                continue;\n            }\n\n            for (let i = 0; i < labels[priority].length; i++) {\n                let { style, feature, label } = labels[priority][i];\n\n                if (!label.discard(this.aabbs[tile])) {\n                    if (!this.feature_labels[tile].has(feature)) {\n                        this.feature_labels[tile].set(feature, []);\n                    }\n                    this.feature_labels[tile].get(feature).push(label);\n                    texts[style][label.text].ref++;\n                }\n            }\n        }\n\n        for (let style in texts) {\n            for (let text in texts[style]) {\n                if (texts[style][text].ref < 1) {\n                    delete texts[style][text];\n                }\n            }\n        }\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n            // No labels for this style\n            if (Object.keys(text_infos).length === 0) {\n                delete texts[style];\n            }\n        }\n    },\n\n    // Override\n    endData (tile) {\n        // Count collected text\n        let count;\n        let tile_data = this.tile_data[tile];\n\n        if (tile_data.queue.length > 0) {\n            count = Object.keys(this.texts[tile]||{}).length;\n            log.trace(`# texts for tile ${tile}: ${count}`);\n        }\n        if (!count) {\n            return Promise.resolve();\n        }\n\n        // first call to main thread, ask for text pixel sizes\n        return WorkerBroker.postMessage(this.main_thread_target, 'getTextSizes', tile, this.texts[tile]).then(texts => {\n            if (!texts) {\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            }\n\n            let labels = this.createLabels(tile, texts);\n            if (!labels) {\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            }\n\n            this.discardLabels(tile, labels, texts);\n\n            // No labels for this tile\n            if (Object.keys(texts).length === 0) {\n                this.freeTile(tile);\n                WorkerBroker.postMessage(this.main_thread_target, 'freeTile', tile);\n                // early exit\n                return;\n            }\n\n            // second call to main thread, for rasterizing the set of texts\n            return WorkerBroker.postMessage(this.main_thread_target, 'addTexts', tile, texts).then(({ texts, texture }) => {\n                if (texts) {\n                    this.texts[tile] = texts;\n\n                    // Attach tile-specific label atlas to mesh as a texture uniform\n                    tile_data.uniforms = { u_texture: texture };\n                    tile_data.textures = [texture]; // assign texture ownership to tile - TODO: implement in VBOMesh\n\n                    // Build queued features\n                    tile_data.queue.forEach(q => this.super.addFeature.apply(this, q));\n                    tile_data.queue = [];\n                }\n\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            });\n        });\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, rule, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        // Collect text\n        let text;\n        let source = rule.text_source || 'name';\n\n        if (typeof source === 'string') {\n            text = feature.properties[source];\n        } else if (typeof source === 'function') {\n            text = source(context);\n        }\n\n        if (text) {\n            feature.text = text;\n\n            if (!this.texts[tile.key]) {\n                this.texts[tile.key] = this.texts[tile.key] || {};\n            }\n\n            // features stored by hash for later use from main thread (tile / text / style)\n            let label_feature = new FeatureLabel(feature, rule, context, text, tile, this.default_font_style);\n            let feature_hash = label_feature.getHash();\n\n            if (!label_feature.style) {\n                return;\n            }\n\n            let style_key = label_feature.style_key;\n            this.feature_style_key[tile.key] = this.feature_style_key[tile.key] || new Map();\n            this.feature_style_key[tile.key].set(feature, style_key);\n\n            if (!this.texts[tile.key][style_key]) {\n                this.texts[tile.key][style_key] = {};\n            }\n\n            // label priority (lower is higher)\n            let priority = rule.priority;\n            if (priority !== undefined) {\n                // if priority is a number, use it as-is, otherwise, check type\n                // if (typeof priority === 'string') {\n                //     priority = feature.properties[priority]; // get priority from feature property\n                // }\n                // else if (typeof priority === 'function') {\n                if (typeof priority === 'function') {\n                    priority = priority(context);\n                }\n            }\n            else {\n                priority = -1 >>> 0; // default to max priority value if none set\n            }\n\n            // label offset in pixel (applied in screen space)\n            let offset = rule.offset || [0, 0];\n            offset[0] = parseFloat(offset[0]);\n            offset[1] = parseFloat(offset[1]); // y-point down\n\n            // label buffer in pixel\n            let buffer = rule.buffer;\n            if (buffer != null) {\n                if (!Array.isArray(buffer)) {\n                    buffer = [buffer, buffer]; // buffer can be 1D or 2D\n                }\n\n                buffer[0] = parseFloat(buffer[0]);\n                buffer[1] = parseFloat(buffer[1]);\n            }\n\n            // label line exceed percentage\n            let line_exceed;\n            if (rule.line_exceed && rule.line_exceed.substr(-1) === '%') {\n                line_exceed = rule.line_exceed.substr(0,rule.line_exceed.length-1);\n            }\n\n            if (!this.texts[tile.key][style_key][text]) {\n                this.texts[tile.key][style_key][text] = {\n                    text_style: label_feature.style,\n                    units_per_pixel: tile.units_per_pixel,\n                    priority,\n                    offset,\n                    buffer,\n                    line_exceed,\n                    ref: 0\n                };\n            }\n\n            // add the label feature\n            this.features = this.features || {};\n            this.features[feature_hash] = this.features[feature_hash] || [];\n            this.features[feature_hash].push(label_feature);\n\n            if (!this.tile_data[tile.key]) {\n                this.startData(tile.key);\n            }\n            this.tile_data[tile.key].queue.push([feature, rule, context]);\n        }\n    },\n\n    build (style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n\n        for (let i in style.labels) {\n            let label = style.labels[i];\n\n            this.buildQuad(\n                [label.position],\n                label.size.texture_text_size,\n                Utils.radToDeg(label.angle) || 0, vertex_data,\n                vertex_template, label.options.offset\n            );\n        }\n    },\n\n    buildLines (lines, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    buildPoints (points, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    buildPolygons (points, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        let text = feature.text;\n\n        let style = this.feature_style;\n        let tile = context.tile.key;\n        let style_key = this.feature_style_key[tile].get(feature);\n        let text_info = this.texts[tile] && this.texts[tile][style_key] && this.texts[tile][style_key][text];\n\n        if (!text_info || !this.feature_labels[tile].has(feature)) {\n            return;\n        }\n\n        this.texcoord_scale = text_info.texcoords;\n        style.text = text;\n        style.labels = this.feature_labels[tile].get(feature);\n\n        // TODO: point style (parent class) requires a color, setting it to white for now,\n        // but could be made conditional in the vertex layout to save space\n        style.color = TextStyle.white;\n\n        // tell the point style (base class) that we want to render polygon labels at the polygon's centroid\n        style.centroid = true;\n\n        // points can be placed off the ground\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n\n        return style;\n    }\n\n});\n\nTextStyle.texture_id = 0;\nTextStyle.white = [1, 1, 1, 1];\n","/*global Tile */\nimport Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport WorkerBroker from './utils/worker_broker';\nimport Texture from './gl/texture';\n\nimport log from 'loglevel';\n\nexport default class Tile {\n\n    /**\n        Tile\n        @constructor\n        Required properties:\n        coords: object with {x, y, z} properties identifying tile coordinate location\n        worker: web worker to handle tile construction\n    */\n    constructor({ coords, source, worker, style_zoom }) {\n        Object.assign(this, {\n            coords: {\n                x: null,\n                y: null,\n                z: null\n            },\n            debug: {},\n            loading: false,\n            loaded: false,\n            error: null,\n            worker: null,\n            generation: null,\n            visible: false,\n            center_dist: 0\n        });\n\n        this.worker = worker;\n        this.source = source;\n        this.style_zoom = style_zoom; // zoom level to be used for styling\n\n        this.coords = coords;\n        this.coords = Tile.overZoomedCoordinate(this.coords, this.source.max_zoom);\n        this.coord_key = Tile.coordKey(this.coords);\n        this.key = Tile.key(this.coords, this.source, this.style_zoom);\n        this.min = Geo.metersForTile(this.coords);\n        this.max = Geo.metersForTile({x: this.coords.x + 1, y: this.coords.y + 1, z: this.coords.z }),\n        this.span = { x: (this.max.x - this.min.x), y: (this.max.y - this.min.y) };\n        this.bounds = { sw: { x: this.min.x, y: this.max.y }, ne: { x: this.max.x, y: this.min.y } };\n\n        // Units per pixel needs to account for over-zooming\n        this.units_per_pixel = Geo.units_per_pixel;\n        if (this.style_zoom > this.coords.z) {\n            this.units_per_pixel /= Math.pow(2, this.style_zoom - this.coords.z);\n        }\n\n        this.meshes = {}; // renderable VBO meshes keyed by style\n        this.textures = []; // textures that the tile owns (labels, etc.)\n    }\n\n    static create(spec) {\n        return new Tile(spec);\n    }\n\n    static coordKey({x, y, z}) {\n        return [x, y, z].join('/');\n    }\n\n    static key (coords, source, style_zoom) {\n        coords = Tile.overZoomedCoordinate(coords, source.max_zoom);\n        return [source.name, style_zoom, coords.x, coords.y, coords.z].join('/');\n    }\n\n    static coordinateAtZoom({x, y, z}, zoom) {\n        if (z !== zoom) {\n            let zscale = Math.pow(2, z - zoom);\n            x = Math.floor(x / zscale);\n            y = Math.floor(y / zscale);\n        }\n        return {x, y, z: zoom};\n    }\n\n    static isChild(parent, child) {\n        if (child.z > parent.z) {\n            let {x, y} = Tile.coordinateAtZoom(child, parent.z);\n            return (parent.x === x && parent.y === y);\n        }\n        return false;\n    }\n\n    static overZoomedCoordinate({x, y, z}, max_zoom) {\n        if (max_zoom !== undefined && z > max_zoom) {\n            return Tile.coordinateAtZoom({x, y, z}, max_zoom);\n        }\n        return {x, y, z};\n    }\n\n    // Sort a set of tile instances (which already have a distance from center tile computed)\n    static sort(tiles) {\n        return tiles.sort((a, b) => {\n            let ad = a.center_dist;\n            let bd = b.center_dist;\n            return (bd > ad ? -1 : (bd === ad ? 0 : 1));\n        });\n    }\n\n    freeResources() {\n        if (this.meshes) {\n            for (let m in this.meshes) {\n                this.meshes[m].destroy();\n            }\n        }\n\n        if (this.textures) {\n            for (let t of this.textures) {\n                let texture = Texture.textures[t];\n                if (texture) {\n                    texture.destroy();\n                }\n            }\n        }\n\n        this.meshes = {};\n        this.textures = [];\n    }\n\n    destroy() {\n        this.workerMessage('removeTile', this.key);\n        this.freeResources();\n        this.worker = null;\n    }\n\n    buildAsMessage() {\n        return {\n            key: this.key,\n            coord_key: this.coord_key,\n            source: this.source.name,\n            coords: this.coords,\n            min: this.min,\n            max: this.max,\n            units_per_pixel: this.units_per_pixel,\n            style_zoom: this.style_zoom,\n            generation: this.generation,\n            debug: this.debug\n        };\n    }\n\n    workerMessage (...message) {\n        return WorkerBroker.postMessage(this.worker, ...message);\n    }\n\n    build(generation) {\n        this.generation = generation;\n        if (!this.loaded) {\n            this.loading = true;\n        }\n        return this.workerMessage('buildTile', { tile: this.buildAsMessage() }).catch(e => { throw e; });\n    }\n\n    // Process geometry for tile - called by web worker\n    // Returns a set of tile keys that should be sent to the main thread (so that we can minimize data exchange between worker and main thread)\n    static buildGeometry (tile, layers, rules, styles) {\n        tile.debug.rendering = +new Date();\n        tile.debug.features = 0;\n\n        let data = tile.source_data;\n\n        // Treat top-level style rules as 'layers'\n        for (let layer_name in layers) {\n            let layer = layers[layer_name];\n            // Skip layers with no data source defined\n            if (!layer.data) {\n                log.warn(`Layer ${layer} was defined without a geometry data source and will not be rendered.`);\n                continue;\n            }\n\n            // Source names don't match\n            if (layer.data.source !== tile.source) {\n                continue;\n            }\n\n            // Get data for one or more layers from source\n            let source_layers = Tile.getDataForSource(data, layer.data, layer_name);\n            if (source_layers.length === 0) {\n                continue;\n            }\n\n            // Render features in layer\n            source_layers.forEach(source_layer => {\n                let geom = source_layer.geom;\n                if (!geom) {\n                    return;\n                }\n\n                for (let f = 0; f < geom.features.length; f++) {\n                    let feature = geom.features[f];\n                    let context = StyleParser.getFeatureParseContext(feature, tile);\n                    context.layer = source_layer.layer; // add data source layer name\n\n                    // Get draw groups for this feature\n                    let layer_rules = rules[layer_name];\n                    let draw_groups = layer_rules.buildDrawGroups(context, true);\n                    if (!draw_groups) {\n                        continue;\n                    }\n\n                    // Render draw groups\n                    for (let group_name in draw_groups) {\n                        let group = draw_groups[group_name];\n                        if (!group.visible) {\n                            continue;\n                        }\n\n                        // Add to style\n                        let style_name = group.style || group_name;\n                        let style = styles[style_name];\n\n                        if (!style) {\n                            log.warn(`Style '${style_name}' not found for rule in layer '${layer_name}':`, group, feature);\n                            continue;\n                        }\n\n                        context.properties = group.properties; // add rule-specific properties to context\n\n                        style.addFeature(feature, group, context);\n\n                        context.properties = null; // clear group-specific properties\n                    }\n\n                    tile.debug.features++;\n                }\n            });\n        }\n        tile.debug.rendering = +new Date() - tile.debug.rendering;\n\n        // Finalize array buffer for each render style\n        let tile_styles = StyleManager.stylesForTile(tile.key);\n        tile.mesh_data = {};\n        let queue = [];\n        for (let style_name of tile_styles) {\n            let style = styles[style_name];\n            queue.push(style.endData(tile.key).then((style_data) => {\n                if (style_data) {\n                    tile.mesh_data[style_name] = {\n                        vertex_data: style_data.vertex_data,\n                        uniforms: style_data.uniforms,\n                        textures: style_data.textures\n                    };\n                }\n            }));\n        }\n\n        return Promise.all(queue).then(() => {\n            // Return keys to be transfered to main thread\n            return ['mesh_data'];\n        });\n    }\n\n    /**\n        Retrieves geometry from a tile according to a data source definition\n        Returns an array of objects with:\n            layer: source layer name\n            geom: GeoJSON FeatureCollection\n    */\n    static getDataForSource (source_data, source_config, default_layer = null) {\n        var layers = [];\n\n        if (source_config != null) {\n            // If no layer specified, and a default source layer exists\n            if (!source_config.layer && source_data.layers._default) {\n                layers.push({\n                    layer: '_default',\n                    geom: source_data.layers._default\n                });\n            }\n            // If no layer specified, and a default requested layer exists\n            else if (!source_config.layer && default_layer) {\n                layers.push({\n                    layer: default_layer,\n                    geom: source_data.layers[default_layer]\n                });\n            }\n            // If a layer is specified by name, use it\n            else if (typeof source_config.layer === 'string') {\n                layers.push({\n                    layer: source_config.layer,\n                    geom: source_data.layers[source_config.layer]\n                });\n            }\n            // If multiple layers are specified by name, combine them\n            else if (Array.isArray(source_config.layer)) {\n                source_config.layer.forEach(layer => {\n                    if (source_data.layers[layer] && source_data.layers[layer].features) {\n                        layers.push({\n                            layer,\n                            geom: source_data.layers[layer]\n                        });\n                    }\n                });\n            }\n            // Assemble a custom layer via a function, which is called with all source layers\n            else if (typeof source_config.layer === 'function') {\n                layers.push({\n                    geom: source_config.layer(source_data.layers)\n                    // custom layer has no name\n                });\n            }\n        }\n\n        return layers;\n    }\n\n    /**\n       Called on main thread when a web worker completes processing\n       for a single tile.\n    */\n    buildMeshes(styles) {\n        if (this.error) {\n            return;\n        }\n\n        // Cleanup existing VBOs\n        this.freeResources();\n\n        // Debug\n        this.debug.geometries = 0;\n        this.debug.buffer_size = 0;\n\n        // Create VBOs\n        let mesh_data = this.mesh_data;\n        if (mesh_data) {\n            for (var s in mesh_data) {\n                if (mesh_data[s].vertex_data) {\n                    this.debug.buffer_size += mesh_data[s].vertex_data.byteLength;\n                    if (!styles[s]) {\n                        log.warn(`Could not create mesh because style '${s}' not found, for tile ${this.key}, aborting tile`);\n                        this.meshes = {};\n                        break;\n                    }\n                    this.meshes[s] = styles[s].makeMesh(mesh_data[s].vertex_data, mesh_data[s]);\n                    this.debug.geometries += this.meshes[s].geometry_count;\n                }\n\n                // Assign ownership to textures if needed\n                if (mesh_data[s].textures) {\n                    this.textures.push(...mesh_data[s].textures);\n                }\n            }\n        }\n\n        this.debug.geom_ratio = (this.debug.geometries / this.debug.features).toFixed(1);\n        this.mesh_data = null; // TODO: might want to preserve this for rebuilding geometries when styles/etc. change?\n        this.printDebug();\n    }\n\n    /**\n        Called on main thread when web worker completes processing, but tile has since been discarded\n        Frees resources that would have been transferred to the tile object.\n        Static method because the tile object no longer exists (the tile data returned by the worker is passed instead).\n    */\n    static abortBuild (tile) {\n        if (tile.mesh_data) {\n            for (let s in tile.mesh_data) {\n                let textures = tile.mesh_data[s].textures;\n                if (textures) {\n                    for (let t of textures) {\n                        let texture = Texture.textures[t];\n                        if (texture) {\n                            log.trace(`destroying texture ${t} for tile ${tile.key}`);\n                            texture.destroy();\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    printDebug () {\n        log.debug(`Tile: debug for ${this.key}: [  ${JSON.stringify(this.debug)} ]`);\n    }\n\n    update(scene) {\n        let coords = this.coords;\n        if (coords.z !== scene.center_tile.z) {\n            coords = Tile.coordinateAtZoom(coords, scene.center_tile.z);\n        }\n        this.center_dist = Math.abs(scene.center_tile.x - coords.x) + Math.abs(scene.center_tile.y - coords.y);\n    }\n\n    // Slice a subset of keys out of a tile\n    // Includes a minimum set of pre-defined keys for load state, debug. etc.\n    // We use this to send a subset of the tile back to the main thread, to minimize unnecessary data transfer\n    // (e.g. very large items like feature geometry are not needed on the main thread)\n    static slice (tile, keys) {\n        let keep = [\n            'key',\n            'loading',\n            'loaded',\n            'generation',\n            'error',\n            'debug'\n        ];\n        if (Array.isArray(keys)) {\n            keep.push(...keys);\n        }\n\n        // Build the tile subset\n        var tile_subset = {};\n        for (let key of keep) {\n            tile_subset[key] = tile[key];\n        }\n\n        return tile_subset;\n    }\n\n    /**\n        Called on worker to cancel loading\n        Static method because the worker only has object representations of tile data, there is no\n        tile instance created yet.\n    */\n    static cancel(tile) {\n        if (tile) {\n            if (tile.source_data && tile.source_data.request) {\n                tile.source_data.request.abort();\n            }\n            Tile.abortBuild(tile);\n        }\n    }\n\n    merge(other) {\n        for (var key in other) {\n            if (key !== 'key') {\n                this[key] = other[key];\n            }\n        }\n        return this;\n    }\n\n}\n","import Tile from './tile';\nimport Utils from './utils/utils';\n\nimport log from 'loglevel';\n\nvar TileManager;\n\nexport default TileManager = {\n\n    init(scene) {\n        this.scene = scene;\n        this.tiles = {};\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.building_tiles = null;\n    },\n\n    destroy() {\n        this.forEachTile(tile => tile.destroy());\n        this.tiles = {};\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.scene = null;\n    },\n\n    keepTile(tile) {\n        this.tiles[tile.key] = tile;\n    },\n\n    hasTile(key) {\n        return this.tiles[key] !== undefined;\n    },\n\n    forgetTile(key) {\n        delete this.tiles[key];\n        this.tileBuildStop(key);\n    },\n\n    // Remove a single tile\n    removeTile(key) {\n        log.trace(`tile unload for ${key}`);\n\n        var tile = this.tiles[key];\n\n        if (tile != null) {\n            tile.destroy();\n        }\n\n        this.forgetTile(tile.key);\n        this.scene.requestRedraw();\n    },\n\n    // Run a function on each tile\n    forEachTile(func) {\n        for (let t in this.tiles) {\n            func(this.tiles[t]);\n        }\n    },\n\n    // Remove tiles that pass a filter condition\n    removeTiles(filter) {\n        let remove_tiles = [];\n        for (let t in this.tiles) {\n            let tile = this.tiles[t];\n            if (filter(tile)) {\n                remove_tiles.push(t);\n            }\n        }\n        for (let r=0; r < remove_tiles.length; r++) {\n            let key = remove_tiles[r];\n            this.removeTile(key);\n        }\n    },\n\n    updateTilesForView() {\n        // Find visible tiles and load new ones\n        this.visible_coords = {};\n        let tile_coords = this.scene.findVisibleTileCoordinates();\n        for (let coords of tile_coords) {\n            this.queueCoordinate(coords);\n            this.visible_coords[Tile.coordKey(coords)] = coords;\n        }\n\n        // Remove tiles too far outside of view\n        this.scene.pruneTileCoordinatesForView(); // TODO: return list to prune?\n\n        this.forEachTile(tile => {\n            this.updateVisibility(tile);\n            tile.update(this.scene);\n        });\n    },\n\n    updateVisibility(tile) {\n        if (tile.style_zoom !== this.scene.tile_zoom) {\n            tile.visible = false;\n            return;\n        }\n\n        if (this.visible_coords[tile.coord_key]) {\n            tile.visible = true;\n        }\n        else {\n            // brute force\n            for (let key in this.visible_coords) {\n                if (Tile.isChild(tile.coords, this.visible_coords[key])) {\n                    tile.visible = true;\n                    return;\n                }\n            }\n\n            tile.visible = false;\n        }\n    },\n\n    getRenderableTiles() {\n        let tiles = [];\n        for (let t in this.tiles) {\n            let tile = this.tiles[t];\n            if (tile.visible && tile.loaded) {\n                tiles.push(tile);\n            }\n        }\n        return tiles;\n    },\n\n    // Queue a tile for load\n    queueCoordinate(coords) {\n        this.queued_coords[this.queued_coords.length] = coords;\n    },\n\n    // Load all queued tiles\n    loadQueuedCoordinates() {\n        if (this.queued_coords.length === 0) {\n            return;\n        }\n\n        // Sort queued tiles from center tile\n        this.queued_coords.sort((a, b) => {\n            let ad = Math.abs(this.scene.center_tile.x - a.x) + Math.abs(this.scene.center_tile.y - a.y);\n            let bd = Math.abs(this.scene.center_tile.x - b.x) + Math.abs(this.scene.center_tile.y - b.y);\n            return (bd > ad ? -1 : (bd === ad ? 0 : 1));\n        });\n        this.queued_coords.forEach(coords => this.loadCoordinate(coords));\n        this.queued_coords = [];\n    },\n\n    // Load all tiles to cover a given logical tile coordinate\n    loadCoordinate(coords) {\n        // Skip if not at current scene zoom\n        if (coords.z !== this.scene.center_tile.z) {\n            return;\n        }\n\n        // Determine necessary tiles for each source\n        for (let source of Utils.values(this.scene.sources)) {\n            if (!source.tiled) {\n                continue;\n            }\n\n            let key = Tile.key(coords, source, this.scene.tile_zoom);\n            if (!this.hasTile(key)) {\n                let tile = Tile.create({\n                    source,\n                    coords,\n                    // max_zoom: this.scene.findMaxZoom(), // TODO: replace with better max zoom handling\n                    worker: this.scene.nextWorker(),\n                    style_zoom: this.scene.styleZoom(coords.z) // TODO: replace?\n                });\n\n                this.keepTile(tile);\n                this.buildTile(tile);\n            }\n        }\n    },\n\n    // Sort and build a list of tiles\n    buildTiles(tiles) {\n        Tile.sort(tiles).forEach(tile => this.buildTile(tile));\n        this.checkBuildQueue();\n    },\n\n    buildTile(tile) {\n        this.tileBuildStart(tile.key);\n        this.updateVisibility(tile);\n        tile.update(this.scene);\n        tile.build(this.scene.generation)\n            .then(message => this.buildTileCompleted(message))\n            .catch(() => {\n                this.forgetTile(tile.key);\n                Tile.abortBuild(tile);\n            });\n    },\n\n    // Called on main thread when a web worker completes processing for a single tile (initial load, or rebuild)\n    buildTileCompleted({ tile }) {\n        // Removed this tile during load?\n        if (this.tiles[tile.key] == null) {\n            log.trace(`discarded tile ${tile.key} in TileManager.buildTileCompleted because previously removed`);\n            Tile.abortBuild(tile);\n            this.scene.updateBounds();\n        }\n        // Built with an outdated scene configuration?\n        else if (tile.generation !== this.scene.generation) {\n            log.debug(`discarded tile ${tile.key} in TileManager.buildTileCompleted because built with ` +\n                `scene config gen ${tile.generation}, current ${this.scene.generation}`);\n            this.forgetTile(tile.key);\n            Tile.abortBuild(tile);\n            this.scene.updateBounds();\n        }\n        else {\n            // Update tile with properties from worker\n            if (this.tiles[tile.key]) {\n                tile = this.tiles[tile.key].merge(tile);\n            }\n\n            this.updateVisibility(tile);\n            tile.update(this.scene);\n            tile.buildMeshes(this.scene.styles);\n            this.scene.requestRedraw();\n        }\n\n        this.tileBuildStop(tile.key);\n    },\n\n    // Track tile build state\n    tileBuildStart(key) {\n        this.building_tiles = this.building_tiles || {};\n        this.building_tiles[key] = true;\n        log.trace(`tileBuildStart for ${key}: ${Object.keys(this.building_tiles).length}`);\n    },\n\n    tileBuildStop(key) {\n        // Done building?\n        if (this.building_tiles) {\n            log.trace(`tileBuildStop for ${key}: ${Object.keys(this.building_tiles).length}`);\n            delete this.building_tiles[key];\n            this.checkBuildQueue();\n        }\n    },\n\n    // Check status of tile building queue and notify scene when we're done\n    checkBuildQueue() {\n        if (!this.building_tiles || Object.keys(this.building_tiles).length === 0) {\n            this.building_tiles = null;\n            this.scene.tileManagerBuildDone();\n        }\n    },\n\n    // Sum of a debug property across tiles\n    getDebugSum(prop, filter) {\n        var sum = 0;\n        for (var t in this.tiles) {\n            if (this.tiles[t].debug[prop] != null && (typeof filter !== 'function' || filter(this.tiles[t]) === true)) {\n                sum += this.tiles[t].debug[prop];\n            }\n        }\n        return sum;\n    },\n\n    // Average of a debug property across tiles\n    getDebugAverage(prop, filter) {\n        return this.getDebugSum(prop, filter) / Object.keys(this.tiles).length;\n    }\n\n};\n","\n\nexport class MethodNotImplemented extends Error {\n    constructor(methodName) {\n        super();\n        this.name    = 'MethodNotImplemented';\n        this.message = 'Method ' + methodName + ' must be implemented in subclass';\n    }\n}\n","import Vector from '../vector';\n\nexport default class OBB {\n\n    constructor (x, y, a, w, h) {\n        this.dimension = [w, h];\n        this.angle = a;\n        this.centroid = [x, y];\n        this.quad = [];\n        this.axes = [];\n\n        this.update();\n    }\n\n    move (px, py) {\n    \tthis.centroid = [px, py];\n\n    \tthis.update();\n    }\n\n    getExtent () {\n    \tlet inf = 1e6;\n    \tlet aabb = [inf, inf, -inf, -inf];\n\n    \tfor (let i = 0; i < 4; ++i) {\n            aabb[0] = Math.min(this.quad[i][0], aabb[0]);\n            aabb[1] = Math.min(this.quad[i][1], aabb[1]);\n            aabb[2] = Math.max(this.quad[i][0], aabb[2]);\n            aabb[3] = Math.max(this.quad[i][1], aabb[3]);\n    \t}\n\n    \treturn aabb;\n    }\n\n    perpAxes () {\n    \tthis.axes[0] = Vector.normalize(Vector.sub(this.quad[2], this.quad[3]));\n    \tthis.axes[1] = Vector.normalize(Vector.sub(this.quad[2], this.quad[1]));\n    }\n\n    update () {\n    \tlet x = [ Math.cos(this.angle), Math.sin(this.angle)];\n    \tlet y = [-Math.sin(this.angle), Math.cos(this.angle)];\n\n    \tx = Vector.mult(x, this.dimension[0] / 2.0);\n    \ty = Vector.mult(y, this.dimension[1] / 2.0);\n\n    \tthis.quad[0] = Vector.sub(Vector.sub(this.centroid, x), y); // lower-left\n    \tthis.quad[1] = Vector.sub(Vector.add(this.centroid, x), y); // lower-right\n    \tthis.quad[2] = Vector.add(Vector.add(this.centroid, x), y); // uper-right\n    \tthis.quad[3] = Vector.add(Vector.sub(this.centroid, x), y); // uper-left\n\n    \tthis.perpAxes();\n    }\n\n    static projectToAxis (obb, axis) {\n    \tlet inf = 1e6;\n    \tlet min = inf;\n    \tlet max = -inf;\n\n    \tlet quad = obb.quad;\n\n    \t// for each axis, project obb quad to it and find min and max values\n    \tfor (let i = 0; i < 4; ++i) {\n            let d =  Vector.dot(quad[i], axis);\n            min = Math.min(min, d);\n            max = Math.max(max, d);\n    \t}\n\n    \treturn [min, max];\n    }\n\n    static axisCollide (obb_a, obb_b, axes) {\n    \tfor (let i = 0; i < 2; ++i) {\n    \t\tlet a_proj = OBB.projectToAxis(obb_a, axes[i]);\n    \t\tlet b_proj = OBB.projectToAxis(obb_b, axes[i]);\n\n    \t\tif (b_proj[0] > a_proj[1] || b_proj[1] < a_proj[0]) {\n    \t\t\treturn false;\n    \t\t}\n    \t}\n    \treturn true;\n    }\n\n    static intersect(obb_a, obb_b) {\n    \treturn OBB.axisCollide(obb_a, obb_b, obb_a.axes) && OBB.axisCollide(obb_a, obb_b, obb_b.axes);\n    }\n\n}\n\n","export default function subscribeMixin (target) {\n\n    var listeners = new Set();\n    // var listeners = [];\n\n    return Object.assign(target, {\n\n        subscribe(listener) {\n            listeners.add(listener);\n            // listeners.push(listener);\n        },\n\n        unsubscribe(listener) {\n            listeners.delete(listener);\n            // var index = listeners.indexOf(listener);\n            // if (index > -1) {\n            //     listeners.splice(index, 1);\n            // }\n        },\n\n        unsubscribeAll() {\n            listeners.clear();\n            // listeners = [];\n        },\n\n        trigger(event, ...data) {\n            for (var listener of listeners) {\n                if (typeof listener[event] === 'function') {\n                    listener[event](...data);\n                }\n            }\n        }\n\n    });\n\n}\n","// Miscellaneous utilities\n/*jshint worker: true*/\n\nimport log from 'loglevel';\nimport yaml from 'js-yaml';\nimport Geo from '../geo';\n\nvar Utils;\nexport default Utils = {};\n\n// Add a base URL for schemeless or protocol-less URLs\n// Defaults to adding current window protocol and base, or adds a custom base if specified\n// Maybe use https://github.com/medialize/URI.js if more robust functionality is needed\nUtils.addBaseURL = function (url, base) {\n    if (!url) {\n        return;\n    }\n\n    // Schemeless, add protocol\n    if (url.substr(0, 2) === '//') {\n        url = window.location.protocol + url;\n    }\n    // No http(s) or data, add base\n    else if (url.search(/^(http|https|data|blob):/) < 0) {\n        var relative = (url[0] !== '/');\n        var base_info;\n        if (base) {\n            base_info = document.createElement('a'); // use a temporary element to parse URL\n            base_info.href = base;\n        }\n        else {\n            base_info = window.location;\n        }\n\n        if (relative) {\n            let path = base_info.href.match(/([^\\#]+)/); // strip hash\n            path = (path && path.length > 1) ? path[0] : '';\n            url = path + url;\n        }\n        else {\n            // Easy way\n            if (base_info.origin) {\n                url = base_info.origin + '/' + url;\n            }\n            // Hard way (IE11)\n            else {\n                var origin = url.match(/^((http|https|data|blob):\\/\\/[^\\/]*\\/)/);\n                origin = (origin && origin.length > 1) ? origin[0] : '';\n                url = origin + url;\n            }\n        }\n    }\n    return url;\n};\n\nUtils.pathForURL = function (url) {\n    if (url.search(/^(data|blob):/) === -1) {\n        return url.substr(0, url.lastIndexOf('/') + 1);\n    }\n    return '';\n};\n\nUtils.cacheBusterForUrl = function (url) {\n    if (url.search(/^(data|blob):/) > -1) {\n        return url; // no cache-busting on object or data URLs\n    }\n    return url + '?' + (+new Date());\n};\n\n// Polyfill (for Safari compatibility)\nUtils._createObjectURL = undefined;\nUtils.createObjectURL = function (url) {\n    if (Utils._createObjectURL === undefined) {\n        Utils._createObjectURL = (window.URL && window.URL.createObjectURL) || (window.webkitURL && window.webkitURL.createObjectURL);\n\n        if (typeof Utils._createObjectURL !== 'function') {\n            Utils._createObjectURL = null;\n            log.warn(`window.URL.createObjectURL (or vendor prefix) not found, unable to create local blob URLs`);\n        }\n    }\n\n    if (Utils._createObjectURL) {\n        return Utils._createObjectURL(url);\n    }\n    else {\n        return url;\n    }\n};\n\nUtils.io = function (url, timeout = 60000, responseType = 'text', method = 'GET', headers = {}) {\n    var request = new XMLHttpRequest();\n    var promise = new Promise((resolve, reject) => {\n        request.open(method, url, true);\n        request.timeout = timeout;\n        request.responseType = responseType;\n        request.onload = () => {\n            if (request.status === 200) {\n                if (['text', 'json'].indexOf(request.responseType) > -1) {\n                    resolve(request.responseText);\n                }\n                else {\n                    resolve(request.response);\n                }\n            } else {\n                reject(Error('Request error with a status of ' + request.statusText));\n            }\n        };\n        request.onerror = (evt) => {\n            reject(Error('There was a network error' + evt.toString()));\n        };\n        request.ontimeout = (evt) => {\n            reject(Error('timeout '+ evt.toString()));\n        };\n        request.send();\n    });\n\n    Object.defineProperty(promise, 'request', {\n        value: request\n    });\n\n    return promise;\n};\n\nUtils.parseResource = function (body) {\n    var data;\n    try {\n        data = yaml.safeLoad(body);\n    } catch (e) {\n        throw e;\n    }\n    return data;\n};\n\nUtils.loadResource = function (source) {\n    return new Promise((resolve, reject) => {\n        if (typeof source === 'string') {\n            Utils.io(Utils.cacheBusterForUrl(source)).then((body) => {\n                try {\n                    let data = Utils.parseResource(body);\n                    resolve(data);\n                }\n                catch(e) {\n                    reject(e);\n                }\n            }, reject);\n        } else {\n            resolve(source);\n        }\n    });\n};\n\n// Needed for older browsers that still support WebGL (Safari 6 etc.)\nUtils.requestAnimationFramePolyfill = function () {\n    if (typeof window.requestAnimationFrame !== 'function') {\n        window.requestAnimationFrame =\n            window.webkitRequestAnimationFrame ||\n            window.mozRequestAnimationFrame    ||\n            window.oRequestAnimationFrame      ||\n            window.msRequestAnimationFrame     ||\n            function (cb) {\n                setTimeout(cb, 1000 /60);\n            };\n    }\n};\n\n// Stringify an object into JSON, but convert functions to strings\nUtils.serializeWithFunctions = function (obj) {\n    var serialized = JSON.stringify(obj, function(k, v) {\n        // Convert functions to strings\n        if (typeof v === 'function') {\n            return v.toString();\n        }\n        return v;\n    });\n\n    return serialized;\n};\n\n// Parse a JSON string, but convert function-like strings back into functions\nUtils.deserializeWithFunctions = function(serialized, wrap) {\n    var obj = JSON.parse(serialized);\n    obj = Utils.stringsToFunctions(obj, wrap);\n    return obj;\n};\n\n// Recursively parse an object, attempting to convert string properties that look like functions back into functions\nUtils.stringsToFunctions = function(obj, wrap) {\n    // Convert string\n    if (typeof obj === 'string') {\n        obj = Utils.stringToFunction(obj, wrap);\n    }\n    // Loop through object properties\n    else if (typeof obj === 'object') {\n        for (let p in obj) {\n            obj[p] = Utils.stringsToFunctions(obj[p], wrap);\n        }\n    }\n    return obj;\n};\n\n// Convert string back into a function\n// TODO: make function matching tolerant of whitespace and multilines\nUtils.stringToFunction = function(val, wrap) {\n    // Convert strings back into functions\n    if (val.match(/^\\s*function\\s*\\w*\\s*\\([\\s\\S]*\\)\\s*\\{[\\s\\S]*\\}/m) != null) {\n        var f;\n        try {\n            if (typeof wrap === 'function') {\n                eval('f = ' + wrap(val)); // jshint ignore:line\n            }\n            else {\n                eval('f = ' + val); // jshint ignore:line\n            }\n            return f;\n        }\n        catch (e) {\n            // fall-back to original value if parsing failed\n            return val;\n        }\n    }\n    return val;\n};\n\n// Log wrapper, sends message to main thread for display, and includes worker id #\nUtils.log = function (level, ...msg) {\n    level = level || 'info';\n    if (Utils.isWorkerThread) {\n        self.postMessage({\n            type: 'log',\n            level: level,\n            worker_id: self._worker_id,\n            msg: msg\n        });\n    }\n    else if (typeof log[level] === 'function') {\n        log[level](...msg);\n    }\n};\n\n// Default to allowing high pixel density\nUtils.use_high_density_display = true;\nUtils.updateDevicePixelRatio = function () {\n    Utils.device_pixel_ratio = (Utils.use_high_density_display && window.devicePixelRatio) || 1;\n};\n\n// Mark thread as main or worker\n(function() {\n    try {\n        if (window.document !== undefined) {\n            Utils.isWorkerThread = false;\n            Utils.isMainThread   = true;\n            Utils.updateDevicePixelRatio();\n        }\n    }\n    catch (e) {\n        if (self !== undefined) {\n            Utils.isWorkerThread = true;\n            Utils.isMainThread   = false;\n        }\n    }\n})();\n\n// Get URL that the current script was loaded from\n// If currentScript is not available, loops through <script> elements searching for a list of provided paths\n// e.g. Utils.findCurrentURL('tangram.debug.js', 'tangram.min.js');\nUtils.findCurrentURL = function (...paths) {\n    // Find currently executing script\n    var script = document.currentScript;\n    if (script) {\n        return script.src;\n    }\n    else if (Array.isArray(paths)) {\n        // Fallback on looping through <script> elements if document.currentScript is not supported\n        var scripts = document.getElementsByTagName('script');\n        for (var s=0; s < scripts.length; s++) {\n            for (var path of paths) {\n                if (scripts[s].src.indexOf(path) > -1) {\n                   return scripts[s].src;\n                }\n            }\n        }\n    }\n};\n\n// Used for differentiating between power-of-2 and non-power-of-2 textures\n// Via: http://stackoverflow.com/questions/19722247/webgl-wait-for-texture-to-load\nUtils.isPowerOf2 = function(value) {\n    return (value & (value - 1)) === 0;\n};\n\nUtils.nextPowerOf2 = function(value) {\n    return Math.pow(2, Math.ceil(Math.log2(value)));\n};\n\n// Interpolate 'x' along a series of control points\n// 'points' is an array of control points in the form [x, y]\n//\n// Example:\n//     Control points:\n//         [0, 5]:  when x=0, y=5\n//         [4, 10]: when x=4, y=10\n//\n//     Utils.interpolate(2, [[0, 5], [4, 10]]);\n//     -> computes x=2, halfway between x=0 and x=4: (10 - 5) / 2 +5\n//     -> returns 7.5\n//\n// TODO: add other interpolation methods besides linear\n//\nUtils.interpolate = function(x, points) {\n    // If this doesn't resemble a list of control points, just return the original value\n    if (!Array.isArray(points) || !Array.isArray(points[0])) {\n        return points;\n    }\n    else if (points.length < 1) {\n        return points;\n    }\n\n    var x1, x2, d, y;\n\n    // Min bounds\n    if (x <= points[0][0]) {\n        y = points[0][1];\n    }\n    // Max bounds\n    else if (x >= points[points.length-1][0]) {\n        y = points[points.length-1][1];\n    }\n    // Find which control points x is between\n    else {\n        for (var i=0; i < points.length - 1; i++) {\n            if (x >= points[i][0] && x < points[i+1][0]) {\n                // Linear interpolation\n                x1 = points[i][0];\n                x2 = points[i+1][0];\n\n                // Multiple values\n                if (Array.isArray(points[i][1])) {\n                    y = [];\n                    for (var c=0; c < points[i][1].length; c++) {\n                        d = points[i+1][1][c] - points[i][1][c];\n                        y[c] = d * (x - x1) / (x2 - x1) + points[i][1][c];\n                    }\n                }\n                // Single value\n                else {\n                    d = points[i+1][1] - points[i][1];\n                    y = d * (x - x1) / (x2 - x1) + points[i][1];\n                }\n                break;\n            }\n        }\n    }\n    return y;\n};\n\n// Iterators (ES6 generators)\n\n// Iterator for key/value pairs of an object\nUtils.entries = function* (obj) {\n    for (var key of Object.keys(obj)) {\n        yield [key, obj[key]];\n    }\n};\n\n// Iterator for values of an object\nUtils.values = function* (obj) {\n    for (var key of Object.keys(obj)) {\n        yield obj[key];\n    }\n};\n\n// Recursive iterators for all properties of an object, no matter how deeply nested\n// TODO: fix for circular structures\nUtils.recurseEntries = function* (obj) {\n    if (!obj) {\n        return;\n    }\n    for (var key of Object.keys(obj)) {\n        if (obj[key]) {\n            yield [key, obj[key], obj];\n            if (typeof obj[key] === 'object') {\n                yield* Utils.recurseEntries(obj[key]);\n            }\n        }\n    }\n};\n\nUtils.recurseValues = function* (obj) {\n    if (!obj) {\n        return;\n    }\n    for (var key of Object.keys(obj)) {\n        if (obj[key]) {\n            yield obj[key];\n            if (typeof obj[key] === 'object') {\n                yield* Utils.recurseValues(obj[key]);\n            }\n        }\n    }\n};\n\n// Scale a *signed* short for use in a GL VBO\n// `unit` is an optional scaling factor to mimic fixed point, since these values will be\n// normalized to 0-1, e.g. divide input by unit on the way in, multiply it back in the shader\nUtils.scaleInt16 = function (val, unit) {\n    return (val / unit) * 32767;\n};\n\nUtils.degToRad = function (degrees) {\n    return degrees * Math.PI / 180;\n};\n\nUtils.radToDeg = function (radians) {\n    return radians * 180 / Math.PI;\n};\n\nUtils.toCanvasColor = function (color) {\n    return 'rgb(' +  Math.round(color[0] * 255) + ',' + Math.round(color[1]  * 255) + ',' + Math.round(color[2] * 255) + ')';\n};\n\nUtils.toPixelSize = function (size, kind) {\n    if (kind === \"px\") {\n        return size;\n    } else if (kind === \"em\") {\n        return 16 * size;\n    } else if (kind === \"pt\") {\n        return size / 0.75;\n    } else if (kind === \"%\") {\n        return size / 6.25;\n    }\n};\n\nUtils.pointInTile = function (point) {\n    return point[0] >= 0 && point[1] > -Geo.tile_scale && point[0] < Geo.tile_scale && point[1] <= 0;\n};\n\n// http://stackoverflow.com/questions/7616461/generate-a-hash-from-string-in-javascript-jquery\nUtils.hashString = function(str) {\n    if (str.length === 0) {\n        return 0;\n    }\n    let hash = 0;\n    \n    for (let i = 0, len = str.length; i < len; i++) {\n        let chr = str.charCodeAt(i);\n        hash = ((hash << 5) - hash) + chr;\n        hash |= 0; \n    }\n    return hash;\n};\n\n","var version;\nexport default version = {\n    string: 'v0.3.0',\n    major: 0,\n    minor: 3,\n    patch: 0,\n    pre: false\n};\n","/*jshint worker: true*/\n\n// WorkerBroker routes messages between web workers and the main thread, allowing for simpler\n// async code via promises. Example usage:\n//\n// In web worker, define a method:\n//\n//     self.square = function (x) {\n//         return x * x;\n//     };\n//\n// In main thread, invoke that method and receive the result (if any) as a promise:\n//\n//     worker = new Worker(...);\n//     WorkerBroker.addWorker(worker);\n//\n//     WorkerBroker.postMessage(worker, 'square', 5).then(function(y) {\n//         console.log(y);\n//     });\n//\n//     -> prints 25\n//\n// Async code:\n//\n// For synchronous code that must pass a return value to the main thread, the function can simply\n// return an immediate value (see example above). For cases where the worker method needs to run\n// asynchronous code, the function can return a promise, and the resolved or rejected value will\n// be sent back to the main thread when the promise is fulfilled.\n//\n// Error handling:\n//\n// If the worker method either throws an error, or returns a promise that is rejected, it will be\n// sent back to the main thread as a promise rejection. These two examples are equivalent:\n//\n//     In worker, throwing an error:\n//\n//         self.broken = function () {\n//             throw new Error('error in worker!');\n//         };\n//\n//     In worker, returning a rejected promise:\n//\n//         self.broken = function () {\n//             return Promise.reject(new Error('error in worker!'));\n//         };\n//\n//     In main thread, both errors are received as a promise rejection:\n//\n//         WorkerBroker.postMessage(worker, 'broken').then(\n//             // Promise resolved\n//             function() {\n//                 console.log('success!');\n//             },\n//             // Promise rejected\n//             function(error) {\n//                 console.log('error!', error);\n//             });\n//\n//         -> prints 'error! error in worker'\n//\n// TODO: add documentation for invoking main thread methods from a worker (basically same API, but in reverse)\nimport Utils from './utils';\n\nvar WorkerBroker;\nexport default WorkerBroker = {};\n\n// Global list of all worker messages\n// Uniquely tracks every call made between main thread and a worker\nvar message_id = 0;\nvar messages = {};\n\n// Main thread:\n// - Send messages to workers, and optionally receive an async response as a promise\n// - Receive messages from workers, and optionally send an async response back as a promise\nfunction setupMainThread () {\n\n    // Send a message to a worker, and optionally get an async response\n    // Arguments:\n    //   - worker: the web worker instance\n    //   - method: the method with this name will be invoked in the worker\n    //   - message: will be passed to the method call in the worker\n    // Returns:\n    //   - a promise that will be fulfilled if the worker method returns a value (could be immediately, or async)\n    //\n    WorkerBroker.postMessage = function (worker, method, ...message) {\n        // Track state of this message\n        var promise = new Promise((resolve, reject) => {\n            messages[message_id] = { method, message, resolve, reject };\n        });\n\n        worker.postMessage({\n            type: 'main_send',      // mark message as method invocation from main thread\n            message_id,             // unique id for this message, for life of program\n            method,                 // will dispatch to a function of this name within the worker\n            message                 // message payload\n        });\n\n        message_id++;\n        return promise;\n    };\n\n    // Add a worker to communicate with - each worker must be registered from the main thread\n    var worker_id = 0;\n    var workers = {};\n\n    WorkerBroker.addWorker = function (worker) {\n\n        // Keep track of all registered workers\n        // TODO: adding a property directly to the worker, would be better to track non-instrusively,\n        // maybe with an ES6 Map\n        worker._worker_broker_id = worker_id++;\n        workers[worker._worker_broker_id] = worker;\n\n        // Listen for messages coming back from the worker, and fulfill that message's promise\n        worker.addEventListener('message', (event) => {\n            if (event.data.type !== 'worker_reply') {\n                return;\n            }\n\n            // Pass the result to the promise\n            var id = event.data.message_id;\n            if (messages[id]) {\n                if (event.data.error) {\n                    messages[id].reject(event.data.error);\n                }\n                else {\n                    messages[id].resolve(event.data.message);\n                }\n                delete messages[id];\n            }\n        });\n\n        // Listen for messages initiating a call from the worker, dispatch them,\n        // and send any return value back to the worker\n        worker.addEventListener('message', (event) => {\n            // Unique id for this message & return call to main thread\n            var id = event.data.message_id;\n            if (event.data.type !== 'worker_send' || id == null) {\n                return;\n            }\n\n            // Call the requested method and save the return value\n            var target = targets[event.data.target];\n            if (!target) {\n                throw Error(`Worker broker could not dispatch message type ${event.data.method} on target ${event.data.target} because no object with that name is registered on main thread`);\n            }\n\n            var method = (typeof target[event.data.method] === 'function') && target[event.data.method];\n            if (!method) {\n                throw Error(`Worker broker could not dispatch message type ${event.data.method} on target ${event.data.target} because object has no method with that name`);\n            }\n\n            var result, error;\n            try {\n                result = method.apply(target, event.data.message);\n            }\n            catch(e) {\n                // Thrown errors will be passed back (in string form) to worker\n                error = e;\n            }\n\n            // Send return value to worker\n            // Async result\n            if (result instanceof Promise) {\n                result.then((value) => {\n                    worker.postMessage({\n                        type: 'main_reply',\n                        message_id: id,\n                        message: value\n                    });\n                }, (error) => {\n                    worker.postMessage({\n                        type: 'main_reply',\n                        message_id: id,\n                        error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                    });\n                });\n            }\n            // Immediate result\n            else {\n                worker.postMessage({\n                    type: 'main_reply',\n                    message_id: id,\n                    message: result,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                });\n            }\n        });\n\n    };\n\n    // Register an object to receive calls from the worker\n    var targets = {};\n    WorkerBroker.addTarget = function (name, target) {\n        targets[name] = target;\n    };\n\n    // Expose for debugging\n    WorkerBroker.getMessages = function () {\n        return messages;\n    };\n\n    WorkerBroker.getMessageId = function () {\n        return message_id;\n    };\n\n}\n\n// Worker threads:\n// - Receive messages from main thread, and optionally send an async response back as a promise\n// - Send messages to main thread, and optionally receive an async response as a promise\nfunction setupWorkerThread () {\n\n    // Send a message to the main thread, and optionally get an async response as a promise\n    // Arguments:\n    //   - target: the name of the object in the main thread to be called\n    //   - method: the method with this name will be invoked on the main thread target object\n    //   - message: will be passed to the method call in the main thread\n    // Returns:\n    //   - a promise that will be fulfilled if the main thread method returns a value (could be immediately, or async)\n    //\n    WorkerBroker.postMessage = function (target, method, ...message) {\n        // Track state of this message\n        var promise = new Promise((resolve, reject) => {\n            messages[message_id] = { target, method, message, resolve, reject };\n        });\n\n        self.postMessage({\n            type: 'worker_send',    // mark message as method invocation from worker\n            message_id,             // unique id for this message, for life of program\n            target,                 // name of the object to be called on main thread\n            method,                 // will dispatch to a method of this name on the main thread\n            message                 // message payload\n        });\n\n        message_id++;\n        return promise;\n    };\n\n    // Listen for messages coming back from the main thread, and fulfill that message's promise\n    self.addEventListener('message', (event) => {\n        if (event.data.type !== 'main_reply') {\n            return;\n        }\n\n        // Pass the result to the promise\n        var id = event.data.message_id;\n        if (messages[id]) {\n            if (event.data.error) {\n                messages[id].reject(event.data.error);\n            }\n            else {\n                messages[id].resolve(event.data.message);\n            }\n            delete messages[id];\n        }\n    });\n\n    // Receive messages from main thread, dispatch them, and send back a reply\n    self.addEventListener('message', (event) => {\n        // Unique id for this message & return call to main thread\n        var id = event.data.message_id;\n        if (event.data.type !== 'main_send' || id == null) {\n            return;\n        }\n\n        // Call the requested worker method and save the return value\n        var method_name = event.data.method;\n        var method = (typeof self[method_name] === 'function') && self[method_name];\n        if (!method) {\n            throw Error(`Worker broker could not dispatch message type ${method_name} because worker has no method with that name`);\n        }\n\n        var result, error;\n        try {\n            result = method.apply(self, event.data.message);\n        }\n        catch(e) {\n            // Thrown errors will be passed back (in string form) to main thread\n            error = e;\n        }\n\n        // Send return value to main thread\n        let transferables;\n        // Async result\n        if (result instanceof Promise) {\n            result.then((value) => {\n                transferables = findTransferables(value);\n\n                self.postMessage({\n                    type: 'worker_reply',\n                    message_id: id,\n                    message: value\n                }, transferables);\n\n                if (transferables.length > 0) {\n                    Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to main thread`);\n                }\n            }, (error) => {\n                self.postMessage({\n                    type: 'worker_reply',\n                    message_id: id,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                });\n            });\n        }\n        // Immediate result\n        else {\n            transferables = findTransferables(result);\n\n            self.postMessage({\n                type: 'worker_reply',\n                message_id: id,\n                message: result,\n                error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n            }, transferables);\n\n            if (transferables.length > 0) {\n                Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to main thread`);\n            }\n        }\n    });\n\n}\n\n// Build a list of transferable objects from a source object\n// TODO: add option in case you DON'T want to transfer objects\nfunction findTransferables(source, list = []) {\n    if (!source) {\n         return list;\n    }\n\n    if (Array.isArray(source)) {\n        // Check each array element\n        source.forEach(x => findTransferables(x, list));\n    }\n    else if (typeof source === 'object') {\n        // Is the object a transferable array buffer?\n        if (source instanceof ArrayBuffer) {\n            list.push(source);\n        }\n        // Or looks like a typed array (has an array buffer property)?\n        else if (source.buffer instanceof ArrayBuffer) {\n            list.push(source.buffer);\n        }\n        // Otherwise check each property\n        else {\n            for (let p in source) {\n                findTransferables(source[p], list);\n            }\n        }\n    }\n    return list;\n}\n\n// Setup this thread as appropriate\nif (Utils.isMainThread) {\n    setupMainThread();\n}\n\nif (Utils.isWorkerThread) {\n    setupWorkerThread();\n}\n","/*** Vector functions - vectors provided as [x, y, z] arrays ***/\n\nvar Vector;\nexport default Vector = {};\n\nVector.set = function (v) {\n    var V = [];\n    var lim = v.length;\n    for (var i = 0; i < lim; i++) {\n        V[i] = v[i];\n    }\n    return V;\n};\n\nVector.neg = function (v) {\n    var V = [];\n    var lim = v.length;\n    for (var i = 0; i < lim; i++) {\n        V[i] = v[i] * -1;\n    }\n    return V;\n};\n\n// Addition of two vectors\nVector.add = function (v1, v2) {\n    var v = [];\n    var lim = Math.min(v1.length,v2.length);\n    for (var i = 0; i < lim; i++) {\n        v[i] = v1[i] + v2[i];\n    }\n    return v;\n};\n\n// Substraction of two vectors\nVector.sub = function (v1, v2) {\n    var v = [];\n    var lim = Math.min(v1.length,v2.length);\n\n    for (var i = 0; i < lim; i++) {\n        v[i] = v1[i] - v2[i];\n    }\n    return v;\n};\n\nVector.signed_area = function (v1, v2, v3) {\n    return (v2[0]-v1[0])*(v3[1]-v1[1]) - (v3[0]-v1[0])*(v2[1]-v1[1]);\n};\n\n// Multiplication of two vectors\nVector.mult = function (v1, v2) {\n    var v = [],\n        len = v1.length,\n        i;\n\n    if (typeof v2 === 'number') {\n        // Mulitply by scalar\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] * v2;\n        }\n    }\n    else {\n        // Multiply two vectors\n        len = Math.min(v1.length,v2.length);\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] * v2[i];\n        }\n    }\n    return v;\n};\n\n// Division of two vectors\nVector.div = function (v1, v2) {\n    var v = [],\n        i;\n    if(typeof v2 === 'number'){\n        // Divide by scalar\n        for (i = 0; i < v1.length; i++){\n            v[i] = v1[i] / v2;\n        }\n    } else {\n        // Divide to vectors\n        var len = Math.min(v1.length,v2.length);\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] / v2[i];\n        }\n    }\n    return v;\n};\n\n// Get 2D perpendicular\nVector.perp = function (v1, v2) {\n    return [ v2[1] - v1[1],\n             v1[0] - v2[0] ];\n};\n\n// Get 2D vector rotated\nVector.rot = function (v, a) {\n    var vr = Vector.length(v);\n    var va = Vector.angle(v);\n    return [vr * Math.cos(va+a),\n            vr * Math.sin(va+a)];\n};\n\n// Get 2D heading angle\nVector.angle = function ([x, y]) {\n    return Math.atan2(y,x);\n};\n\n// Compare two points\nVector.isEqual = function (v1, v2) {\n    var len = v1.length;\n    for (var i = 0; i < len; i++) {\n        if (v1[i] !== v2[i]){\n            return false;\n        }\n    }\n    return true;\n};\n\n// Vector length squared\nVector.lengthSq = function (v)\n{\n    if (v.length === 2) {\n        return (v[0]*v[0] + v[1]*v[1]);\n    }\n    else {\n        return (v[0]*v[0] + v[1]*v[1] + v[2]*v[2]);\n    }\n};\n\n// Vector length\nVector.length = function (v)\n{\n    return Math.sqrt(Vector.lengthSq(v));\n};\n\n// Normalize a vector\nVector.normalize = function (v)\n{\n    var d;\n    if (v.length === 2) {\n        d = v[0]*v[0] + v[1]*v[1];\n        d = Math.sqrt(d);\n\n        if (d !== 0) {\n            return [v[0] / d, v[1] / d];\n        }\n        return [0, 0];\n    } else {\n        d = v[0]*v[0] + v[1]*v[1] + v[2]*v[2];\n        d = Math.sqrt(d);\n\n        if (d !== 0) {\n            return [v[0] / d, v[1] / d, v[2] / d];\n        }\n        return [0, 0, 0];\n    }\n};\n\n// Cross product of two vectors\nVector.cross  = function (v1, v2) {\n    return [\n        (v1[1] * v2[2]) - (v1[2] * v2[1]),\n        (v1[2] * v2[0]) - (v1[0] * v2[2]),\n        (v1[0] * v2[1]) - (v1[1] * v2[0])\n    ];\n};\n\n// Dot product of two vectors\nVector.dot = function (v1, v2) {\n    var n = 0;\n    var lim = Math.min(v1.length, v2.length);\n    for (var i = 0; i < lim; i++) {\n        n += v1[i] * v2[i];\n    }\n    return n;\n};\n\n// Find the intersection of two lines specified as segments from points (p1, p2) and (p3, p4)\n// http://en.wikipedia.org/wiki/Line-line_intersection\n// http://en.wikipedia.org/wiki/Cramer's_rule\nVector.lineIntersection = function (p1, p2, p3, p4, parallel_tolerance) {\n    parallel_tolerance = parallel_tolerance || 0.01;\n\n    // a1*x + b1*y = c1 for line (x1, y1) to (x2, y2)\n    // a2*x + b2*y = c2 for line (x3, y3) to (x4, y4)\n    var a1 = p1[1] - p2[1]; // y1 - y2\n    var b1 = p1[0] - p2[0]; // x1 - x2\n    var a2 = p3[1] - p4[1]; // y3 - y4\n    var b2 = p3[0] - p4[0]; // x3 - x4\n    var c1 = (p1[0] * p2[1]) - (p1[1] * p2[0]); // x1*y2 - y1*x2\n    var c2 = (p3[0] * p4[1]) - (p3[1] * p4[0]); // x3*y4 - y3*x4\n    var denom = (b1 * a2) - (a1 * b2);\n\n    if (Math.abs(denom) > parallel_tolerance) {\n        return [\n            ((c1 * b2) - (b1 * c2)) / denom,\n            ((c1 * a2) - (a1 * c2)) / denom\n        ];\n    }\n    return null; // return null if lines are (close to) parallel\n};\n","module.exports = require(\"./lib/babel/polyfill\");\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/babel/lib/babel/polyfill.js","node_modules/babel/node_modules/core-js/shim.js","node_modules/babel/node_modules/regenerator-babel/runtime.js","node_modules/box-intersect/index.js","node_modules/box-intersect/lib/brute.js","node_modules/box-intersect/lib/intersect.js","node_modules/box-intersect/lib/median.js","node_modules/box-intersect/lib/partition.js","node_modules/box-intersect/lib/sort.js","node_modules/box-intersect/lib/sweep.js","node_modules/box-intersect/node_modules/bit-twiddle/twiddle.js","node_modules/box-intersect/node_modules/typedarray-pool/node_modules/dup/dup.js","node_modules/box-intersect/node_modules/typedarray-pool/pool.js","node_modules/browserify/node_modules/browser-resolve/empty.js","node_modules/browserify/node_modules/buffer/index.js","node_modules/browserify/node_modules/buffer/node_modules/base64-js/lib/b64.js","node_modules/browserify/node_modules/buffer/node_modules/ieee754/index.js","node_modules/browserify/node_modules/buffer/node_modules/is-array/index.js","node_modules/csscolorparser/csscolorparser.js","node_modules/earcut/src/earcut.js","node_modules/geojson-vt/src/clip.js","node_modules/geojson-vt/src/convert.js","node_modules/geojson-vt/src/index.js","node_modules/geojson-vt/src/simplify.js","node_modules/geojson-vt/src/tile.js","node_modules/geojson-vt/src/wrap.js","node_modules/gl-matrix/dist/gl-matrix.js","node_modules/gl-shader-errors/index.js","node_modules/js-yaml/index.js","node_modules/js-yaml/lib/js-yaml.js","node_modules/js-yaml/lib/js-yaml/common.js","node_modules/js-yaml/lib/js-yaml/dumper.js","node_modules/js-yaml/lib/js-yaml/exception.js","node_modules/js-yaml/lib/js-yaml/loader.js","node_modules/js-yaml/lib/js-yaml/mark.js","node_modules/js-yaml/lib/js-yaml/schema.js","node_modules/js-yaml/lib/js-yaml/schema/core.js","node_modules/js-yaml/lib/js-yaml/schema/default_full.js","node_modules/js-yaml/lib/js-yaml/schema/default_safe.js","node_modules/js-yaml/lib/js-yaml/schema/failsafe.js","node_modules/js-yaml/lib/js-yaml/schema/json.js","node_modules/js-yaml/lib/js-yaml/type.js","node_modules/js-yaml/lib/js-yaml/type/binary.js","node_modules/js-yaml/lib/js-yaml/type/bool.js","node_modules/js-yaml/lib/js-yaml/type/float.js","node_modules/js-yaml/lib/js-yaml/type/int.js","node_modules/js-yaml/lib/js-yaml/type/js/function.js","node_modules/js-yaml/lib/js-yaml/type/js/regexp.js","node_modules/js-yaml/lib/js-yaml/type/js/undefined.js","node_modules/js-yaml/lib/js-yaml/type/map.js","node_modules/js-yaml/lib/js-yaml/type/merge.js","node_modules/js-yaml/lib/js-yaml/type/null.js","node_modules/js-yaml/lib/js-yaml/type/omap.js","node_modules/js-yaml/lib/js-yaml/type/pairs.js","node_modules/js-yaml/lib/js-yaml/type/seq.js","node_modules/js-yaml/lib/js-yaml/type/set.js","node_modules/js-yaml/lib/js-yaml/type/str.js","node_modules/js-yaml/lib/js-yaml/type/timestamp.js","node_modules/js-yaml/node_modules/esprima/esprima.js","node_modules/loglevel/lib/loglevel.js","node_modules/match-feature/index.js","node_modules/pbf/buffer.js","node_modules/pbf/index.js","node_modules/strip-comments/index.js","node_modules/topojson/topojson.js","node_modules/vector-tile/index.js","node_modules/vector-tile/lib/vectortile.js","node_modules/vector-tile/lib/vectortilefeature.js","node_modules/vector-tile/lib/vectortilelayer.js","node_modules/vector-tile/node_modules/point-geometry/index.js","/Users/bcamper/Documents/dev/vector-map/src/camera.js","/Users/bcamper/Documents/dev/vector-map/src/geo.js","/Users/bcamper/Documents/dev/vector-map/src/gl/constants.js","/Users/bcamper/Documents/dev/vector-map/src/gl/context.js","/Users/bcamper/Documents/dev/vector-map/src/gl/extensions.js","/Users/bcamper/Documents/dev/vector-map/src/gl/glsl.js","/Users/bcamper/Documents/dev/vector-map/src/gl/render_state.js","/Users/bcamper/Documents/dev/vector-map/src/gl/shader_program.js","/Users/bcamper/Documents/dev/vector-map/src/gl/shader_sources.js","/Users/bcamper/Documents/dev/vector-map/src/gl/texture.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vao.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vbo_mesh.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vertex_data.js","/Users/bcamper/Documents/dev/vector-map/src/gl/vertex_layout.js","/Users/bcamper/Documents/dev/vector-map/src/leaflet_layer.js","/Users/bcamper/Documents/dev/vector-map/src/light.js","/Users/bcamper/Documents/dev/vector-map/src/material.js","/Users/bcamper/Documents/dev/vector-map/src/module.js","/Users/bcamper/Documents/dev/vector-map/src/scene.js","/Users/bcamper/Documents/dev/vector-map/src/scene_loader.js","/Users/bcamper/Documents/dev/vector-map/src/scene_worker.js","/Users/bcamper/Documents/dev/vector-map/src/selection.js","/Users/bcamper/Documents/dev/vector-map/src/sources/data_source.js","/Users/bcamper/Documents/dev/vector-map/src/sources/geojson.js","/Users/bcamper/Documents/dev/vector-map/src/sources/mvt.js","/Users/bcamper/Documents/dev/vector-map/src/sources/topojson.js","/Users/bcamper/Documents/dev/vector-map/src/styles/builders.js","/Users/bcamper/Documents/dev/vector-map/src/styles/lines/lines.js","/Users/bcamper/Documents/dev/vector-map/src/styles/points/points.js","/Users/bcamper/Documents/dev/vector-map/src/styles/polygons/polygons.js","/Users/bcamper/Documents/dev/vector-map/src/styles/rule.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style_manager.js","/Users/bcamper/Documents/dev/vector-map/src/styles/style_parser.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/feature_label.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_builder.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_line.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_options.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/label_point.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text.js","/Users/bcamper/Documents/dev/vector-map/src/tile.js","/Users/bcamper/Documents/dev/vector-map/src/tile_manager.js","/Users/bcamper/Documents/dev/vector-map/src/utils/errors.js","/Users/bcamper/Documents/dev/vector-map/src/utils/obb.js","/Users/bcamper/Documents/dev/vector-map/src/utils/subscribe.js","/Users/bcamper/Documents/dev/vector-map/src/utils/utils.js","/Users/bcamper/Documents/dev/vector-map/src/utils/version.js","/Users/bcamper/Documents/dev/vector-map/src/utils/worker_broker.js","/Users/bcamper/Documents/dev/vector-map/src/vector.js","node_modules/babel/polyfill.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACz7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5hBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7eA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxNA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5hCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjkBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC10BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACljDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzsKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACthBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;IClIO,GAAG,2BAAM,OAAO;;IAChB,KAAK,2BAAM,eAAe;;IAC1B,aAAa,2BAAM,qBAAqB;;IAExC,QAAQ,2BAAM,WAAW;;AAChC,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;AACzB,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;;;;IAGJ,MAAM;AAEZ,aAFM,MAAM,CAEX,IAAI,EAAE,KAAK,EAAgB;YAAd,OAAO,gCAAG,EAAE;;8BAFpB,MAAM;;AAGnB,YAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,YAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;AACjC,YAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;;KAE5B;;iBAPgB,MAAM;AAwBvB,cAAM;;;;mBAAA,kBAAG,EAER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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function (global){\n\"use strict\";\n\nif (global._babelPolyfill) {\n  throw new Error(\"only one instance of babel/polyfill is allowed\");\n}\nglobal._babelPolyfill = true;\n\nrequire(\"core-js/shim\");\n\nrequire(\"regenerator-babel/runtime\");\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9iYWJlbC9saWIvYmFiZWwvcG9seWZpbGwuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaWYgKGdsb2JhbC5fYmFiZWxQb2x5ZmlsbCkge1xuICB0aHJvdyBuZXcgRXJyb3IoXCJvbmx5IG9uZSBpbnN0YW5jZSBvZiBiYWJlbC9wb2x5ZmlsbCBpcyBhbGxvd2VkXCIpO1xufVxuZ2xvYmFsLl9iYWJlbFBvbHlmaWxsID0gdHJ1ZTtcblxucmVxdWlyZShcImNvcmUtanMvc2hpbVwiKTtcblxucmVxdWlyZShcInJlZ2VuZXJhdG9yLWJhYmVsL3J1bnRpbWVcIik7Il19","/**\n * Core.js 0.6.1\n * https://github.com/zloirock/core-js\n * License: http://rock.mit-license.org\n * © 2015 Denis Pushkarev\n */\n!function(global, framework, undefined){\n'use strict';\n\n/******************************************************************************\n * Module : common                                                            *\n ******************************************************************************/\n\n  // Shortcuts for [[Class]] & property names\r\nvar OBJECT          = 'Object'\r\n  , FUNCTION        = 'Function'\r\n  , ARRAY           = 'Array'\r\n  , STRING          = 'String'\r\n  , NUMBER          = 'Number'\r\n  , REGEXP          = 'RegExp'\r\n  , DATE            = 'Date'\r\n  , MAP             = 'Map'\r\n  , SET             = 'Set'\r\n  , WEAKMAP         = 'WeakMap'\r\n  , WEAKSET         = 'WeakSet'\r\n  , SYMBOL          = 'Symbol'\r\n  , PROMISE         = 'Promise'\r\n  , MATH            = 'Math'\r\n  , ARGUMENTS       = 'Arguments'\r\n  , PROTOTYPE       = 'prototype'\r\n  , CONSTRUCTOR     = 'constructor'\r\n  , TO_STRING       = 'toString'\r\n  , TO_STRING_TAG   = TO_STRING + 'Tag'\r\n  , TO_LOCALE       = 'toLocaleString'\r\n  , HAS_OWN         = 'hasOwnProperty'\r\n  , FOR_EACH        = 'forEach'\r\n  , ITERATOR        = 'iterator'\r\n  , FF_ITERATOR     = '@@' + ITERATOR\r\n  , PROCESS         = 'process'\r\n  , CREATE_ELEMENT  = 'createElement'\r\n  // Aliases global objects and prototypes\r\n  , Function        = global[FUNCTION]\r\n  , Object          = global[OBJECT]\r\n  , Array           = global[ARRAY]\r\n  , String          = global[STRING]\r\n  , Number          = global[NUMBER]\r\n  , RegExp          = global[REGEXP]\r\n  , Date            = global[DATE]\r\n  , Map             = global[MAP]\r\n  , Set             = global[SET]\r\n  , WeakMap         = global[WEAKMAP]\r\n  , WeakSet         = global[WEAKSET]\r\n  , Symbol          = global[SYMBOL]\r\n  , Math            = global[MATH]\r\n  , TypeError       = global.TypeError\r\n  , RangeError      = global.RangeError\r\n  , setTimeout      = global.setTimeout\r\n  , setImmediate    = global.setImmediate\r\n  , clearImmediate  = global.clearImmediate\r\n  , parseInt        = global.parseInt\r\n  , isFinite        = global.isFinite\r\n  , process         = global[PROCESS]\r\n  , nextTick        = process && process.nextTick\r\n  , document        = global.document\r\n  , html            = document && document.documentElement\r\n  , navigator       = global.navigator\r\n  , define          = global.define\r\n  , console         = global.console || {}\r\n  , ArrayProto      = Array[PROTOTYPE]\r\n  , ObjectProto     = Object[PROTOTYPE]\r\n  , FunctionProto   = Function[PROTOTYPE]\r\n  , Infinity        = 1 / 0\r\n  , DOT             = '.';\r\n\r\n// http://jsperf.com/core-js-isobject\r\nfunction isObject(it){\r\n  return it !== null && (typeof it == 'object' || typeof it == 'function');\r\n}\r\nfunction isFunction(it){\r\n  return typeof it == 'function';\r\n}\r\n// Native function?\r\nvar isNative = ctx(/./.test, /\\[native code\\]\\s*\\}\\s*$/, 1);\r\n\r\n// Object internal [[Class]] or toStringTag\r\n// http://people.mozilla.org/~jorendorff/es6-draft.html#sec-object.prototype.tostring\r\nvar toString = ObjectProto[TO_STRING];\r\nfunction setToStringTag(it, tag, stat){\r\n  if(it && !has(it = stat ? it : it[PROTOTYPE], SYMBOL_TAG))hidden(it, SYMBOL_TAG, tag);\r\n}\r\nfunction cof(it){\r\n  return toString.call(it).slice(8, -1);\r\n}\r\nfunction classof(it){\r\n  var O, T;\r\n  return it == undefined ? it === undefined ? 'Undefined' : 'Null'\r\n    : typeof (T = (O = Object(it))[SYMBOL_TAG]) == 'string' ? T : cof(O);\r\n}\r\n\r\n// Function\r\nvar call  = FunctionProto.call\r\n  , apply = FunctionProto.apply\r\n  , REFERENCE_GET;\r\n// Partial apply\r\nfunction part(/* ...args */){\r\n  var fn     = assertFunction(this)\r\n    , length = arguments.length\r\n    , args   = Array(length)\r\n    , i      = 0\r\n    , _      = path._\r\n    , holder = false;\r\n  while(length > i)if((args[i] = arguments[i++]) === _)holder = true;\r\n  return function(/* ...args */){\r\n    var that    = this\r\n      , _length = arguments.length\r\n      , i = 0, j = 0, _args;\r\n    if(!holder && !_length)return invoke(fn, args, that);\r\n    _args = args.slice();\r\n    if(holder)for(;length > i; i++)if(_args[i] === _)_args[i] = arguments[j++];\r\n    while(_length > j)_args.push(arguments[j++]);\r\n    return invoke(fn, _args, that);\r\n  }\r\n}\r\n// Optional / simple context binding\r\nfunction ctx(fn, that, length){\r\n  assertFunction(fn);\r\n  if(~length && that === undefined)return fn;\r\n  switch(length){\r\n    case 1: return function(a){\r\n      return fn.call(that, a);\r\n    }\r\n    case 2: return function(a, b){\r\n      return fn.call(that, a, b);\r\n    }\r\n    case 3: return function(a, b, c){\r\n      return fn.call(that, a, b, c);\r\n    }\r\n  } return function(/* ...args */){\r\n      return fn.apply(that, arguments);\r\n  }\r\n}\r\n// Fast apply\r\n// http://jsperf.lnkit.com/fast-apply/5\r\nfunction invoke(fn, args, that){\r\n  var un = that === undefined;\r\n  switch(args.length | 0){\r\n    case 0: return un ? fn()\r\n                      : fn.call(that);\r\n    case 1: return un ? fn(args[0])\r\n                      : fn.call(that, args[0]);\r\n    case 2: return un ? fn(args[0], args[1])\r\n                      : fn.call(that, args[0], args[1]);\r\n    case 3: return un ? fn(args[0], args[1], args[2])\r\n                      : fn.call(that, args[0], args[1], args[2]);\r\n    case 4: return un ? fn(args[0], args[1], args[2], args[3])\r\n                      : fn.call(that, args[0], args[1], args[2], args[3]);\r\n    case 5: return un ? fn(args[0], args[1], args[2], args[3], args[4])\r\n                      : fn.call(that, args[0], args[1], args[2], args[3], args[4]);\r\n  } return              fn.apply(that, args);\r\n}\r\n\r\n// Object:\r\nvar create           = Object.create\r\n  , getPrototypeOf   = Object.getPrototypeOf\r\n  , setPrototypeOf   = Object.setPrototypeOf\r\n  , defineProperty   = Object.defineProperty\r\n  , defineProperties = Object.defineProperties\r\n  , getOwnDescriptor = Object.getOwnPropertyDescriptor\r\n  , getKeys          = Object.keys\r\n  , getNames         = Object.getOwnPropertyNames\r\n  , getSymbols       = Object.getOwnPropertySymbols\r\n  , isFrozen         = Object.isFrozen\r\n  , has              = ctx(call, ObjectProto[HAS_OWN], 2)\r\n  // Dummy, fix for not array-like ES3 string in es5 module\r\n  , ES5Object        = Object\r\n  , Dict;\r\nfunction toObject(it){\r\n  return ES5Object(assertDefined(it));\r\n}\r\nfunction returnIt(it){\r\n  return it;\r\n}\r\nfunction returnThis(){\r\n  return this;\r\n}\r\nfunction get(object, key){\r\n  if(has(object, key))return object[key];\r\n}\r\nfunction ownKeys(it){\r\n  assertObject(it);\r\n  return getSymbols ? getNames(it).concat(getSymbols(it)) : getNames(it);\r\n}\r\n// 19.1.2.1 Object.assign(target, source, ...)\r\nvar assign = Object.assign || function(target, source){\r\n  var T = Object(assertDefined(target))\r\n    , l = arguments.length\r\n    , i = 1;\r\n  while(l > i){\r\n    var S      = ES5Object(arguments[i++])\r\n      , keys   = getKeys(S)\r\n      , length = keys.length\r\n      , j      = 0\r\n      , key;\r\n    while(length > j)T[key = keys[j++]] = S[key];\r\n  }\r\n  return T;\r\n}\r\nfunction keyOf(object, el){\r\n  var O      = toObject(object)\r\n    , keys   = getKeys(O)\r\n    , length = keys.length\r\n    , index  = 0\r\n    , key;\r\n  while(length > index)if(O[key = keys[index++]] === el)return key;\r\n}\r\n\r\n// Array\r\n// array('str1,str2,str3') => ['str1', 'str2', 'str3']\r\nfunction array(it){\r\n  return String(it).split(',');\r\n}\r\nvar push    = ArrayProto.push\r\n  , unshift = ArrayProto.unshift\r\n  , slice   = ArrayProto.slice\r\n  , splice  = ArrayProto.splice\r\n  , indexOf = ArrayProto.indexOf\r\n  , forEach = ArrayProto[FOR_EACH];\r\n/*\r\n * 0 -> forEach\r\n * 1 -> map\r\n * 2 -> filter\r\n * 3 -> some\r\n * 4 -> every\r\n * 5 -> find\r\n * 6 -> findIndex\r\n */\r\nfunction createArrayMethod(type){\r\n  var isMap       = type == 1\r\n    , isFilter    = type == 2\r\n    , isSome      = type == 3\r\n    , isEvery     = type == 4\r\n    , isFindIndex = type == 6\r\n    , noholes     = type == 5 || isFindIndex;\r\n  return function(callbackfn/*, that = undefined */){\r\n    var O      = Object(assertDefined(this))\r\n      , that   = arguments[1]\r\n      , self   = ES5Object(O)\r\n      , f      = ctx(callbackfn, that, 3)\r\n      , length = toLength(self.length)\r\n      , index  = 0\r\n      , result = isMap ? Array(length) : isFilter ? [] : undefined\r\n      , val, res;\r\n    for(;length > index; index++)if(noholes || index in self){\r\n      val = self[index];\r\n      res = f(val, index, O);\r\n      if(type){\r\n        if(isMap)result[index] = res;             // map\r\n        else if(res)switch(type){\r\n          case 3: return true;                    // some\r\n          case 5: return val;                     // find\r\n          case 6: return index;                   // findIndex\r\n          case 2: result.push(val);               // filter\r\n        } else if(isEvery)return false;           // every\r\n      }\r\n    }\r\n    return isFindIndex ? -1 : isSome || isEvery ? isEvery : result;\r\n  }\r\n}\r\nfunction createArrayContains(isContains){\r\n  return function(el /*, fromIndex = 0 */){\r\n    var O      = toObject(this)\r\n      , length = toLength(O.length)\r\n      , index  = toIndex(arguments[1], length);\r\n    if(isContains && el != el){\r\n      for(;length > index; index++)if(sameNaN(O[index]))return isContains || index;\r\n    } else for(;length > index; index++)if(isContains || index in O){\r\n      if(O[index] === el)return isContains || index;\r\n    } return !isContains && -1;\r\n  }\r\n}\r\nfunction generic(A, B){\r\n  // strange IE quirks mode bug -> use typeof vs isFunction\r\n  return typeof A == 'function' ? A : B;\r\n}\r\n\r\n// Math\r\nvar MAX_SAFE_INTEGER = 0x1fffffffffffff // pow(2, 53) - 1 == 9007199254740991\r\n  , pow    = Math.pow\r\n  , abs    = Math.abs\r\n  , ceil   = Math.ceil\r\n  , floor  = Math.floor\r\n  , max    = Math.max\r\n  , min    = Math.min\r\n  , random = Math.random\r\n  , trunc  = Math.trunc || function(it){\r\n      return (it > 0 ? floor : ceil)(it);\r\n    }\r\n// 20.1.2.4 Number.isNaN(number)\r\nfunction sameNaN(number){\r\n  return number != number;\r\n}\r\n// 7.1.4 ToInteger\r\nfunction toInteger(it){\r\n  return isNaN(it) ? 0 : trunc(it);\r\n}\r\n// 7.1.15 ToLength\r\nfunction toLength(it){\r\n  return it > 0 ? min(toInteger(it), MAX_SAFE_INTEGER) : 0;\r\n}\r\nfunction toIndex(index, length){\r\n  var index = toInteger(index);\r\n  return index < 0 ? max(index + length, 0) : min(index, length);\r\n}\r\nfunction lz(num){\r\n  return num > 9 ? num : '0' + num;\r\n}\r\n\r\nfunction createReplacer(regExp, replace, isStatic){\r\n  var replacer = isObject(replace) ? function(part){\r\n    return replace[part];\r\n  } : replace;\r\n  return function(it){\r\n    return String(isStatic ? it : this).replace(regExp, replacer);\r\n  }\r\n}\r\nfunction createPointAt(toString){\r\n  return function(pos){\r\n    var s = String(assertDefined(this))\r\n      , i = toInteger(pos)\r\n      , l = s.length\r\n      , a, b;\r\n    if(i < 0 || i >= l)return toString ? '' : undefined;\r\n    a = s.charCodeAt(i);\r\n    return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\r\n      ? toString ? s.charAt(i) : a\r\n      : toString ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\r\n  }\r\n}\r\n\r\n// Assertion & errors\r\nvar REDUCE_ERROR = 'Reduce of empty object with no initial value';\r\nfunction assert(condition, msg1, msg2){\r\n  if(!condition)throw TypeError(msg2 ? msg1 + msg2 : msg1);\r\n}\r\nfunction assertDefined(it){\r\n  if(it == undefined)throw TypeError('Function called on null or undefined');\r\n  return it;\r\n}\r\nfunction assertFunction(it){\r\n  assert(isFunction(it), it, ' is not a function!');\r\n  return it;\r\n}\r\nfunction assertObject(it){\r\n  assert(isObject(it), it, ' is not an object!');\r\n  return it;\r\n}\r\nfunction assertInstance(it, Constructor, name){\r\n  assert(it instanceof Constructor, name, \": use the 'new' operator!\");\r\n}\r\n\r\n// Property descriptors & Symbol\r\nfunction descriptor(bitmap, value){\r\n  return {\r\n    enumerable  : !(bitmap & 1),\r\n    configurable: !(bitmap & 2),\r\n    writable    : !(bitmap & 4),\r\n    value       : value\r\n  }\r\n}\r\nfunction simpleSet(object, key, value){\r\n  object[key] = value;\r\n  return object;\r\n}\r\nfunction createDefiner(bitmap){\r\n  return DESC ? function(object, key, value){\r\n    return defineProperty(object, key, descriptor(bitmap, value));\r\n  } : simpleSet;\r\n}\r\nfunction uid(key){\r\n  return SYMBOL + '(' + key + ')_' + (++sid + random())[TO_STRING](36);\r\n}\r\nfunction getWellKnownSymbol(name, setter){\r\n  return (Symbol && Symbol[name]) || (setter ? Symbol : safeSymbol)(SYMBOL + DOT + name);\r\n}\r\n// The engine works fine with descriptors? Thank's IE8 for his funny defineProperty.\r\nvar DESC = !!function(){\r\n      try {\r\n        return defineProperty({}, 'a', {get: function(){ return 2 }}).a == 2;\r\n      } catch(e){}\r\n    }()\r\n  , sid    = 0\r\n  , hidden = createDefiner(1)\r\n  , set    = Symbol ? simpleSet : hidden\r\n  , safeSymbol = Symbol || uid;\r\nfunction assignHidden(target, src){\r\n  for(var key in src)hidden(target, key, src[key]);\r\n  return target;\r\n}\r\n\r\nvar SYMBOL_UNSCOPABLES = getWellKnownSymbol('unscopables')\r\n  , ArrayUnscopables   = ArrayProto[SYMBOL_UNSCOPABLES] || {}\r\n  , SYMBOL_TAG         = getWellKnownSymbol(TO_STRING_TAG)\r\n  , SYMBOL_SPECIES     = getWellKnownSymbol('species')\r\n  , SYMBOL_ITERATOR;\r\nfunction setSpecies(C){\r\n  if(DESC && (framework || !isNative(C)))defineProperty(C, SYMBOL_SPECIES, {\r\n    configurable: true,\r\n    get: returnThis\r\n  });\r\n}\n\n/******************************************************************************\n * Module : common.export                                                     *\n ******************************************************************************/\n\nvar NODE = cof(process) == PROCESS\r\n  , core = {}\r\n  , path = framework ? global : core\r\n  , old  = global.core\r\n  , exportGlobal\r\n  // type bitmap\r\n  , FORCED = 1\r\n  , GLOBAL = 2\r\n  , STATIC = 4\r\n  , PROTO  = 8\r\n  , BIND   = 16\r\n  , WRAP   = 32;\r\nfunction $define(type, name, source){\r\n  var key, own, out, exp\r\n    , isGlobal = type & GLOBAL\r\n    , target   = isGlobal ? global : (type & STATIC)\r\n        ? global[name] : (global[name] || ObjectProto)[PROTOTYPE]\r\n    , exports  = isGlobal ? core : core[name] || (core[name] = {});\r\n  if(isGlobal)source = name;\r\n  for(key in source){\r\n    // there is a similar native\r\n    own = !(type & FORCED) && target && key in target\r\n      && (!isFunction(target[key]) || isNative(target[key]));\r\n    // export native or passed\r\n    out = (own ? target : source)[key];\r\n    // prevent global pollution for namespaces\r\n    if(!framework && isGlobal && !isFunction(target[key]))exp = source[key];\r\n    // bind timers to global for call from export context\r\n    else if(type & BIND && own)exp = ctx(out, global);\r\n    // wrap global constructors for prevent change them in library\r\n    else if(type & WRAP && !framework && target[key] == out){\r\n      exp = function(param){\r\n        return this instanceof out ? new out(param) : out(param);\r\n      }\r\n      exp[PROTOTYPE] = out[PROTOTYPE];\r\n    } else exp = type & PROTO && isFunction(out) ? ctx(call, out) : out;\r\n    // extend global\r\n    if(framework && target && !own){\r\n      if(isGlobal)target[key] = out;\r\n      else delete target[key] && hidden(target, key, out);\r\n    }\r\n    // export\r\n    if(exports[key] != out)hidden(exports, key, exp);\r\n  }\r\n}\r\n// CommonJS export\r\nif(typeof module != 'undefined' && module.exports)module.exports = core;\r\n// RequireJS export\r\nelse if(isFunction(define) && define.amd)define(function(){return core});\r\n// Export to global object\r\nelse exportGlobal = true;\r\nif(exportGlobal || framework){\r\n  core.noConflict = function(){\r\n    global.core = old;\r\n    return core;\r\n  }\r\n  global.core = core;\r\n}\n\n/******************************************************************************\n * Module : common.iterators                                                  *\n ******************************************************************************/\n\nSYMBOL_ITERATOR = getWellKnownSymbol(ITERATOR);\r\nvar ITER  = safeSymbol('iter')\r\n  , KEY   = 1\r\n  , VALUE = 2\r\n  , Iterators = {}\r\n  , IteratorPrototype = {}\r\n    // Safari has byggy iterators w/o `next`\r\n  , BUGGY_ITERATORS = 'keys' in ArrayProto && !('next' in [].keys());\r\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\r\nsetIterator(IteratorPrototype, returnThis);\r\nfunction setIterator(O, value){\r\n  hidden(O, SYMBOL_ITERATOR, value);\r\n  // Add iterator for FF iterator protocol\r\n  FF_ITERATOR in ArrayProto && hidden(O, FF_ITERATOR, value);\r\n}\r\nfunction createIterator(Constructor, NAME, next, proto){\r\n  Constructor[PROTOTYPE] = create(proto || IteratorPrototype, {next: descriptor(1, next)});\r\n  setToStringTag(Constructor, NAME + ' Iterator');\r\n}\r\nfunction defineIterator(Constructor, NAME, value, DEFAULT){\r\n  var proto = Constructor[PROTOTYPE]\r\n    , iter  = get(proto, SYMBOL_ITERATOR) || get(proto, FF_ITERATOR) || (DEFAULT && get(proto, DEFAULT)) || value;\r\n  if(framework){\r\n    // Define iterator\r\n    setIterator(proto, iter);\r\n    if(iter !== value){\r\n      var iterProto = getPrototypeOf(iter.call(new Constructor));\r\n      // Set @@toStringTag to native iterators\r\n      setToStringTag(iterProto, NAME + ' Iterator', true);\r\n      // FF fix\r\n      has(proto, FF_ITERATOR) && setIterator(iterProto, returnThis);\r\n    }\r\n  }\r\n  // Plug for library\r\n  Iterators[NAME] = iter;\r\n  // FF & v8 fix\r\n  Iterators[NAME + ' Iterator'] = returnThis;\r\n  return iter;\r\n}\r\nfunction defineStdIterators(Base, NAME, Constructor, next, DEFAULT, IS_SET){\r\n  function createIter(kind){\r\n    return function(){\r\n      return new Constructor(this, kind);\r\n    }\r\n  }\r\n  createIterator(Constructor, NAME, next);\r\n  var entries = createIter(KEY+VALUE)\r\n    , values  = createIter(VALUE);\r\n  if(DEFAULT == VALUE)values = defineIterator(Base, NAME, values, 'values');\r\n  else entries = defineIterator(Base, NAME, entries, 'entries');\r\n  if(DEFAULT){\r\n    $define(PROTO + FORCED * BUGGY_ITERATORS, NAME, {\r\n      entries: entries,\r\n      keys: IS_SET ? values : createIter(KEY),\r\n      values: values\r\n    });\r\n  }\r\n}\r\nfunction iterResult(done, value){\r\n  return {value: value, done: !!done};\r\n}\r\nfunction isIterable(it){\r\n  var O      = Object(it)\r\n    , Symbol = global[SYMBOL]\r\n    , hasExt = (Symbol && Symbol[ITERATOR] || FF_ITERATOR) in O;\r\n  return hasExt || SYMBOL_ITERATOR in O || has(Iterators, classof(O));\r\n}\r\nfunction getIterator(it){\r\n  var Symbol  = global[SYMBOL]\r\n    , ext     = it[Symbol && Symbol[ITERATOR] || FF_ITERATOR]\r\n    , getIter = ext || it[SYMBOL_ITERATOR] || Iterators[classof(it)];\r\n  return assertObject(getIter.call(it));\r\n}\r\nfunction stepCall(fn, value, entries){\r\n  return entries ? invoke(fn, value) : fn(value);\r\n}\r\nfunction checkDangerIterClosing(fn){\r\n  var danger = true;\r\n  var O = {\r\n    next: function(){ throw 1 },\r\n    'return': function(){ danger = false }\r\n  };\r\n  O[SYMBOL_ITERATOR] = returnThis;\r\n  try {\r\n    fn(O);\r\n  } catch(e){}\r\n  return danger;\r\n}\r\nfunction closeIterator(iterator){\r\n  var ret = iterator['return'];\r\n  if(ret !== undefined)ret.call(iterator);\r\n}\r\nfunction safeIterClose(exec, iterator){\r\n  try {\r\n    exec(iterator);\r\n  } catch(e){\r\n    closeIterator(iterator);\r\n    throw e;\r\n  }\r\n}\r\nfunction forOf(iterable, entries, fn, that){\r\n  safeIterClose(function(iterator){\r\n    var f = ctx(fn, that, entries ? 2 : 1)\r\n      , step;\r\n    while(!(step = iterator.next()).done)if(stepCall(f, step.value, entries) === false){\r\n      return closeIterator(iterator);\r\n    }\r\n  }, getIterator(iterable));\r\n}\n\n/******************************************************************************\n * Module : es6.symbol                                                        *\n ******************************************************************************/\n\n// ECMAScript 6 symbols shim\r\n!function(TAG, SymbolRegistry, AllSymbols, setter){\r\n  // 19.4.1.1 Symbol([description])\r\n  if(!isNative(Symbol)){\r\n    Symbol = function(description){\r\n      assert(!(this instanceof Symbol), SYMBOL + ' is not a ' + CONSTRUCTOR);\r\n      var tag = uid(description)\r\n        , sym = set(create(Symbol[PROTOTYPE]), TAG, tag);\r\n      AllSymbols[tag] = sym;\r\n      DESC && setter && defineProperty(ObjectProto, tag, {\r\n        configurable: true,\r\n        set: function(value){\r\n          hidden(this, tag, value);\r\n        }\r\n      });\r\n      return sym;\r\n    }\r\n    hidden(Symbol[PROTOTYPE], TO_STRING, function(){\r\n      return this[TAG];\r\n    });\r\n  }\r\n  $define(GLOBAL + WRAP, {Symbol: Symbol});\r\n  \r\n  var symbolStatics = {\r\n    // 19.4.2.1 Symbol.for(key)\r\n    'for': function(key){\r\n      return has(SymbolRegistry, key += '')\r\n        ? SymbolRegistry[key]\r\n        : SymbolRegistry[key] = Symbol(key);\r\n    },\r\n    // 19.4.2.4 Symbol.iterator\r\n    iterator: SYMBOL_ITERATOR || getWellKnownSymbol(ITERATOR),\r\n    // 19.4.2.5 Symbol.keyFor(sym)\r\n    keyFor: part.call(keyOf, SymbolRegistry),\r\n    // 19.4.2.10 Symbol.species\r\n    species: SYMBOL_SPECIES,\r\n    // 19.4.2.13 Symbol.toStringTag\r\n    toStringTag: SYMBOL_TAG = getWellKnownSymbol(TO_STRING_TAG, true),\r\n    // 19.4.2.14 Symbol.unscopables\r\n    unscopables: SYMBOL_UNSCOPABLES,\r\n    pure: safeSymbol,\r\n    set: set,\r\n    useSetter: function(){setter = true},\r\n    useSimple: function(){setter = false}\r\n  };\r\n  // 19.4.2.2 Symbol.hasInstance\r\n  // 19.4.2.3 Symbol.isConcatSpreadable\r\n  // 19.4.2.6 Symbol.match\r\n  // 19.4.2.8 Symbol.replace\r\n  // 19.4.2.9 Symbol.search\r\n  // 19.4.2.11 Symbol.split\r\n  // 19.4.2.12 Symbol.toPrimitive\r\n  forEach.call(array('hasInstance,isConcatSpreadable,match,replace,search,split,toPrimitive'),\r\n    function(it){\r\n      symbolStatics[it] = getWellKnownSymbol(it);\r\n    }\r\n  );\r\n  $define(STATIC, SYMBOL, symbolStatics);\r\n  \r\n  setToStringTag(Symbol, SYMBOL);\r\n  \r\n  $define(STATIC + FORCED * !isNative(Symbol), OBJECT, {\r\n    // 19.1.2.7 Object.getOwnPropertyNames(O)\r\n    getOwnPropertyNames: function(it){\r\n      var names = getNames(toObject(it)), result = [], key, i = 0;\r\n      while(names.length > i)has(AllSymbols, key = names[i++]) || result.push(key);\r\n      return result;\r\n    },\r\n    // 19.1.2.8 Object.getOwnPropertySymbols(O)\r\n    getOwnPropertySymbols: function(it){\r\n      var names = getNames(toObject(it)), result = [], key, i = 0;\r\n      while(names.length > i)has(AllSymbols, key = names[i++]) && result.push(AllSymbols[key]);\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  // 20.2.1.9 Math[@@toStringTag]\r\n  setToStringTag(Math, MATH, true);\r\n  // 24.3.3 JSON[@@toStringTag]\r\n  setToStringTag(global.JSON, 'JSON', true);\r\n}(safeSymbol('tag'), {}, {}, true);\n\n/******************************************************************************\n * Module : es6.object.statics                                                *\n ******************************************************************************/\n\n!function(){\r\n  var objectStatic = {\r\n    // 19.1.3.1 Object.assign(target, source)\r\n    assign: assign,\r\n    // 19.1.3.10 Object.is(value1, value2)\r\n    is: function(x, y){\r\n      return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\r\n    }\r\n  };\r\n  // 19.1.3.19 Object.setPrototypeOf(O, proto)\r\n  // Works with __proto__ only. Old v8 can't works with null proto objects.\r\n  '__proto__' in ObjectProto && function(buggy, set){\r\n    try {\r\n      set = ctx(call, getOwnDescriptor(ObjectProto, '__proto__').set, 2);\r\n      set({}, ArrayProto);\r\n    } catch(e){ buggy = true }\r\n    objectStatic.setPrototypeOf = setPrototypeOf = setPrototypeOf || function(O, proto){\r\n      assertObject(O);\r\n      assert(proto === null || isObject(proto), proto, \": can't set as prototype!\");\r\n      if(buggy)O.__proto__ = proto;\r\n      else set(O, proto);\r\n      return O;\r\n    }\r\n  }();\r\n  $define(STATIC, OBJECT, objectStatic);\r\n}();\n\n/******************************************************************************\n * Module : es6.object.prototype                                              *\n ******************************************************************************/\n\n!function(tmp){\r\n  // 19.1.3.6 Object.prototype.toString()\r\n  tmp[SYMBOL_TAG] = DOT;\r\n  if(cof(tmp) != DOT)hidden(ObjectProto, TO_STRING, function(){\r\n    return '[object ' + classof(this) + ']';\r\n  });\r\n}({});\n\n/******************************************************************************\n * Module : es6.object.statics-accept-primitives                              *\n ******************************************************************************/\n\n!function(){\r\n  // Object static methods accept primitives\r\n  function wrapObjectMethod(key, MODE){\r\n    var fn  = Object[key]\r\n      , exp = core[OBJECT][key]\r\n      , f   = 0\r\n      , o   = {};\r\n    if(!exp || isNative(exp)){\r\n      o[key] = MODE == 1 ? function(it){\r\n        return isObject(it) ? fn(it) : it;\r\n      } : MODE == 2 ? function(it){\r\n        return isObject(it) ? fn(it) : true;\r\n      } : MODE == 3 ? function(it){\r\n        return isObject(it) ? fn(it) : false;\r\n      } : MODE == 4 ? function(it, key){\r\n        return fn(toObject(it), key);\r\n      } : function(it){\r\n        return fn(toObject(it));\r\n      };\r\n      try { fn(DOT) }\r\n      catch(e){ f = 1 }\r\n      $define(STATIC + FORCED * f, OBJECT, o);\r\n    }\r\n  }\r\n  wrapObjectMethod('freeze', 1);\r\n  wrapObjectMethod('seal', 1);\r\n  wrapObjectMethod('preventExtensions', 1);\r\n  wrapObjectMethod('isFrozen', 2);\r\n  wrapObjectMethod('isSealed', 2);\r\n  wrapObjectMethod('isExtensible', 3);\r\n  wrapObjectMethod('getOwnPropertyDescriptor', 4);\r\n  wrapObjectMethod('getPrototypeOf');\r\n  wrapObjectMethod('keys');\r\n  wrapObjectMethod('getOwnPropertyNames');\r\n}();\n\n/******************************************************************************\n * Module : es6.function                                                      *\n ******************************************************************************/\n\n!function(NAME){\r\n  // 19.2.4.2 name\r\n  NAME in FunctionProto || (DESC && defineProperty(FunctionProto, NAME, {\r\n    configurable: true,\r\n    get: function(){\r\n      var match = String(this).match(/^\\s*function ([^ (]*)/)\r\n        , name  = match ? match[1] : '';\r\n      has(this, NAME) || defineProperty(this, NAME, descriptor(5, name));\r\n      return name;\r\n    },\r\n    set: function(value){\r\n      has(this, NAME) || defineProperty(this, NAME, descriptor(0, value));\r\n    }\r\n  }));\r\n}('name');\n\n/******************************************************************************\n * Module : es6.number.constructor                                            *\n ******************************************************************************/\n\nNumber('0o1') && Number('0b1') || function(_Number, NumberProto){\r\n  function toNumber(it){\r\n    if(isObject(it))it = toPrimitive(it);\r\n    if(typeof it == 'string' && it.length > 2 && it.charCodeAt(0) == 48){\r\n      var binary = false;\r\n      switch(it.charCodeAt(1)){\r\n        case 66 : case 98  : binary = true;\r\n        case 79 : case 111 : return parseInt(it.slice(2), binary ? 2 : 8);\r\n      }\r\n    } return +it;\r\n  }\r\n  function toPrimitive(it){\r\n    var fn, val;\r\n    if(isFunction(fn = it.valueOf) && !isObject(val = fn.call(it)))return val;\r\n    if(isFunction(fn = it[TO_STRING]) && !isObject(val = fn.call(it)))return val;\r\n    throw TypeError(\"Can't convert object to number\");\r\n  }\r\n  Number = function Number(it){\r\n    return this instanceof Number ? new _Number(toNumber(it)) : toNumber(it);\r\n  }\r\n  forEach.call(DESC ? getNames(_Number)\r\n  : array('MAX_VALUE,MIN_VALUE,NaN,NEGATIVE_INFINITY,POSITIVE_INFINITY'), function(key){\r\n    key in Number || defineProperty(Number, key, getOwnDescriptor(_Number, key));\r\n  });\r\n  Number[PROTOTYPE] = NumberProto;\r\n  NumberProto[CONSTRUCTOR] = Number;\r\n  hidden(global, NUMBER, Number);\r\n}(Number, Number[PROTOTYPE]);\n\n/******************************************************************************\n * Module : es6.number.statics                                                *\n ******************************************************************************/\n\n!function(isInteger){\r\n  $define(STATIC, NUMBER, {\r\n    // 20.1.2.1 Number.EPSILON\r\n    EPSILON: pow(2, -52),\r\n    // 20.1.2.2 Number.isFinite(number)\r\n    isFinite: function(it){\r\n      return typeof it == 'number' && isFinite(it);\r\n    },\r\n    // 20.1.2.3 Number.isInteger(number)\r\n    isInteger: isInteger,\r\n    // 20.1.2.4 Number.isNaN(number)\r\n    isNaN: sameNaN,\r\n    // 20.1.2.5 Number.isSafeInteger(number)\r\n    isSafeInteger: function(number){\r\n      return isInteger(number) && abs(number) <= MAX_SAFE_INTEGER;\r\n    },\r\n    // 20.1.2.6 Number.MAX_SAFE_INTEGER\r\n    MAX_SAFE_INTEGER: MAX_SAFE_INTEGER,\r\n    // 20.1.2.10 Number.MIN_SAFE_INTEGER\r\n    MIN_SAFE_INTEGER: -MAX_SAFE_INTEGER,\r\n    // 20.1.2.12 Number.parseFloat(string)\r\n    parseFloat: parseFloat,\r\n    // 20.1.2.13 Number.parseInt(string, radix)\r\n    parseInt: parseInt\r\n  });\r\n// 20.1.2.3 Number.isInteger(number)\r\n}(Number.isInteger || function(it){\r\n  return !isObject(it) && isFinite(it) && floor(it) === it;\r\n});\n\n/******************************************************************************\n * Module : es6.math                                                          *\n ******************************************************************************/\n\n// ECMAScript 6 shim\r\n!function(){\r\n  // 20.2.2.28 Math.sign(x)\r\n  var E    = Math.E\r\n    , exp  = Math.exp\r\n    , log  = Math.log\r\n    , sqrt = Math.sqrt\r\n    , sign = Math.sign || function(x){\r\n        return (x = +x) == 0 || x != x ? x : x < 0 ? -1 : 1;\r\n      };\r\n  \r\n  // 20.2.2.5 Math.asinh(x)\r\n  function asinh(x){\r\n    return !isFinite(x = +x) || x == 0 ? x : x < 0 ? -asinh(-x) : log(x + sqrt(x * x + 1));\r\n  }\r\n  // 20.2.2.14 Math.expm1(x)\r\n  function expm1(x){\r\n    return (x = +x) == 0 ? x : x > -1e-6 && x < 1e-6 ? x + x * x / 2 : exp(x) - 1;\r\n  }\r\n    \r\n  $define(STATIC, MATH, {\r\n    // 20.2.2.3 Math.acosh(x)\r\n    acosh: function(x){\r\n      return (x = +x) < 1 ? NaN : isFinite(x) ? log(x / E + sqrt(x + 1) * sqrt(x - 1) / E) + 1 : x;\r\n    },\r\n    // 20.2.2.5 Math.asinh(x)\r\n    asinh: asinh,\r\n    // 20.2.2.7 Math.atanh(x)\r\n    atanh: function(x){\r\n      return (x = +x) == 0 ? x : log((1 + x) / (1 - x)) / 2;\r\n    },\r\n    // 20.2.2.9 Math.cbrt(x)\r\n    cbrt: function(x){\r\n      return sign(x = +x) * pow(abs(x), 1 / 3);\r\n    },\r\n    // 20.2.2.11 Math.clz32(x)\r\n    clz32: function(x){\r\n      return (x >>>= 0) ? 32 - x[TO_STRING](2).length : 32;\r\n    },\r\n    // 20.2.2.12 Math.cosh(x)\r\n    cosh: function(x){\r\n      return (exp(x = +x) + exp(-x)) / 2;\r\n    },\r\n    // 20.2.2.14 Math.expm1(x)\r\n    expm1: expm1,\r\n    // 20.2.2.16 Math.fround(x)\r\n    // TODO: fallback for IE9-\r\n    fround: function(x){\r\n      return new Float32Array([x])[0];\r\n    },\r\n    // 20.2.2.17 Math.hypot([value1[, value2[, … ]]])\r\n    hypot: function(value1, value2){\r\n      var sum  = 0\r\n        , len1 = arguments.length\r\n        , len2 = len1\r\n        , args = Array(len1)\r\n        , larg = -Infinity\r\n        , arg;\r\n      while(len1--){\r\n        arg = args[len1] = +arguments[len1];\r\n        if(arg == Infinity || arg == -Infinity)return Infinity;\r\n        if(arg > larg)larg = arg;\r\n      }\r\n      larg = arg || 1;\r\n      while(len2--)sum += pow(args[len2] / larg, 2);\r\n      return larg * sqrt(sum);\r\n    },\r\n    // 20.2.2.18 Math.imul(x, y)\r\n    imul: function(x, y){\r\n      var UInt16 = 0xffff\r\n        , xn = +x\r\n        , yn = +y\r\n        , xl = UInt16 & xn\r\n        , yl = UInt16 & yn;\r\n      return 0 | xl * yl + ((UInt16 & xn >>> 16) * yl + xl * (UInt16 & yn >>> 16) << 16 >>> 0);\r\n    },\r\n    // 20.2.2.20 Math.log1p(x)\r\n    log1p: function(x){\r\n      return (x = +x) > -1e-8 && x < 1e-8 ? x - x * x / 2 : log(1 + x);\r\n    },\r\n    // 20.2.2.21 Math.log10(x)\r\n    log10: function(x){\r\n      return log(x) / Math.LN10;\r\n    },\r\n    // 20.2.2.22 Math.log2(x)\r\n    log2: function(x){\r\n      return log(x) / Math.LN2;\r\n    },\r\n    // 20.2.2.28 Math.sign(x)\r\n    sign: sign,\r\n    // 20.2.2.30 Math.sinh(x)\r\n    sinh: function(x){\r\n      return (abs(x = +x) < 1) ? (expm1(x) - expm1(-x)) / 2 : (exp(x - 1) - exp(-x - 1)) * (E / 2);\r\n    },\r\n    // 20.2.2.33 Math.tanh(x)\r\n    tanh: function(x){\r\n      var a = expm1(x = +x)\r\n        , b = expm1(-x);\r\n      return a == Infinity ? 1 : b == Infinity ? -1 : (a - b) / (exp(x) + exp(-x));\r\n    },\r\n    // 20.2.2.34 Math.trunc(x)\r\n    trunc: trunc\r\n  });\r\n}();\n\n/******************************************************************************\n * Module : es6.string                                                        *\n ******************************************************************************/\n\n!function(fromCharCode){\r\n  function assertNotRegExp(it){\r\n    if(cof(it) == REGEXP)throw TypeError();\r\n  }\r\n  \r\n  $define(STATIC, STRING, {\r\n    // 21.1.2.2 String.fromCodePoint(...codePoints)\r\n    fromCodePoint: function(x){\r\n      var res = []\r\n        , len = arguments.length\r\n        , i   = 0\r\n        , code\r\n      while(len > i){\r\n        code = +arguments[i++];\r\n        if(toIndex(code, 0x10ffff) !== code)throw RangeError(code + ' is not a valid code point');\r\n        res.push(code < 0x10000\r\n          ? fromCharCode(code)\r\n          : fromCharCode(((code -= 0x10000) >> 10) + 0xd800, code % 0x400 + 0xdc00)\r\n        );\r\n      } return res.join('');\r\n    },\r\n    // 21.1.2.4 String.raw(callSite, ...substitutions)\r\n    raw: function(callSite){\r\n      var raw = toObject(callSite.raw)\r\n        , len = toLength(raw.length)\r\n        , sln = arguments.length\r\n        , res = []\r\n        , i   = 0;\r\n      while(len > i){\r\n        res.push(String(raw[i++]));\r\n        if(i < sln)res.push(String(arguments[i]));\r\n      } return res.join('');\r\n    }\r\n  });\r\n  \r\n  $define(PROTO, STRING, {\r\n    // 21.1.3.3 String.prototype.codePointAt(pos)\r\n    codePointAt: createPointAt(false),\r\n    // 21.1.3.6 String.prototype.endsWith(searchString [, endPosition])\r\n    endsWith: function(searchString /*, endPosition = @length */){\r\n      assertNotRegExp(searchString);\r\n      var that = String(assertDefined(this))\r\n        , endPosition = arguments[1]\r\n        , len = toLength(that.length)\r\n        , end = endPosition === undefined ? len : min(toLength(endPosition), len);\r\n      searchString += '';\r\n      return that.slice(end - searchString.length, end) === searchString;\r\n    },\r\n    // 21.1.3.7 String.prototype.includes(searchString, position = 0)\r\n    includes: function(searchString /*, position = 0 */){\r\n      assertNotRegExp(searchString);\r\n      return !!~String(assertDefined(this)).indexOf(searchString, arguments[1]);\r\n    },\r\n    // 21.1.3.13 String.prototype.repeat(count)\r\n    repeat: function(count){\r\n      var str = String(assertDefined(this))\r\n        , res = ''\r\n        , n   = toInteger(count);\r\n      if(0 > n || n == Infinity)throw RangeError(\"Count can't be negative\");\r\n      for(;n > 0; (n >>>= 1) && (str += str))if(n & 1)res += str;\r\n      return res;\r\n    },\r\n    // 21.1.3.18 String.prototype.startsWith(searchString [, position ])\r\n    startsWith: function(searchString /*, position = 0 */){\r\n      assertNotRegExp(searchString);\r\n      var that  = String(assertDefined(this))\r\n        , index = toLength(min(arguments[1], that.length));\r\n      searchString += '';\r\n      return that.slice(index, index + searchString.length) === searchString;\r\n    }\r\n  });\r\n}(String.fromCharCode);\n\n/******************************************************************************\n * Module : es6.array.statics                                                 *\n ******************************************************************************/\n\n!function(){\r\n  $define(STATIC + FORCED * checkDangerIterClosing(Array.from), ARRAY, {\r\n    // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\r\n    from: function(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\r\n      var O       = Object(assertDefined(arrayLike))\r\n        , mapfn   = arguments[1]\r\n        , mapping = mapfn !== undefined\r\n        , f       = mapping ? ctx(mapfn, arguments[2], 2) : undefined\r\n        , index   = 0\r\n        , length, result, step;\r\n      if(isIterable(O)){\r\n        result = new (generic(this, Array));\r\n        safeIterClose(function(iterator){\r\n          for(; !(step = iterator.next()).done; index++){\r\n            result[index] = mapping ? f(step.value, index) : step.value;\r\n          }\r\n        }, getIterator(O));\r\n      } else {\r\n        result = new (generic(this, Array))(length = toLength(O.length));\r\n        for(; length > index; index++){\r\n          result[index] = mapping ? f(O[index], index) : O[index];\r\n        }\r\n      }\r\n      result.length = index;\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  $define(STATIC, ARRAY, {\r\n    // 22.1.2.3 Array.of( ...items)\r\n    of: function(/* ...args */){\r\n      var index  = 0\r\n        , length = arguments.length\r\n        , result = new (generic(this, Array))(length);\r\n      while(length > index)result[index] = arguments[index++];\r\n      result.length = length;\r\n      return result;\r\n    }\r\n  });\r\n  \r\n  setSpecies(Array);\r\n}();\n\n/******************************************************************************\n * Module : es6.array.prototype                                               *\n ******************************************************************************/\n\n!function(){\r\n  $define(PROTO, ARRAY, {\r\n    // 22.1.3.3 Array.prototype.copyWithin(target, start, end = this.length)\r\n    copyWithin: function(target /* = 0 */, start /* = 0, end = @length */){\r\n      var O     = Object(assertDefined(this))\r\n        , len   = toLength(O.length)\r\n        , to    = toIndex(target, len)\r\n        , from  = toIndex(start, len)\r\n        , end   = arguments[2]\r\n        , fin   = end === undefined ? len : toIndex(end, len)\r\n        , count = min(fin - from, len - to)\r\n        , inc   = 1;\r\n      if(from < to && to < from + count){\r\n        inc  = -1;\r\n        from = from + count - 1;\r\n        to   = to + count - 1;\r\n      }\r\n      while(count-- > 0){\r\n        if(from in O)O[to] = O[from];\r\n        else delete O[to];\r\n        to += inc;\r\n        from += inc;\r\n      } return O;\r\n    },\r\n    // 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length)\r\n    fill: function(value /*, start = 0, end = @length */){\r\n      var O      = Object(assertDefined(this))\r\n        , length = toLength(O.length)\r\n        , index  = toIndex(arguments[1], length)\r\n        , end    = arguments[2]\r\n        , endPos = end === undefined ? length : toIndex(end, length);\r\n      while(endPos > index)O[index++] = value;\r\n      return O;\r\n    },\r\n    // 22.1.3.8 Array.prototype.find(predicate, thisArg = undefined)\r\n    find: createArrayMethod(5),\r\n    // 22.1.3.9 Array.prototype.findIndex(predicate, thisArg = undefined)\r\n    findIndex: createArrayMethod(6)\r\n  });\r\n  \r\n  if(framework){\r\n    // 22.1.3.31 Array.prototype[@@unscopables]\r\n    forEach.call(array('find,findIndex,fill,copyWithin,entries,keys,values'), function(it){\r\n      ArrayUnscopables[it] = true;\r\n    });\r\n    SYMBOL_UNSCOPABLES in ArrayProto || hidden(ArrayProto, SYMBOL_UNSCOPABLES, ArrayUnscopables);\r\n  }\r\n}();\n\n/******************************************************************************\n * Module : es6.iterators                                                     *\n ******************************************************************************/\n\n!function(at){\r\n  // 22.1.3.4 Array.prototype.entries()\r\n  // 22.1.3.13 Array.prototype.keys()\r\n  // 22.1.3.29 Array.prototype.values()\r\n  // 22.1.3.30 Array.prototype[@@iterator]()\r\n  defineStdIterators(Array, ARRAY, function(iterated, kind){\r\n    set(this, ITER, {o: toObject(iterated), i: 0, k: kind});\r\n  // 22.1.5.2.1 %ArrayIteratorPrototype%.next()\r\n  }, function(){\r\n    var iter  = this[ITER]\r\n      , O     = iter.o\r\n      , kind  = iter.k\r\n      , index = iter.i++;\r\n    if(!O || index >= O.length){\r\n      iter.o = undefined;\r\n      return iterResult(1);\r\n    }\r\n    if(kind == KEY)  return iterResult(0, index);\r\n    if(kind == VALUE)return iterResult(0, O[index]);\r\n                     return iterResult(0, [index, O[index]]);\r\n  }, VALUE);\r\n  \r\n  // argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\r\n  Iterators[ARGUMENTS] = Iterators[ARRAY];\r\n  \r\n  // 21.1.3.27 String.prototype[@@iterator]()\r\n  defineStdIterators(String, STRING, function(iterated){\r\n    set(this, ITER, {o: String(iterated), i: 0});\r\n  // 21.1.5.2.1 %StringIteratorPrototype%.next()\r\n  }, function(){\r\n    var iter  = this[ITER]\r\n      , O     = iter.o\r\n      , index = iter.i\r\n      , point;\r\n    if(index >= O.length)return iterResult(1);\r\n    point = at.call(O, index);\r\n    iter.i += point.length;\r\n    return iterResult(0, point);\r\n  });\r\n}(createPointAt(true));\n\n/******************************************************************************\n * Module : es6.regexp                                                        *\n ******************************************************************************/\n\nDESC && !function(RegExpProto, _RegExp){  \r\n  // RegExp allows a regex with flags as the pattern\r\n  if(!function(){try{return RegExp(/a/g, 'i') == '/a/i'}catch(e){}}()){\r\n    RegExp = function RegExp(pattern, flags){\r\n      return new _RegExp(cof(pattern) == REGEXP && flags !== undefined\r\n        ? pattern.source : pattern, flags);\r\n    }\r\n    forEach.call(getNames(_RegExp), function(key){\r\n      key in RegExp || defineProperty(RegExp, key, {\r\n        configurable: true,\r\n        get: function(){ return _RegExp[key] },\r\n        set: function(it){ _RegExp[key] = it }\r\n      });\r\n    });\r\n    RegExpProto[CONSTRUCTOR] = RegExp;\r\n    RegExp[PROTOTYPE] = RegExpProto;\r\n    hidden(global, REGEXP, RegExp);\r\n  }\r\n  \r\n  // 21.2.5.3 get RegExp.prototype.flags()\r\n  if(/./g.flags != 'g')defineProperty(RegExpProto, 'flags', {\r\n    configurable: true,\r\n    get: createReplacer(/^.*\\/(\\w*)$/, '$1')\r\n  });\r\n  \r\n  setSpecies(RegExp);\r\n}(RegExp[PROTOTYPE], RegExp);\n\n/******************************************************************************\n * Module : web.immediate                                                     *\n ******************************************************************************/\n\n// setImmediate shim\r\n// Node.js 0.9+ & IE10+ has setImmediate, else:\r\nisFunction(setImmediate) && isFunction(clearImmediate) || function(ONREADYSTATECHANGE){\r\n  var postMessage      = global.postMessage\r\n    , addEventListener = global.addEventListener\r\n    , MessageChannel   = global.MessageChannel\r\n    , counter          = 0\r\n    , queue            = {}\r\n    , defer, channel, port;\r\n  setImmediate = function(fn){\r\n    var args = [], i = 1;\r\n    while(arguments.length > i)args.push(arguments[i++]);\r\n    queue[++counter] = function(){\r\n      invoke(isFunction(fn) ? fn : Function(fn), args);\r\n    }\r\n    defer(counter);\r\n    return counter;\r\n  }\r\n  clearImmediate = function(id){\r\n    delete queue[id];\r\n  }\r\n  function run(id){\r\n    if(has(queue, id)){\r\n      var fn = queue[id];\r\n      delete queue[id];\r\n      fn();\r\n    }\r\n  }\r\n  function listner(event){\r\n    run(event.data);\r\n  }\r\n  // Node.js 0.8-\r\n  if(NODE){\r\n    defer = function(id){\r\n      nextTick(part.call(run, id));\r\n    }\r\n  // Modern browsers, skip implementation for WebWorkers\r\n  // IE8 has postMessage, but it's sync & typeof its postMessage is object\r\n  } else if(addEventListener && isFunction(postMessage) && !global.importScripts){\r\n    defer = function(id){\r\n      postMessage(id, '*');\r\n    }\r\n    addEventListener('message', listner, false);\r\n  // WebWorkers\r\n  } else if(isFunction(MessageChannel)){\r\n    channel = new MessageChannel;\r\n    port    = channel.port2;\r\n    channel.port1.onmessage = listner;\r\n    defer = ctx(port.postMessage, port, 1);\r\n  // IE8-\r\n  } else if(document && ONREADYSTATECHANGE in document[CREATE_ELEMENT]('script')){\r\n    defer = function(id){\r\n      html.appendChild(document[CREATE_ELEMENT]('script'))[ONREADYSTATECHANGE] = function(){\r\n        html.removeChild(this);\r\n        run(id);\r\n      }\r\n    }\r\n  // Rest old browsers\r\n  } else {\r\n    defer = function(id){\r\n      setTimeout(run, 0, id);\r\n    }\r\n  }\r\n}('onreadystatechange');\r\n$define(GLOBAL + BIND, {\r\n  setImmediate:   setImmediate,\r\n  clearImmediate: clearImmediate\r\n});\n\n/******************************************************************************\n * Module : es6.promise                                                       *\n ******************************************************************************/\n\n// ES6 promises shim\r\n// Based on https://github.com/getify/native-promise-only/\r\n!function(Promise, test){\r\n  isFunction(Promise) && isFunction(Promise.resolve)\r\n  && Promise.resolve(test = new Promise(function(){})) == test\r\n  || function(asap, RECORD){\r\n    function isThenable(it){\r\n      var then;\r\n      if(isObject(it))then = it.then;\r\n      return isFunction(then) ? then : false;\r\n    }\r\n    function handledRejectionOrHasOnRejected(promise){\r\n      var record = promise[RECORD]\r\n        , chain  = record.c\r\n        , i      = 0\r\n        , react;\r\n      if(record.h)return true;\r\n      while(chain.length > i){\r\n        react = chain[i++];\r\n        if(react.fail || handledRejectionOrHasOnRejected(react.P))return true;\r\n      }\r\n    }\r\n    function notify(record, reject){\r\n      var chain = record.c;\r\n      if(reject || chain.length)asap(function(){\r\n        var promise = record.p\r\n          , value   = record.v\r\n          , ok      = record.s == 1\r\n          , i       = 0;\r\n        if(reject && !handledRejectionOrHasOnRejected(promise)){\r\n          setTimeout(function(){\r\n            if(!handledRejectionOrHasOnRejected(promise)){\r\n              if(NODE){\r\n                if(!process.emit('unhandledRejection', value, promise)){\r\n                  // default node.js behavior\r\n                }\r\n              } else if(isFunction(console.error)){\r\n                console.error('Unhandled promise rejection', value);\r\n              }\r\n            }\r\n          }, 1e3);\r\n        } else while(chain.length > i)!function(react){\r\n          var cb = ok ? react.ok : react.fail\r\n            , ret, then;\r\n          try {\r\n            if(cb){\r\n              if(!ok)record.h = true;\r\n              ret = cb === true ? value : cb(value);\r\n              if(ret === react.P){\r\n                react.rej(TypeError(PROMISE + '-chain cycle'));\r\n              } else if(then = isThenable(ret)){\r\n                then.call(ret, react.res, react.rej);\r\n              } else react.res(ret);\r\n            } else react.rej(value);\r\n          } catch(err){\r\n            react.rej(err);\r\n          }\r\n        }(chain[i++]);\r\n        chain.length = 0;\r\n      });\r\n    }\r\n    function resolve(value){\r\n      var record = this\r\n        , then, wrapper;\r\n      if(record.d)return;\r\n      record.d = true;\r\n      record = record.r || record; // unwrap\r\n      try {\r\n        if(then = isThenable(value)){\r\n          wrapper = {r: record, d: false}; // wrap\r\n          then.call(value, ctx(resolve, wrapper, 1), ctx(reject, wrapper, 1));\r\n        } else {\r\n          record.v = value;\r\n          record.s = 1;\r\n          notify(record);\r\n        }\r\n      } catch(err){\r\n        reject.call(wrapper || {r: record, d: false}, err); // wrap\r\n      }\r\n    }\r\n    function reject(value){\r\n      var record = this;\r\n      if(record.d)return;\r\n      record.d = true;\r\n      record = record.r || record; // unwrap\r\n      record.v = value;\r\n      record.s = 2;\r\n      notify(record, true);\r\n    }\r\n    function getConstructor(C){\r\n      var S = assertObject(C)[SYMBOL_SPECIES];\r\n      return S != undefined ? S : C;\r\n    }\r\n    // 25.4.3.1 Promise(executor)\r\n    Promise = function(executor){\r\n      assertFunction(executor);\r\n      assertInstance(this, Promise, PROMISE);\r\n      var record = {\r\n        p: this,      // promise\r\n        c: [],        // chain\r\n        s: 0,         // state\r\n        d: false,     // done\r\n        v: undefined, // value\r\n        h: false      // handled rejection\r\n      };\r\n      hidden(this, RECORD, record);\r\n      try {\r\n        executor(ctx(resolve, record, 1), ctx(reject, record, 1));\r\n      } catch(err){\r\n        reject.call(record, err);\r\n      }\r\n    }\r\n    assignHidden(Promise[PROTOTYPE], {\r\n      // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\r\n      then: function(onFulfilled, onRejected){\r\n        var S = assertObject(assertObject(this)[CONSTRUCTOR])[SYMBOL_SPECIES];\r\n        var react = {\r\n          ok:   isFunction(onFulfilled) ? onFulfilled : true,\r\n          fail: isFunction(onRejected)  ? onRejected  : false\r\n        } , P = react.P = new (S != undefined ? S : Promise)(function(resolve, reject){\r\n          react.res = assertFunction(resolve);\r\n          react.rej = assertFunction(reject);\r\n        }), record = this[RECORD];\r\n        record.c.push(react);\r\n        record.s && notify(record);\r\n        return P;\r\n      },\r\n      // 25.4.5.1 Promise.prototype.catch(onRejected)\r\n      'catch': function(onRejected){\r\n        return this.then(undefined, onRejected);\r\n      }\r\n    });\r\n    assignHidden(Promise, {\r\n      // 25.4.4.1 Promise.all(iterable)\r\n      all: function(iterable){\r\n        var Promise = getConstructor(this)\r\n          , values  = [];\r\n        return new Promise(function(resolve, reject){\r\n          forOf(iterable, false, push, values);\r\n          var remaining = values.length\r\n            , results   = Array(remaining);\r\n          if(remaining)forEach.call(values, function(promise, index){\r\n            Promise.resolve(promise).then(function(value){\r\n              results[index] = value;\r\n              --remaining || resolve(results);\r\n            }, reject);\r\n          });\r\n          else resolve(results);\r\n        });\r\n      },\r\n      // 25.4.4.4 Promise.race(iterable)\r\n      race: function(iterable){\r\n        var Promise = getConstructor(this);\r\n        return new Promise(function(resolve, reject){\r\n          forOf(iterable, false, function(promise){\r\n            Promise.resolve(promise).then(resolve, reject);\r\n          });\r\n        });\r\n      },\r\n      // 25.4.4.5 Promise.reject(r)\r\n      reject: function(r){\r\n        return new (getConstructor(this))(function(resolve, reject){\r\n          reject(r);\r\n        });\r\n      },\r\n      // 25.4.4.6 Promise.resolve(x)\r\n      resolve: function(x){\r\n        return isObject(x) && RECORD in x && getPrototypeOf(x) === this[PROTOTYPE]\r\n          ? x : new (getConstructor(this))(function(resolve, reject){\r\n            resolve(x);\r\n          });\r\n      }\r\n    });\r\n  }(nextTick || setImmediate, safeSymbol('record'));\r\n  setToStringTag(Promise, PROMISE);\r\n  setSpecies(Promise);\r\n  $define(GLOBAL + FORCED * !isNative(Promise), {Promise: Promise});\r\n}(global[PROMISE]);\n\n/******************************************************************************\n * Module : es6.collections                                                   *\n ******************************************************************************/\n\n// ECMAScript 6 collections shim\r\n!function(){\r\n  var UID   = safeSymbol('uid')\r\n    , O1    = safeSymbol('O1')\r\n    , WEAK  = safeSymbol('weak')\r\n    , LEAK  = safeSymbol('leak')\r\n    , LAST  = safeSymbol('last')\r\n    , FIRST = safeSymbol('first')\r\n    , SIZE  = DESC ? safeSymbol('size') : 'size'\r\n    , uid   = 0\r\n    , tmp   = {};\r\n  \r\n  function getCollection(C, NAME, methods, commonMethods, isMap, isWeak){\r\n    var ADDER = isMap ? 'set' : 'add'\r\n      , proto = C && C[PROTOTYPE]\r\n      , O     = {};\r\n    function initFromIterable(that, iterable){\r\n      if(iterable != undefined)forOf(iterable, isMap, that[ADDER], that);\r\n      return that;\r\n    }\r\n    function fixSVZ(key, chain){\r\n      var method = proto[key];\r\n      if(framework)proto[key] = function(a, b){\r\n        var result = method.call(this, a === 0 ? 0 : a, b);\r\n        return chain ? this : result;\r\n      };\r\n    }\r\n    if(!isNative(C) || !(isWeak || (!BUGGY_ITERATORS && has(proto, FOR_EACH) && has(proto, 'entries')))){\r\n      // create collection constructor\r\n      C = isWeak\r\n        ? function(iterable){\r\n            assertInstance(this, C, NAME);\r\n            set(this, UID, uid++);\r\n            initFromIterable(this, iterable);\r\n          }\r\n        : function(iterable){\r\n            var that = this;\r\n            assertInstance(that, C, NAME);\r\n            set(that, O1, create(null));\r\n            set(that, SIZE, 0);\r\n            set(that, LAST, undefined);\r\n            set(that, FIRST, undefined);\r\n            initFromIterable(that, iterable);\r\n          };\r\n      assignHidden(assignHidden(C[PROTOTYPE], methods), commonMethods);\r\n      isWeak || !DESC || defineProperty(C[PROTOTYPE], 'size', {get: function(){\r\n        return assertDefined(this[SIZE]);\r\n      }});\r\n    } else {\r\n      var Native = C\r\n        , inst   = new C\r\n        , chain  = inst[ADDER](isWeak ? {} : -0, 1)\r\n        , buggyZero;\r\n      // wrap to init collections from iterable\r\n      if(checkDangerIterClosing(function(O){ new C(O) })){\r\n        C = function(iterable){\r\n          assertInstance(this, C, NAME);\r\n          return initFromIterable(new Native, iterable);\r\n        }\r\n        C[PROTOTYPE] = proto;\r\n        if(framework)proto[CONSTRUCTOR] = C;\r\n      }\r\n      isWeak || inst[FOR_EACH](function(val, key){\r\n        buggyZero = 1 / key === -Infinity;\r\n      });\r\n      // fix converting -0 key to +0\r\n      if(buggyZero){\r\n        fixSVZ('delete');\r\n        fixSVZ('has');\r\n        isMap && fixSVZ('get');\r\n      }\r\n      // + fix .add & .set for chaining\r\n      if(buggyZero || chain !== inst)fixSVZ(ADDER, true);\r\n    }\r\n    setToStringTag(C, NAME);\r\n    setSpecies(C);\r\n    \r\n    O[NAME] = C;\r\n    $define(GLOBAL + WRAP + FORCED * !isNative(C), O);\r\n    \r\n    // add .keys, .values, .entries, [@@iterator]\r\n    // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\r\n    isWeak || defineStdIterators(C, NAME, function(iterated, kind){\r\n      set(this, ITER, {o: iterated, k: kind});\r\n    }, function(){\r\n      var iter  = this[ITER]\r\n        , kind  = iter.k\r\n        , entry = iter.l;\r\n      // revert to the last existing entry\r\n      while(entry && entry.r)entry = entry.p;\r\n      // get next entry\r\n      if(!iter.o || !(iter.l = entry = entry ? entry.n : iter.o[FIRST])){\r\n        // or finish the iteration\r\n        iter.o = undefined;\r\n        return iterResult(1);\r\n      }\r\n      // return step by kind\r\n      if(kind == KEY)  return iterResult(0, entry.k);\r\n      if(kind == VALUE)return iterResult(0, entry.v);\r\n                       return iterResult(0, [entry.k, entry.v]);   \r\n    }, isMap ? KEY+VALUE : VALUE, !isMap);\r\n    \r\n    return C;\r\n  }\r\n  \r\n  function fastKey(it, create){\r\n    // return primitive with prefix\r\n    if(!isObject(it))return (typeof it == 'string' ? 'S' : 'P') + it;\r\n    // can't set id to frozen object\r\n    if(isFrozen(it))return 'F';\r\n    if(!has(it, UID)){\r\n      // not necessary to add id\r\n      if(!create)return 'E';\r\n      // add missing object id\r\n      hidden(it, UID, ++uid);\r\n    // return object id with prefix\r\n    } return 'O' + it[UID];\r\n  }\r\n  function getEntry(that, key){\r\n    // fast case\r\n    var index = fastKey(key), entry;\r\n    if(index != 'F')return that[O1][index];\r\n    // frozen object case\r\n    for(entry = that[FIRST]; entry; entry = entry.n){\r\n      if(entry.k == key)return entry;\r\n    }\r\n  }\r\n  function def(that, key, value){\r\n    var entry = getEntry(that, key)\r\n      , prev, index;\r\n    // change existing entry\r\n    if(entry)entry.v = value;\r\n    // create new entry\r\n    else {\r\n      that[LAST] = entry = {\r\n        i: index = fastKey(key, true), // <- index\r\n        k: key,                        // <- key\r\n        v: value,                      // <- value\r\n        p: prev = that[LAST],          // <- previous entry\r\n        n: undefined,                  // <- next entry\r\n        r: false                       // <- removed\r\n      };\r\n      if(!that[FIRST])that[FIRST] = entry;\r\n      if(prev)prev.n = entry;\r\n      that[SIZE]++;\r\n      // add to index\r\n      if(index != 'F')that[O1][index] = entry;\r\n    } return that;\r\n  }\r\n\r\n  var collectionMethods = {\r\n    // 23.1.3.1 Map.prototype.clear()\r\n    // 23.2.3.2 Set.prototype.clear()\r\n    clear: function(){\r\n      for(var that = this, data = that[O1], entry = that[FIRST]; entry; entry = entry.n){\r\n        entry.r = true;\r\n        if(entry.p)entry.p = entry.p.n = undefined;\r\n        delete data[entry.i];\r\n      }\r\n      that[FIRST] = that[LAST] = undefined;\r\n      that[SIZE] = 0;\r\n    },\r\n    // 23.1.3.3 Map.prototype.delete(key)\r\n    // 23.2.3.4 Set.prototype.delete(value)\r\n    'delete': function(key){\r\n      var that  = this\r\n        , entry = getEntry(that, key);\r\n      if(entry){\r\n        var next = entry.n\r\n          , prev = entry.p;\r\n        delete that[O1][entry.i];\r\n        entry.r = true;\r\n        if(prev)prev.n = next;\r\n        if(next)next.p = prev;\r\n        if(that[FIRST] == entry)that[FIRST] = next;\r\n        if(that[LAST] == entry)that[LAST] = prev;\r\n        that[SIZE]--;\r\n      } return !!entry;\r\n    },\r\n    // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\r\n    // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\r\n    forEach: function(callbackfn /*, that = undefined */){\r\n      var f = ctx(callbackfn, arguments[1], 3)\r\n        , entry;\r\n      while(entry = entry ? entry.n : this[FIRST]){\r\n        f(entry.v, entry.k, this);\r\n        // revert to the last existing entry\r\n        while(entry && entry.r)entry = entry.p;\r\n      }\r\n    },\r\n    // 23.1.3.7 Map.prototype.has(key)\r\n    // 23.2.3.7 Set.prototype.has(value)\r\n    has: function(key){\r\n      return !!getEntry(this, key);\r\n    }\r\n  }\r\n  \r\n  // 23.1 Map Objects\r\n  Map = getCollection(Map, MAP, {\r\n    // 23.1.3.6 Map.prototype.get(key)\r\n    get: function(key){\r\n      var entry = getEntry(this, key);\r\n      return entry && entry.v;\r\n    },\r\n    // 23.1.3.9 Map.prototype.set(key, value)\r\n    set: function(key, value){\r\n      return def(this, key === 0 ? 0 : key, value);\r\n    }\r\n  }, collectionMethods, true);\r\n  \r\n  // 23.2 Set Objects\r\n  Set = getCollection(Set, SET, {\r\n    // 23.2.3.1 Set.prototype.add(value)\r\n    add: function(value){\r\n      return def(this, value = value === 0 ? 0 : value, value);\r\n    }\r\n  }, collectionMethods);\r\n  \r\n  function defWeak(that, key, value){\r\n    if(isFrozen(assertObject(key)))leakStore(that).set(key, value);\r\n    else {\r\n      has(key, WEAK) || hidden(key, WEAK, {});\r\n      key[WEAK][that[UID]] = value;\r\n    } return that;\r\n  }\r\n  function leakStore(that){\r\n    return that[LEAK] || hidden(that, LEAK, new Map)[LEAK];\r\n  }\r\n  \r\n  var weakMethods = {\r\n    // 23.3.3.2 WeakMap.prototype.delete(key)\r\n    // 23.4.3.3 WeakSet.prototype.delete(value)\r\n    'delete': function(key){\r\n      if(!isObject(key))return false;\r\n      if(isFrozen(key))return leakStore(this)['delete'](key);\r\n      return has(key, WEAK) && has(key[WEAK], this[UID]) && delete key[WEAK][this[UID]];\r\n    },\r\n    // 23.3.3.4 WeakMap.prototype.has(key)\r\n    // 23.4.3.4 WeakSet.prototype.has(value)\r\n    has: function(key){\r\n      if(!isObject(key))return false;\r\n      if(isFrozen(key))return leakStore(this).has(key);\r\n      return has(key, WEAK) && has(key[WEAK], this[UID]);\r\n    }\r\n  };\r\n  \r\n  // 23.3 WeakMap Objects\r\n  WeakMap = getCollection(WeakMap, WEAKMAP, {\r\n    // 23.3.3.3 WeakMap.prototype.get(key)\r\n    get: function(key){\r\n      if(isObject(key)){\r\n        if(isFrozen(key))return leakStore(this).get(key);\r\n        if(has(key, WEAK))return key[WEAK][this[UID]];\r\n      }\r\n    },\r\n    // 23.3.3.5 WeakMap.prototype.set(key, value)\r\n    set: function(key, value){\r\n      return defWeak(this, key, value);\r\n    }\r\n  }, weakMethods, true, true);\r\n  \r\n  // IE11 WeakMap frozen keys fix\r\n  if(framework && new WeakMap().set(Object.freeze(tmp), 7).get(tmp) != 7){\r\n    forEach.call(array('delete,has,get,set'), function(key){\r\n      var method = WeakMap[PROTOTYPE][key];\r\n      WeakMap[PROTOTYPE][key] = function(a, b){\r\n        // store frozen objects on leaky map\r\n        if(isObject(a) && isFrozen(a)){\r\n          var result = leakStore(this)[key](a, b);\r\n          return key == 'set' ? this : result;\r\n        // store all the rest on native weakmap\r\n        } return method.call(this, a, b);\r\n      };\r\n    });\r\n  }\r\n  \r\n  // 23.4 WeakSet Objects\r\n  WeakSet = getCollection(WeakSet, WEAKSET, {\r\n    // 23.4.3.1 WeakSet.prototype.add(value)\r\n    add: function(value){\r\n      return defWeak(this, value, true);\r\n    }\r\n  }, weakMethods, false, true);\r\n}();\n\n/******************************************************************************\n * Module : es6.reflect                                                       *\n ******************************************************************************/\n\n!function(){\r\n  function Enumerate(iterated){\r\n    var keys = [], key;\r\n    for(key in iterated)keys.push(key);\r\n    set(this, ITER, {o: iterated, a: keys, i: 0});\r\n  }\r\n  createIterator(Enumerate, OBJECT, function(){\r\n    var iter = this[ITER]\r\n      , keys = iter.a\r\n      , key;\r\n    do {\r\n      if(iter.i >= keys.length)return iterResult(1);\r\n    } while(!((key = keys[iter.i++]) in iter.o));\r\n    return iterResult(0, key);\r\n  });\r\n  \r\n  function wrap(fn){\r\n    return function(it){\r\n      assertObject(it);\r\n      try {\r\n        return fn.apply(undefined, arguments), true;\r\n      } catch(e){\r\n        return false;\r\n      }\r\n    }\r\n  }\r\n  \r\n  function reflectGet(target, propertyKey/*, receiver*/){\r\n    var receiver = arguments.length < 3 ? target : arguments[2]\r\n      , desc = getOwnDescriptor(assertObject(target), propertyKey), proto;\r\n    if(desc)return has(desc, 'value')\r\n      ? desc.value\r\n      : desc.get === undefined\r\n        ? undefined\r\n        : desc.get.call(receiver);\r\n    return isObject(proto = getPrototypeOf(target))\r\n      ? reflectGet(proto, propertyKey, receiver)\r\n      : undefined;\r\n  }\r\n  function reflectSet(target, propertyKey, V/*, receiver*/){\r\n    var receiver = arguments.length < 4 ? target : arguments[3]\r\n      , ownDesc  = getOwnDescriptor(assertObject(target), propertyKey)\r\n      , existingDescriptor, proto;\r\n    if(!ownDesc){\r\n      if(isObject(proto = getPrototypeOf(target))){\r\n        return reflectSet(proto, propertyKey, V, receiver);\r\n      }\r\n      ownDesc = descriptor(0);\r\n    }\r\n    if(has(ownDesc, 'value')){\r\n      if(ownDesc.writable === false || !isObject(receiver))return false;\r\n      existingDescriptor = getOwnDescriptor(receiver, propertyKey) || descriptor(0);\r\n      existingDescriptor.value = V;\r\n      return defineProperty(receiver, propertyKey, existingDescriptor), true;\r\n    }\r\n    return ownDesc.set === undefined\r\n      ? false\r\n      : (ownDesc.set.call(receiver, V), true);\r\n  }\r\n  var isExtensible = Object.isExtensible || returnIt;\r\n  \r\n  var reflect = {\r\n    // 26.1.1 Reflect.apply(target, thisArgument, argumentsList)\r\n    apply: ctx(call, apply, 3),\r\n    // 26.1.2 Reflect.construct(target, argumentsList [, newTarget])\r\n    construct: function(target, argumentsList /*, newTarget*/){\r\n      var proto    = assertFunction(arguments.length < 3 ? target : arguments[2])[PROTOTYPE]\r\n        , instance = create(isObject(proto) ? proto : ObjectProto)\r\n        , result   = apply.call(target, instance, argumentsList);\r\n      return isObject(result) ? result : instance;\r\n    },\r\n    // 26.1.3 Reflect.defineProperty(target, propertyKey, attributes)\r\n    defineProperty: wrap(defineProperty),\r\n    // 26.1.4 Reflect.deleteProperty(target, propertyKey)\r\n    deleteProperty: function(target, propertyKey){\r\n      var desc = getOwnDescriptor(assertObject(target), propertyKey);\r\n      return desc && !desc.configurable ? false : delete target[propertyKey];\r\n    },\r\n    // 26.1.5 Reflect.enumerate(target)\r\n    enumerate: function(target){\r\n      return new Enumerate(assertObject(target));\r\n    },\r\n    // 26.1.6 Reflect.get(target, propertyKey [, receiver])\r\n    get: reflectGet,\r\n    // 26.1.7 Reflect.getOwnPropertyDescriptor(target, propertyKey)\r\n    getOwnPropertyDescriptor: function(target, propertyKey){\r\n      return getOwnDescriptor(assertObject(target), propertyKey);\r\n    },\r\n    // 26.1.8 Reflect.getPrototypeOf(target)\r\n    getPrototypeOf: function(target){\r\n      return getPrototypeOf(assertObject(target));\r\n    },\r\n    // 26.1.9 Reflect.has(target, propertyKey)\r\n    has: function(target, propertyKey){\r\n      return propertyKey in target;\r\n    },\r\n    // 26.1.10 Reflect.isExtensible(target)\r\n    isExtensible: function(target){\r\n      return !!isExtensible(assertObject(target));\r\n    },\r\n    // 26.1.11 Reflect.ownKeys(target)\r\n    ownKeys: ownKeys,\r\n    // 26.1.12 Reflect.preventExtensions(target)\r\n    preventExtensions: wrap(Object.preventExtensions || returnIt),\r\n    // 26.1.13 Reflect.set(target, propertyKey, V [, receiver])\r\n    set: reflectSet\r\n  }\r\n  // 26.1.14 Reflect.setPrototypeOf(target, proto)\r\n  if(setPrototypeOf)reflect.setPrototypeOf = function(target, proto){\r\n    return setPrototypeOf(assertObject(target), proto), true;\r\n  };\r\n  \r\n  $define(GLOBAL, {Reflect: {}});\r\n  $define(STATIC, 'Reflect', reflect);\r\n}();\n\n/******************************************************************************\n * Module : es7.proposals                                                     *\n ******************************************************************************/\n\n!function(){\r\n  $define(PROTO, ARRAY, {\r\n    // https://github.com/domenic/Array.prototype.includes\r\n    includes: createArrayContains(true)\r\n  });\r\n  $define(PROTO, STRING, {\r\n    // https://github.com/mathiasbynens/String.prototype.at\r\n    at: createPointAt(true)\r\n  });\r\n  \r\n  function createObjectToArray(isEntries){\r\n    return function(object){\r\n      var O      = toObject(object)\r\n        , keys   = getKeys(object)\r\n        , length = keys.length\r\n        , i      = 0\r\n        , result = Array(length)\r\n        , key;\r\n      if(isEntries)while(length > i)result[i] = [key = keys[i++], O[key]];\r\n      else while(length > i)result[i] = O[keys[i++]];\r\n      return result;\r\n    }\r\n  }\r\n  $define(STATIC, OBJECT, {\r\n    // https://gist.github.com/WebReflection/9353781\r\n    getOwnPropertyDescriptors: function(object){\r\n      var O      = toObject(object)\r\n        , result = {};\r\n      forEach.call(ownKeys(O), function(key){\r\n        defineProperty(result, key, descriptor(0, getOwnDescriptor(O, key)));\r\n      });\r\n      return result;\r\n    },\r\n    // https://github.com/rwaldron/tc39-notes/blob/master/es6/2014-04/apr-9.md#51-objectentries-objectvalues\r\n    values:  createObjectToArray(false),\r\n    entries: createObjectToArray(true)\r\n  });\r\n  $define(STATIC, REGEXP, {\r\n    // https://gist.github.com/kangax/9698100\r\n    escape: createReplacer(/([\\\\\\-[\\]{}()*+?.,^$|])/g, '\\\\$1', true)\r\n  });\r\n}();\n\n/******************************************************************************\n * Module : es7.abstract-refs                                                 *\n ******************************************************************************/\n\n// https://github.com/zenparsing/es-abstract-refs\r\n!function(REFERENCE){\r\n  REFERENCE_GET = getWellKnownSymbol(REFERENCE+'Get', true);\r\n  var REFERENCE_SET = getWellKnownSymbol(REFERENCE+SET, true)\r\n    , REFERENCE_DELETE = getWellKnownSymbol(REFERENCE+'Delete', true);\r\n  \r\n  $define(STATIC, SYMBOL, {\r\n    referenceGet: REFERENCE_GET,\r\n    referenceSet: REFERENCE_SET,\r\n    referenceDelete: REFERENCE_DELETE\r\n  });\r\n  \r\n  hidden(FunctionProto, REFERENCE_GET, returnThis);\r\n  \r\n  function setMapMethods(Constructor){\r\n    if(Constructor){\r\n      var MapProto = Constructor[PROTOTYPE];\r\n      hidden(MapProto, REFERENCE_GET, MapProto.get);\r\n      hidden(MapProto, REFERENCE_SET, MapProto.set);\r\n      hidden(MapProto, REFERENCE_DELETE, MapProto['delete']);\r\n    }\r\n  }\r\n  setMapMethods(Map);\r\n  setMapMethods(WeakMap);\r\n}('reference');\n\n/******************************************************************************\n * Module : js.array.statics                                                  *\n ******************************************************************************/\n\n// JavaScript 1.6 / Strawman array statics shim\r\n!function(arrayStatics){\r\n  function setArrayStatics(keys, length){\r\n    forEach.call(array(keys), function(key){\r\n      if(key in ArrayProto)arrayStatics[key] = ctx(call, ArrayProto[key], length);\r\n    });\r\n  }\r\n  setArrayStatics('pop,reverse,shift,keys,values,entries', 1);\r\n  setArrayStatics('indexOf,every,some,forEach,map,filter,find,findIndex,includes', 3);\r\n  setArrayStatics('join,slice,concat,push,splice,unshift,sort,lastIndexOf,' +\r\n                  'reduce,reduceRight,copyWithin,fill,turn');\r\n  $define(STATIC, ARRAY, arrayStatics);\r\n}({});\n\n/******************************************************************************\n * Module : web.dom.itarable                                                  *\n ******************************************************************************/\n\n!function(NodeList){\r\n  if(framework && NodeList && !(SYMBOL_ITERATOR in NodeList[PROTOTYPE])){\r\n    hidden(NodeList[PROTOTYPE], SYMBOL_ITERATOR, Iterators[ARRAY]);\r\n  }\r\n  Iterators.NodeList = Iterators[ARRAY];\r\n}(global.NodeList);\n}(typeof self != 'undefined' && self.Math === Math ? self : Function('return this')(), true);","(function (global){\n/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n  \"use strict\";\n\n  var hasOwn = Object.prototype.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var iteratorSymbol =\n    typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n  var inModule = typeof module === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    return new Generator(innerFn, outerFn, self || null, tryLocsList || []);\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    return new Promise(function(resolve, reject) {\n      var generator = wrap(innerFn, outerFn, self, tryLocsList);\n      var callNext = step.bind(generator.next);\n      var callThrow = step.bind(generator[\"throw\"]);\n\n      function step(arg) {\n        var record = tryCatch(this, null, arg);\n        if (record.type === \"throw\") {\n          reject(record.arg);\n          return;\n        }\n\n        var info = record.arg;\n        if (info.done) {\n          resolve(info.value);\n        } else {\n          Promise.resolve(info.value).then(callNext, callThrow);\n        }\n      }\n\n      callNext();\n    });\n  };\n\n  function Generator(innerFn, outerFn, self, tryLocsList) {\n    var generator = outerFn ? Object.create(outerFn.prototype) : this;\n    var context = new Context(tryLocsList);\n    var state = GenStateSuspendedStart;\n\n    function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var record = tryCatch(\n            delegate.iterator[method],\n            delegate.iterator,\n            arg\n          );\n\n          if (record.type === \"throw\") {\n            context.delegate = null;\n\n            // Like returning generator.throw(uncaught), but without the\n            // overhead of an extra function call.\n            method = \"throw\";\n            arg = record.arg;\n\n            continue;\n          }\n\n          // Delegate generator ran and handled its own exceptions so\n          // regardless of what the method was, we continue as if it is\n          // \"next\" with an undefined arg.\n          method = \"next\";\n          arg = undefined;\n\n          var info = record.arg;\n          if (info.done) {\n            context[delegate.resultName] = info.value;\n            context.next = delegate.nextLoc;\n          } else {\n            state = GenStateSuspendedYield;\n            return info;\n          }\n\n          context.delegate = null;\n        }\n\n        if (method === \"next\") {\n          if (state === GenStateSuspendedStart &&\n              typeof arg !== \"undefined\") {\n            // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n            throw new TypeError(\n              \"attempt to send \" + JSON.stringify(arg) + \" to newborn generator\"\n            );\n          }\n\n          if (state === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            delete context.sent;\n          }\n\n        } else if (method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw arg;\n          }\n\n          if (context.dispatchException(arg)) {\n            // If the dispatched exception was caught by a catch block,\n            // then let that catch block handle the exception normally.\n            method = \"next\";\n            arg = undefined;\n          }\n\n        } else if (method === \"return\") {\n          context.abrupt(\"return\", arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          var info = {\n            value: record.arg,\n            done: context.done\n          };\n\n          if (record.arg === ContinueSentinel) {\n            if (context.delegate && method === \"next\") {\n              // Deliberately forget the last sent value so that we don't\n              // accidentally pass it on to the delegate.\n              arg = undefined;\n            }\n          } else {\n            return info;\n          }\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n\n          if (method === \"next\") {\n            context.dispatchException(record.arg);\n          } else {\n            arg = record.arg;\n          }\n        }\n      }\n    }\n\n    generator.next = invoke.bind(generator, \"next\");\n    generator[\"throw\"] = invoke.bind(generator, \"throw\");\n    generator[\"return\"] = invoke.bind(generator, \"return\");\n\n    return generator;\n  }\n\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset();\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function() {\n      this.prev = 0;\n      this.next = 0;\n      this.sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      // Pre-initialize at least 20 temporary variables to enable hidden\n      // class optimizations for simple generators.\n      for (var tempIndex = 0, tempName;\n           hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n           ++tempIndex) {\n        this[tempName] = null;\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n        return !!caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg < finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.next = finallyEntry.finallyLoc;\n      } else {\n        this.complete(record);\n      }\n\n      return ContinueSentinel;\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = record.arg;\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          return this.complete(entry.completion, entry.afterLoc);\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // Among the various tricks for obtaining a reference to the global\n  // object, this seems to be the most reliable technique that does not\n  // use indirect eval (which violates Content Security Policy).\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window : this\n);\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/babel/node_modules/regenerator-babel/runtime.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n  \"use strict\";\n\n  var hasOwn = Object.prototype.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var iteratorSymbol =\n    typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n  var inModule = typeof module === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    return new Generator(innerFn, outerFn, self || null, tryLocsList || []);\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    return new Promise(function(resolve, reject) {\n      var generator = wrap(innerFn, outerFn, self, tryLocsList);\n      var callNext = step.bind(generator.next);\n      var callThrow = step.bind(generator[\"throw\"]);\n\n      function step(arg) {\n        var record = tryCatch(this, null, arg);\n        if (record.type === \"throw\") {\n          reject(record.arg);\n          return;\n        }\n\n        var info = record.arg;\n        if (info.done) {\n          resolve(info.value);\n        } else {\n          Promise.resolve(info.value).then(callNext, callThrow);\n        }\n      }\n\n      callNext();\n    });\n  };\n\n  function Generator(innerFn, outerFn, self, tryLocsList) {\n    var generator = outerFn ? Object.create(outerFn.prototype) : this;\n    var context = new Context(tryLocsList);\n    var state = GenStateSuspendedStart;\n\n    function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var record = tryCatch(\n            delegate.iterator[method],\n            delegate.iterator,\n            arg\n          );\n\n          if (record.type === \"throw\") {\n            context.delegate = null;\n\n            // Like returning generator.throw(uncaught), but without the\n            // overhead of an extra function call.\n            method = \"throw\";\n            arg = record.arg;\n\n            continue;\n          }\n\n          // Delegate generator ran and handled its own exceptions so\n          // regardless of what the method was, we continue as if it is\n          // \"next\" with an undefined arg.\n          method = \"next\";\n          arg = undefined;\n\n          var info = record.arg;\n          if (info.done) {\n            context[delegate.resultName] = info.value;\n            context.next = delegate.nextLoc;\n          } else {\n            state = GenStateSuspendedYield;\n            return info;\n          }\n\n          context.delegate = null;\n        }\n\n        if (method === \"next\") {\n          if (state === GenStateSuspendedStart &&\n              typeof arg !== \"undefined\") {\n            // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n            throw new TypeError(\n              \"attempt to send \" + JSON.stringify(arg) + \" to newborn generator\"\n            );\n          }\n\n          if (state === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            delete context.sent;\n          }\n\n        } else if (method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw arg;\n          }\n\n          if (context.dispatchException(arg)) {\n            // If the dispatched exception was caught by a catch block,\n            // then let that catch block handle the exception normally.\n            method = \"next\";\n            arg = undefined;\n          }\n\n        } else if (method === \"return\") {\n          context.abrupt(\"return\", arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          var info = {\n            value: record.arg,\n            done: context.done\n          };\n\n          if (record.arg === ContinueSentinel) {\n            if (context.delegate && method === \"next\") {\n              // Deliberately forget the last sent value so that we don't\n              // accidentally pass it on to the delegate.\n              arg = undefined;\n            }\n          } else {\n            return info;\n          }\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n\n          if (method === \"next\") {\n            context.dispatchException(record.arg);\n          } else {\n            arg = record.arg;\n          }\n        }\n      }\n    }\n\n    generator.next = invoke.bind(generator, \"next\");\n    generator[\"throw\"] = invoke.bind(generator, \"throw\");\n    generator[\"return\"] = invoke.bind(generator, \"return\");\n\n    return generator;\n  }\n\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset();\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function() {\n      this.prev = 0;\n      this.next = 0;\n      this.sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      // Pre-initialize at least 20 temporary variables to enable hidden\n      // class optimizations for simple generators.\n      for (var tempIndex = 0, tempName;\n           hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n           ++tempIndex) {\n        this[tempName] = null;\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n        return !!caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg < finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.next = finallyEntry.finallyLoc;\n      } else {\n        this.complete(record);\n      }\n\n      return ContinueSentinel;\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = record.arg;\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          return this.complete(entry.completion, entry.afterLoc);\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // Among the various tricks for obtaining a reference to the global\n  // object, this seems to be the most reliable technique that does not\n  // use indirect eval (which violates Content Security Policy).\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window : this\n);\n"]}","'use strict'\n\nmodule.exports = boxIntersectWrapper\n\nvar pool = require('typedarray-pool')\nvar sweep = require('./lib/sweep')\nvar boxIntersectIter = require('./lib/intersect')\n\nfunction boxEmpty(d, box) {\n  for(var j=0; j<d; ++j) {\n    if(!(box[j] <= box[j+d])) {\n      return true\n    }\n  }\n  return false\n}\n\n//Unpack boxes into a flat typed array, remove empty boxes\nfunction convertBoxes(boxes, d, data, ids) {\n  var ptr = 0\n  var count = 0\n  for(var i=0, n=boxes.length; i<n; ++i) {\n    var b = boxes[i]\n    if(boxEmpty(d, b)) {\n      continue\n    }\n    for(var j=0; j<2*d; ++j) {\n      data[ptr++] = b[j]\n    }\n    ids[count++] = i\n  }\n  return count\n}\n\n//Perform type conversions, check bounds\nfunction boxIntersect(red, blue, visit, full) {\n  var n = red.length\n  var m = blue.length\n\n  //If either array is empty, then we can skip this whole thing\n  if(n <= 0 || m <= 0) {\n    return\n  }\n\n  //Compute dimension, if it is 0 then we skip\n  var d = (red[0].length)>>>1\n  if(d <= 0) {\n    return\n  }\n\n  var retval\n\n  //Convert red boxes\n  var redList  = pool.mallocDouble(2*d*n)\n  var redIds   = pool.mallocInt32(n)\n  n = convertBoxes(red, d, redList, redIds)\n\n  if(n > 0) {\n    if(d === 1 && full) {\n      //Special case: 1d complete\n      sweep.init(n)\n      retval = sweep.sweepComplete(\n        d, visit, \n        0, n, redList, redIds,\n        0, n, redList, redIds)\n    } else {\n\n      //Convert blue boxes\n      var blueList = pool.mallocDouble(2*d*m)\n      var blueIds  = pool.mallocInt32(m)\n      m = convertBoxes(blue, d, blueList, blueIds)\n\n      if(m > 0) {\n        sweep.init(n+m)\n\n        if(d === 1) {\n          //Special case: 1d bipartite\n          retval = sweep.sweepBipartite(\n            d, visit, \n            0, n, redList,  redIds,\n            0, m, blueList, blueIds)\n        } else {\n          //General case:  d>1\n          retval = boxIntersectIter(\n            d, visit,    full,\n            n, redList,  redIds,\n            m, blueList, blueIds)\n        }\n\n        pool.free(blueList)\n        pool.free(blueIds)\n      }\n    }\n\n    pool.free(redList)\n    pool.free(redIds)\n  }\n\n  return retval\n}\n\n\nvar RESULT\n\nfunction appendItem(i,j) {\n  RESULT.push([i,j])\n}\n\nfunction intersectFullArray(x) {\n  RESULT = []\n  boxIntersect(x, x, appendItem, true)\n  return RESULT\n}\n\nfunction intersectBipartiteArray(x, y) {\n  RESULT = []\n  boxIntersect(x, y, appendItem, false)\n  return RESULT\n}\n\n//User-friendly wrapper, handle full input and no-visitor cases\nfunction boxIntersectWrapper(arg0, arg1, arg2) {\n  var result\n  switch(arguments.length) {\n    case 1:\n      return intersectFullArray(arg0)\n    case 2:\n      if(typeof arg1 === 'function') {\n        return boxIntersect(arg0, arg0, arg1, true)\n      } else {\n        return intersectBipartiteArray(arg0, arg1)\n      }\n    case 3:\n      return boxIntersect(arg0, arg1, arg2, false)\n    default:\n      throw new Error('box-intersect: Invalid arguments')\n  }\n}","'use strict'\n\nvar DIMENSION   = 'd'\nvar AXIS        = 'ax'\nvar VISIT       = 'vv'\nvar FLIP        = 'fp'\n\nvar ELEM_SIZE   = 'es'\n\nvar RED_START   = 'rs'\nvar RED_END     = 're'\nvar RED_BOXES   = 'rb'\nvar RED_INDEX   = 'ri'\nvar RED_PTR     = 'rp'\n\nvar BLUE_START  = 'bs'\nvar BLUE_END    = 'be'\nvar BLUE_BOXES  = 'bb'\nvar BLUE_INDEX  = 'bi'\nvar BLUE_PTR    = 'bp'\n\nvar RETVAL      = 'rv'\n\nvar INNER_LABEL = 'Q'\n\nvar ARGS = [\n  DIMENSION,\n  AXIS,\n  VISIT,\n  RED_START,\n  RED_END,\n  RED_BOXES,\n  RED_INDEX,\n  BLUE_START,\n  BLUE_END,\n  BLUE_BOXES,\n  BLUE_INDEX\n]\n\nfunction generateBruteForce(redMajor, flip, full) {\n  var funcName = 'bruteForce' + \n    (redMajor ? 'Red' : 'Blue') + \n    (flip ? 'Flip' : '') +\n    (full ? 'Full' : '')\n\n  var code = ['function ', funcName, '(', ARGS.join(), '){',\n    'var ', ELEM_SIZE, '=2*', DIMENSION, ';']\n\n  var redLoop = \n    'for(var i=' + RED_START + ',' + RED_PTR + '=' + ELEM_SIZE + '*' + RED_START + ';' +\n        'i<' + RED_END +';' +\n        '++i,' + RED_PTR + '+=' + ELEM_SIZE + '){' +\n        'var x0=' + RED_BOXES + '[' + AXIS + '+' + RED_PTR + '],' +\n            'x1=' + RED_BOXES + '[' + AXIS + '+' + RED_PTR + '+' + DIMENSION + '],' +\n            'xi=' + RED_INDEX + '[i];'\n\n  var blueLoop = \n    'for(var j=' + BLUE_START + ',' + BLUE_PTR + '=' + ELEM_SIZE + '*' + BLUE_START + ';' +\n        'j<' + BLUE_END + ';' +\n        '++j,' + BLUE_PTR + '+=' + ELEM_SIZE + '){' +\n        'var y0=' + BLUE_BOXES + '[' + AXIS + '+' + BLUE_PTR + '],' +\n            (full ? 'y1=' + BLUE_BOXES + '[' + AXIS + '+' + BLUE_PTR + '+' + DIMENSION + '],' : '') +\n            'yi=' + BLUE_INDEX + '[j];'\n\n  if(redMajor) {\n    code.push(redLoop, INNER_LABEL, ':', blueLoop)\n  } else {\n    code.push(blueLoop, INNER_LABEL, ':', redLoop)\n  }\n\n  if(full) {\n    code.push('if(y1<x0||x1<y0)continue;')\n  } else if(flip) {\n    code.push('if(y0<=x0||x1<y0)continue;')\n  } else {\n    code.push('if(y0<x0||x1<y0)continue;')\n  }\n\n  code.push('for(var k='+AXIS+'+1;k<'+DIMENSION+';++k){'+\n    'var r0='+RED_BOXES+'[k+'+RED_PTR+'],'+\n        'r1='+RED_BOXES+'[k+'+DIMENSION+'+'+RED_PTR+'],'+\n        'b0='+BLUE_BOXES+'[k+'+BLUE_PTR+'],'+\n        'b1='+BLUE_BOXES+'[k+'+DIMENSION+'+'+BLUE_PTR+'];'+\n      'if(r1<b0||b1<r0)continue ' + INNER_LABEL + ';}' +\n      'var ' + RETVAL + '=' + VISIT + '(')\n\n  if(flip) {\n    code.push('yi,xi')\n  } else {\n    code.push('xi,yi')\n  }\n\n  code.push(');if(' + RETVAL + '!==void 0)return ' + RETVAL + ';}}}')\n\n  return {\n    name: funcName, \n    code: code.join('')\n  }\n}\n\nfunction bruteForcePlanner(full) {\n  var funcName = 'bruteForce' + (full ? 'Full' : 'Partial')\n  var prefix = []\n  var fargs = ARGS.slice()\n  if(!full) {\n    fargs.splice(3, 0, FLIP)\n  }\n\n  var code = ['function ' + funcName + '(' + fargs.join() + '){']\n\n  function invoke(redMajor, flip) {\n    var res = generateBruteForce(redMajor, flip, full)\n    prefix.push(res.code)\n    code.push('return ' + res.name + '(' + ARGS.join() + ');')\n  }\n\n  code.push('if(' + RED_END + '-' + RED_START + '>' +\n                    BLUE_END + '-' + BLUE_START + '){')\n\n  if(full) {\n    invoke(true, false)\n    code.push('}else{')\n    invoke(false, false)\n  } else {\n    code.push('if(' + FLIP + '){')\n    invoke(true, true)\n    code.push('}else{')\n    invoke(true, false)\n    code.push('}}else{if(' + FLIP + '){')\n    invoke(false, true)\n    code.push('}else{')\n    invoke(false, false)\n    code.push('}')\n  }\n  code.push('}}return ' + funcName)\n\n  var codeStr = prefix.join('') + code.join('')\n  var proc = new Function(codeStr)\n  return proc()\n}\n\n\nexports.partial = bruteForcePlanner(false)\nexports.full    = bruteForcePlanner(true)","'use strict'\n\nmodule.exports = boxIntersectIter\n\nvar pool = require('typedarray-pool')\nvar bits = require('bit-twiddle')\nvar bruteForce = require('./brute')\nvar bruteForcePartial = bruteForce.partial\nvar bruteForceFull = bruteForce.full\nvar sweep = require('./sweep')\nvar findMedian = require('./median')\nvar genPartition = require('./partition')\n\n//Twiddle parameters\nvar BRUTE_FORCE_CUTOFF    = 128       //Cut off for brute force search\nvar SCAN_CUTOFF           = (1<<22)   //Cut off for two way scan\nvar SCAN_COMPLETE_CUTOFF  = (1<<22)  \n\n//Partition functions\nvar partitionInteriorContainsInterval = genPartition(\n  '!(lo>=p0)&&!(p1>=hi)', \n  ['p0', 'p1'])\n\nvar partitionStartEqual = genPartition(\n  'lo===p0',\n  ['p0'])\n\nvar partitionStartLessThan = genPartition(\n  'lo<p0',\n  ['p0'])\n\nvar partitionEndLessThanEqual = genPartition(\n  'hi<=p0',\n  ['p0'])\n\nvar partitionContainsPoint = genPartition(\n  'lo<=p0&&p0<=hi',\n  ['p0'])\n\nvar partitionContainsPointProper = genPartition(\n  'lo<p0&&p0<=hi',\n  ['p0'])\n\n//Frame size for iterative loop\nvar IFRAME_SIZE = 6\nvar DFRAME_SIZE = 2\n\n//Data for box statck\nvar INIT_CAPACITY = 1024\nvar BOX_ISTACK  = pool.mallocInt32(INIT_CAPACITY)\nvar BOX_DSTACK  = pool.mallocDouble(INIT_CAPACITY)\n\n//Initialize iterative loop queue\nfunction iterInit(d, count) {\n  var levels = (8 * bits.log2(count+1) * (d+1))|0\n  var maxInts = bits.nextPow2(IFRAME_SIZE*levels)\n  if(BOX_ISTACK.length < maxInts) {\n    pool.free(BOX_ISTACK)\n    BOX_ISTACK = pool.mallocInt32(maxInts)\n  }\n  var maxDoubles = bits.nextPow2(DFRAME_SIZE*levels)\n  if(BOX_DSTACK < maxDoubles) {\n    pool.free(BOX_DSTACK)\n    BOX_DSTACK = pool.mallocDouble(maxDoubles)\n  }\n}\n\n//Append item to queue\nfunction iterPush(ptr,\n  axis, \n  redStart, redEnd, \n  blueStart, blueEnd, \n  state, \n  lo, hi) {\n\n  var iptr = IFRAME_SIZE * ptr\n  BOX_ISTACK[iptr]   = axis\n  BOX_ISTACK[iptr+1] = redStart\n  BOX_ISTACK[iptr+2] = redEnd\n  BOX_ISTACK[iptr+3] = blueStart\n  BOX_ISTACK[iptr+4] = blueEnd\n  BOX_ISTACK[iptr+5] = state\n\n  var dptr = DFRAME_SIZE * ptr\n  BOX_DSTACK[dptr]   = lo\n  BOX_DSTACK[dptr+1] = hi\n}\n\n//Special case:  Intersect single point with list of intervals\nfunction onePointPartial(\n  d, axis, visit, flip,\n  redStart, redEnd, red, redIndex,\n  blueOffset, blue, blueId) {\n\n  var elemSize = 2 * d\n  var bluePtr  = blueOffset * elemSize\n  var blueX    = blue[bluePtr + axis]\n\nred_loop:\n  for(var i=redStart, redPtr=redStart*elemSize; i<redEnd; ++i, redPtr+=elemSize) {\n    var r0 = red[redPtr+axis]\n    var r1 = red[redPtr+axis+d]\n    if(blueX < r0 || r1 < blueX) {\n      continue\n    }\n    if(flip && blueX === r0) {\n      continue\n    }\n    var redId = redIndex[i]\n    for(var j=axis+1; j<d; ++j) {\n      var r0 = red[redPtr+j]\n      var r1 = red[redPtr+j+d]\n      var b0 = blue[bluePtr+j]\n      var b1 = blue[bluePtr+j+d]\n      if(r1 < b0 || b1 < r0) {\n        continue red_loop\n      }\n    }\n    var retval\n    if(flip) {\n      retval = visit(blueId, redId)\n    } else {\n      retval = visit(redId, blueId)\n    }\n    if(retval !== void 0) {\n      return retval\n    }\n  }\n}\n\n//Special case:  Intersect one point with list of intervals\nfunction onePointFull(\n  d, axis, visit,\n  redStart, redEnd, red, redIndex,\n  blueOffset, blue, blueId) {\n\n  var elemSize = 2 * d\n  var bluePtr  = blueOffset * elemSize\n  var blueX    = blue[bluePtr + axis]\n\nred_loop:\n  for(var i=redStart, redPtr=redStart*elemSize; i<redEnd; ++i, redPtr+=elemSize) {\n    var redId = redIndex[i]\n    if(redId === blueId) {\n      continue\n    }\n    var r0 = red[redPtr+axis]\n    var r1 = red[redPtr+axis+d]\n    if(blueX < r0 || r1 < blueX) {\n      continue\n    }\n    for(var j=axis+1; j<d; ++j) {\n      var r0 = red[redPtr+j]\n      var r1 = red[redPtr+j+d]\n      var b0 = blue[bluePtr+j]\n      var b1 = blue[bluePtr+j+d]\n      if(r1 < b0 || b1 < r0) {\n        continue red_loop\n      }\n    }\n    var retval = visit(redId, blueId)\n    if(retval !== void 0) {\n      return retval\n    }\n  }\n}\n\n//The main box intersection routine\nfunction boxIntersectIter(\n  d, visit, initFull,\n  xSize, xBoxes, xIndex,\n  ySize, yBoxes, yIndex) {\n\n  //Reserve memory for stack\n  iterInit(d, xSize + ySize)\n\n  var top  = 0\n  var elemSize = 2 * d\n  var retval\n\n  iterPush(top++,\n      0,\n      0, xSize,\n      0, ySize,\n      initFull ? 16 : 0, \n      -Infinity, Infinity)\n  if(!initFull) {\n    iterPush(top++,\n      0,\n      0, ySize,\n      0, xSize,\n      1, \n      -Infinity, Infinity)\n  }\n\n  while(top > 0) {\n    top  -= 1\n\n    var iptr = top * IFRAME_SIZE\n    var axis      = BOX_ISTACK[iptr]\n    var redStart  = BOX_ISTACK[iptr+1]\n    var redEnd    = BOX_ISTACK[iptr+2]\n    var blueStart = BOX_ISTACK[iptr+3]\n    var blueEnd   = BOX_ISTACK[iptr+4]\n    var state     = BOX_ISTACK[iptr+5]\n\n    var dptr = top * DFRAME_SIZE\n    var lo        = BOX_DSTACK[dptr]\n    var hi        = BOX_DSTACK[dptr+1]\n\n    //Unpack state info\n    var flip      = (state & 1)\n    var full      = !!(state & 16)\n\n    //Unpack indices\n    var red       = xBoxes\n    var redIndex  = xIndex\n    var blue      = yBoxes\n    var blueIndex = yIndex\n    if(flip) {\n      red         = yBoxes\n      redIndex    = yIndex\n      blue        = xBoxes\n      blueIndex   = xIndex\n    }\n\n    if(state & 2) {\n      redEnd = partitionStartLessThan(\n        d, axis,\n        redStart, redEnd, red, redIndex,\n        hi)\n      if(redStart >= redEnd) {\n        continue\n      }\n    }\n    if(state & 4) {\n      redStart = partitionEndLessThanEqual(\n        d, axis,\n        redStart, redEnd, red, redIndex,\n        lo)\n      if(redStart >= redEnd) {\n        continue\n      }\n    }\n    \n    var redCount  = redEnd  - redStart\n    var blueCount = blueEnd - blueStart\n\n    if(full) {\n      if(d * redCount * (redCount + blueCount) < SCAN_COMPLETE_CUTOFF) {\n        retval = sweep.scanComplete(\n          d, axis, visit, \n          redStart, redEnd, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      }\n    } else {\n      if(d * Math.min(redCount, blueCount) < BRUTE_FORCE_CUTOFF) {\n        //If input small, then use brute force\n        retval = bruteForcePartial(\n            d, axis, visit, flip,\n            redStart,  redEnd,  red,  redIndex,\n            blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      } else if(d * redCount * blueCount < SCAN_CUTOFF) {\n        //If input medium sized, then use sweep and prune\n        retval = sweep.scanBipartite(\n          d, axis, visit, flip, \n          redStart, redEnd, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n        continue\n      }\n    }\n    \n    //First, find all red intervals whose interior contains (lo,hi)\n    var red0 = partitionInteriorContainsInterval(\n      d, axis, \n      redStart, redEnd, red, redIndex,\n      lo, hi)\n\n    //Lower dimensional case\n    if(redStart < red0) {\n\n      if(d * (red0 - redStart) < BRUTE_FORCE_CUTOFF) {\n        //Special case for small inputs: use brute force\n        retval = bruteForceFull(\n          d, axis+1, visit,\n          redStart, red0, red, redIndex,\n          blueStart, blueEnd, blue, blueIndex)\n        if(retval !== void 0) {\n          return retval\n        }\n      } else if(axis === d-2) {\n        if(flip) {\n          retval = sweep.sweepBipartite(\n            d, visit,\n            blueStart, blueEnd, blue, blueIndex,\n            redStart, red0, red, redIndex)\n        } else {\n          retval = sweep.sweepBipartite(\n            d, visit,\n            redStart, red0, red, redIndex,\n            blueStart, blueEnd, blue, blueIndex)\n        }\n        if(retval !== void 0) {\n          return retval\n        }\n      } else {\n        iterPush(top++,\n          axis+1,\n          redStart, red0,\n          blueStart, blueEnd,\n          flip,\n          -Infinity, Infinity)\n        iterPush(top++,\n          axis+1,\n          blueStart, blueEnd,\n          redStart, red0,\n          flip^1,\n          -Infinity, Infinity)\n      }\n    }\n\n    //Divide and conquer phase\n    if(red0 < redEnd) {\n\n      //Cut blue into 3 parts:\n      //\n      //  Points < mid point\n      //  Points = mid point\n      //  Points > mid point\n      //\n      var blue0 = findMedian(\n        d, axis, \n        blueStart, blueEnd, blue, blueIndex)\n      var mid = blue[elemSize * blue0 + axis]\n      var blue1 = partitionStartEqual(\n        d, axis,\n        blue0, blueEnd, blue, blueIndex,\n        mid)\n\n      //Right case\n      if(blue1 < blueEnd) {\n        iterPush(top++,\n          axis,\n          red0, redEnd,\n          blue1, blueEnd,\n          (flip|4) + (full ? 16 : 0),\n          mid, hi)\n      }\n\n      //Left case\n      if(blueStart < blue0) {\n        iterPush(top++,\n          axis,\n          red0, redEnd,\n          blueStart, blue0,\n          (flip|2) + (full ? 16 : 0),\n          lo, mid)\n      }\n\n      //Center case (the hard part)\n      if(blue0 + 1 === blue1) {\n        //Optimization: Range with exactly 1 point, use a brute force scan\n        if(full) {\n          retval = onePointFull(\n            d, axis, visit,\n            red0, redEnd, red, redIndex,\n            blue0, blue, blueIndex[blue0])\n        } else {\n          retval = onePointPartial(\n            d, axis, visit, flip,\n            red0, redEnd, red, redIndex,\n            blue0, blue, blueIndex[blue0])\n        }\n        if(retval !== void 0) {\n          return retval\n        }\n      } else if(blue0 < blue1) {\n        var red1\n        if(full) {\n          //If full intersection, need to handle special case\n          red1 = partitionContainsPoint(\n            d, axis,\n            red0, redEnd, red, redIndex,\n            mid)\n          if(red0 < red1) {\n            var redX = partitionStartEqual(\n              d, axis,\n              red0, red1, red, redIndex,\n              mid)\n            if(axis === d-2) {\n              //Degenerate sweep intersection:\n              //  [red0, redX] with [blue0, blue1]\n              if(red0 < redX) {\n                retval = sweep.sweepComplete(\n                  d, visit,\n                  red0, redX, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n                if(retval !== void 0) {\n                  return retval\n                }\n              }\n\n              //Normal sweep intersection:\n              //  [redX, red1] with [blue0, blue1]\n              if(redX < red1) {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  redX, red1, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n                if(retval !== void 0) {\n                  return retval\n                }\n              }\n            } else {\n              if(red0 < redX) {\n                iterPush(top++,\n                  axis+1,\n                  red0, redX,\n                  blue0, blue1,\n                  16,\n                  -Infinity, Infinity)\n              }\n              if(redX < red1) {\n                iterPush(top++,\n                  axis+1,\n                  redX, red1,\n                  blue0, blue1,\n                  0,\n                  -Infinity, Infinity)\n                iterPush(top++,\n                  axis+1,\n                  blue0, blue1,\n                  redX, red1,\n                  1,\n                  -Infinity, Infinity)\n              }\n            }\n          }\n        } else {\n          if(flip) {\n            red1 = partitionContainsPointProper(\n              d, axis,\n              red0, redEnd, red, redIndex,\n              mid)\n          } else {\n            red1 = partitionContainsPoint(\n              d, axis,\n              red0, redEnd, red, redIndex,\n              mid)\n          }\n          if(red0 < red1) {\n            if(axis === d-2) {\n              if(flip) {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  blue0, blue1, blue, blueIndex,\n                  red0, red1, red, redIndex)\n              } else {\n                retval = sweep.sweepBipartite(\n                  d, visit,\n                  red0, red1, red, redIndex,\n                  blue0, blue1, blue, blueIndex)\n              }\n            } else {\n              iterPush(top++,\n                axis+1,\n                red0, red1,\n                blue0, blue1,\n                flip,\n                -Infinity, Infinity)\n              iterPush(top++,\n                axis+1,\n                blue0, blue1,\n                red0, red1,\n                flip^1,\n                -Infinity, Infinity)\n            }\n          }\n        }\n      }\n    }\n  }\n}","'use strict'\n\nmodule.exports = findMedian\n\nvar genPartition = require('./partition')\n\nvar partitionStartLessThan = genPartition('lo<p0', ['p0'])\n\nvar PARTITION_THRESHOLD = 8   //Cut off for using insertion sort in findMedian\n\n//Base case for median finding:  Use insertion sort\nfunction insertionSort(d, axis, start, end, boxes, ids) {\n  var elemSize = 2 * d\n  var boxPtr = elemSize * (start+1) + axis\n  for(var i=start+1; i<end; ++i, boxPtr+=elemSize) {\n    var x = boxes[boxPtr]\n    for(var j=i, ptr=elemSize*(i-1); \n        j>start && boxes[ptr+axis] > x; \n        --j, ptr-=elemSize) {\n      //Swap\n      var aPtr = ptr\n      var bPtr = ptr+elemSize\n      for(var k=0; k<elemSize; ++k, ++aPtr, ++bPtr) {\n        var y = boxes[aPtr]\n        boxes[aPtr] = boxes[bPtr]\n        boxes[bPtr] = y\n      }\n      var tmp = ids[j]\n      ids[j] = ids[j-1]\n      ids[j-1] = tmp\n    }\n  }\n}\n\n//Find median using quick select algorithm\n//  takes O(n) time with high probability\nfunction findMedian(d, axis, start, end, boxes, ids) {\n  if(end <= start+1) {\n    return start\n  }\n\n  var lo       = start\n  var hi       = end\n  var mid      = ((end + start) >>> 1)\n  var elemSize = 2*d\n  var pivot    = mid\n  var value    = boxes[elemSize*mid+axis]\n  \n  while(lo < hi) {\n    if(hi - lo < PARTITION_THRESHOLD) {\n      insertionSort(d, axis, lo, hi, boxes, ids)\n      value = boxes[elemSize*mid+axis]\n      break\n    }\n    \n    //Select pivot using median-of-3\n    var count  = hi - lo\n    var pivot0 = (Math.random()*count+lo)|0\n    var value0 = boxes[elemSize*pivot0 + axis]\n    var pivot1 = (Math.random()*count+lo)|0\n    var value1 = boxes[elemSize*pivot1 + axis]\n    var pivot2 = (Math.random()*count+lo)|0\n    var value2 = boxes[elemSize*pivot2 + axis]\n    if(value0 <= value1) {\n      if(value2 >= value1) {\n        pivot = pivot1\n        value = value1\n      } else if(value0 >= value2) {\n        pivot = pivot0\n        value = value0\n      } else {\n        pivot = pivot2\n        value = value2\n      }\n    } else {\n      if(value1 >= value2) {\n        pivot = pivot1\n        value = value1\n      } else if(value2 >= value0) {\n        pivot = pivot0\n        value = value0\n      } else {\n        pivot = pivot2\n        value = value2\n      }\n    }\n\n    //Swap pivot to end of array\n    var aPtr = elemSize * (hi-1)\n    var bPtr = elemSize * pivot\n    for(var i=0; i<elemSize; ++i, ++aPtr, ++bPtr) {\n      var x = boxes[aPtr]\n      boxes[aPtr] = boxes[bPtr]\n      boxes[bPtr] = x\n    }\n    var y = ids[hi-1]\n    ids[hi-1] = ids[pivot]\n    ids[pivot] = y\n\n    //Partition using pivot\n    pivot = partitionStartLessThan(\n      d, axis, \n      lo, hi-1, boxes, ids,\n      value)\n\n    //Swap pivot back\n    var aPtr = elemSize * (hi-1)\n    var bPtr = elemSize * pivot\n    for(var i=0; i<elemSize; ++i, ++aPtr, ++bPtr) {\n      var x = boxes[aPtr]\n      boxes[aPtr] = boxes[bPtr]\n      boxes[bPtr] = x\n    }\n    var y = ids[hi-1]\n    ids[hi-1] = ids[pivot]\n    ids[pivot] = y\n\n    //Swap pivot to last pivot\n    if(mid < pivot) {\n      hi = pivot-1\n      while(lo < hi && \n        boxes[elemSize*(hi-1)+axis] === value) {\n        hi -= 1\n      }\n      hi += 1\n    } else if(pivot < mid) {\n      lo = pivot + 1\n      while(lo < hi &&\n        boxes[elemSize*lo+axis] === value) {\n        lo += 1\n      }\n    } else {\n      break\n    }\n  }\n\n  //Make sure pivot is at start\n  return partitionStartLessThan(\n    d, axis, \n    start, mid, boxes, ids,\n    boxes[elemSize*mid+axis])\n}","'use strict'\n\nmodule.exports = genPartition\n\nvar code = 'for(var j=2*a,k=j*c,l=k,m=c,n=b,o=a+b,p=c;d>p;++p,k+=j){var _;if($)if(m===p)m+=1,l+=j;else{for(var s=0;j>s;++s){var t=e[k+s];e[k+s]=e[l],e[l++]=t}var u=f[p];f[p]=f[m],f[m++]=u}}return m'\n\nfunction genPartition(predicate, args) {\n  var fargs ='abcdef'.split('').concat(args)\n  var reads = []\n  if(predicate.indexOf('lo') >= 0) {\n    reads.push('lo=e[k+n]')\n  }\n  if(predicate.indexOf('hi') >= 0) {\n    reads.push('hi=e[k+o]')\n  }\n  fargs.push(\n    code.replace('_', reads.join())\n        .replace('$', predicate))\n  return Function.apply(void 0, fargs)\n}","'use strict';\n\n//This code is extracted from ndarray-sort\n//It is inlined here as a temporary workaround\n\nmodule.exports = wrapper;\n\nvar INSERT_SORT_CUTOFF = 32\n\nfunction wrapper(data, n0) {\n  if (n0 <= 4*INSERT_SORT_CUTOFF) {\n    insertionSort(0, n0 - 1, data);\n  } else {\n    quickSort(0, n0 - 1, data);\n  }\n}\n\nfunction insertionSort(left, right, data) {\n  var ptr = 2*(left+1)\n  for(var i=left+1; i<=right; ++i) {\n    var a = data[ptr++]\n    var b = data[ptr++]\n    var j = i\n    var jptr = ptr-2\n    while(j-- > left) {\n      var x = data[jptr-2]\n      var y = data[jptr-1]\n      if(x < a) {\n        break\n      } else if(x === a && y < b) {\n        break\n      }\n      data[jptr]   = x\n      data[jptr+1] = y\n      jptr -= 2\n    }\n    data[jptr]   = a\n    data[jptr+1] = b\n  }\n}\n\nfunction swap(i, j, data) {\n  i *= 2\n  j *= 2\n  var x = data[i]\n  var y = data[i+1]\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n  data[j] = x\n  data[j+1] = y\n}\n\nfunction move(i, j, data) {\n  i *= 2\n  j *= 2\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n}\n\nfunction rotate(i, j, k, data) {\n  i *= 2\n  j *= 2\n  k *= 2\n  var x = data[i]\n  var y = data[i+1]\n  data[i] = data[j]\n  data[i+1] = data[j+1]\n  data[j] = data[k]\n  data[j+1] = data[k+1]\n  data[k] = x\n  data[k+1] = y\n}\n\nfunction shufflePivot(i, j, px, py, data) {\n  i *= 2\n  j *= 2\n  data[i] = data[j]\n  data[j] = px\n  data[i+1] = data[j+1]\n  data[j+1] = py\n}\n\nfunction compare(i, j, data) {\n  i *= 2\n  j *= 2\n  var x = data[i],\n      y = data[j]\n  if(x < y) {\n    return false\n  } else if(x === y) {\n    return data[i+1] > data[j+1]\n  }\n  return true\n}\n\nfunction comparePivot(i, y, b, data) {\n  i *= 2\n  var x = data[i]\n  if(x < y) {\n    return true\n  } else if(x === y) {\n    return data[i+1] < b\n  }\n  return false\n}\n\nfunction quickSort(left, right, data) {\n  var sixth = (right - left + 1) / 6 | 0, \n      index1 = left + sixth, \n      index5 = right - sixth, \n      index3 = left + right >> 1, \n      index2 = index3 - sixth, \n      index4 = index3 + sixth, \n      el1 = index1, \n      el2 = index2, \n      el3 = index3, \n      el4 = index4, \n      el5 = index5, \n      less = left + 1, \n      great = right - 1, \n      tmp = 0\n  if(compare(el1, el2, data)) {\n    tmp = el1\n    el1 = el2\n    el2 = tmp\n  }\n  if(compare(el4, el5, data)) {\n    tmp = el4\n    el4 = el5\n    el5 = tmp\n  }\n  if(compare(el1, el3, data)) {\n    tmp = el1\n    el1 = el3\n    el3 = tmp\n  }\n  if(compare(el2, el3, data)) {\n    tmp = el2\n    el2 = el3\n    el3 = tmp\n  }\n  if(compare(el1, el4, data)) {\n    tmp = el1\n    el1 = el4\n    el4 = tmp\n  }\n  if(compare(el3, el4, data)) {\n    tmp = el3\n    el3 = el4\n    el4 = tmp\n  }\n  if(compare(el2, el5, data)) {\n    tmp = el2\n    el2 = el5\n    el5 = tmp\n  }\n  if(compare(el2, el3, data)) {\n    tmp = el2\n    el2 = el3\n    el3 = tmp\n  }\n  if(compare(el4, el5, data)) {\n    tmp = el4\n    el4 = el5\n    el5 = tmp\n  }\n\n  var pivot1X = data[2*el2]\n  var pivot1Y = data[2*el2+1]\n  var pivot2X = data[2*el4]\n  var pivot2Y = data[2*el4+1]\n\n  var ptr0 = 2 * el1;\n  var ptr2 = 2 * el3;\n  var ptr4 = 2 * el5;\n  var ptr5 = 2 * index1;\n  var ptr6 = 2 * index3;\n  var ptr7 = 2 * index5;\n  for (var i1 = 0; i1 < 2; ++i1) {\n    var x = data[ptr0+i1];\n    var y = data[ptr2+i1];\n    var z = data[ptr4+i1];\n    data[ptr5+i1] = x;\n    data[ptr6+i1] = y;\n    data[ptr7+i1] = z;\n  }\n\n  move(index2, left, data)\n  move(index4, right, data)\n  for (var k = less; k <= great; ++k) {\n    if (comparePivot(k, pivot1X, pivot1Y, data)) {\n      if (k !== less) {\n        swap(k, less, data)\n      }\n      ++less;\n    } else {\n      if (!comparePivot(k, pivot2X, pivot2Y, data)) {\n        while (true) {\n          if (!comparePivot(great, pivot2X, pivot2Y, data)) {\n            if (--great < k) {\n              break;\n            }\n            continue;\n          } else {\n            if (comparePivot(great, pivot1X, pivot1Y, data)) {\n              rotate(k, less, great, data)\n              ++less;\n              --great;\n            } else {\n              swap(k, great, data)\n              --great;\n            }\n            break;\n          }\n        }\n      }\n    }\n  }\n  shufflePivot(left, less-1, pivot1X, pivot1Y, data)\n  shufflePivot(right, great+1, pivot2X, pivot2Y, data)\n  if (less - 2 - left <= INSERT_SORT_CUTOFF) {\n    insertionSort(left, less - 2, data);\n  } else {\n    quickSort(left, less - 2, data);\n  }\n  if (right - (great + 2) <= INSERT_SORT_CUTOFF) {\n    insertionSort(great + 2, right, data);\n  } else {\n    quickSort(great + 2, right, data);\n  }\n  if (great - less <= INSERT_SORT_CUTOFF) {\n    insertionSort(less, great, data);\n  } else {\n    quickSort(less, great, data);\n  }\n}","'use strict'\n\nmodule.exports = {\n  init:           sqInit,\n  sweepBipartite: sweepBipartite,\n  sweepComplete:  sweepComplete,\n  scanBipartite:  scanBipartite,\n  scanComplete:   scanComplete\n}\n\nvar pool  = require('typedarray-pool')\nvar bits  = require('bit-twiddle')\nvar isort = require('./sort')\n\n//Flag for blue\nvar BLUE_FLAG = (1<<28)\n\n//1D sweep event queue stuff (use pool to save space)\nvar INIT_CAPACITY      = 1024\nvar RED_SWEEP_QUEUE    = pool.mallocInt32(INIT_CAPACITY)\nvar RED_SWEEP_INDEX    = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_QUEUE   = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_INDEX   = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_QUEUE = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_INDEX = pool.mallocInt32(INIT_CAPACITY)\nvar SWEEP_EVENTS       = pool.mallocDouble(INIT_CAPACITY * 8)\n\n//Reserves memory for the 1D sweep data structures\nfunction sqInit(count) {\n  var rcount = bits.nextPow2(count)\n  if(RED_SWEEP_QUEUE.length < rcount) {\n    pool.free(RED_SWEEP_QUEUE)\n    RED_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(RED_SWEEP_INDEX.length < rcount) {\n    pool.free(RED_SWEEP_INDEX)\n    RED_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  if(BLUE_SWEEP_QUEUE.length < rcount) {\n    pool.free(BLUE_SWEEP_QUEUE)\n    BLUE_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(BLUE_SWEEP_INDEX.length < rcount) {\n    pool.free(BLUE_SWEEP_INDEX)\n    BLUE_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  if(COMMON_SWEEP_QUEUE.length < rcount) {\n    pool.free(COMMON_SWEEP_QUEUE)\n    COMMON_SWEEP_QUEUE = pool.mallocInt32(rcount)\n  }\n  if(COMMON_SWEEP_INDEX.length < rcount) {\n    pool.free(COMMON_SWEEP_INDEX)\n    COMMON_SWEEP_INDEX = pool.mallocInt32(rcount)\n  }\n  var eventLength = 8 * rcount\n  if(SWEEP_EVENTS.length < eventLength) {\n    pool.free(SWEEP_EVENTS)\n    SWEEP_EVENTS = pool.mallocDouble(eventLength)\n  }\n}\n\n//Remove an item from the active queue in O(1)\nfunction sqPop(queue, index, count, item) {\n  var idx = index[item]\n  var top = queue[count-1]\n  queue[idx] = top\n  index[top] = idx\n}\n\n//Insert an item into the active queue in O(1)\nfunction sqPush(queue, index, count, item) {\n  queue[count] = item\n  index[item]  = count\n}\n\n//Recursion base case: use 1D sweep algorithm\nfunction sweepBipartite(\n    d, visit,\n    redStart,  redEnd, red, redIndex,\n    blueStart, blueEnd, blue, blueIndex) {\n\n  //store events as pairs [coordinate, idx]\n  //\n  //  red create:  -(idx+1)\n  //  red destroy: idx\n  //  blue create: -(idx+BLUE_FLAG)\n  //  blue destroy: idx+BLUE_FLAG\n  //\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = d-1\n  var iend     = elemSize-1\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = redIndex[i]\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -(idx+1)\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = blueIndex[i]+BLUE_FLAG\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive  = 0\n  var blueActive = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e >= BLUE_FLAG) {\n      //blue destroy event\n      e = (e-BLUE_FLAG)|0\n      sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, e)\n    } else if(e >= 0) {\n      //red destroy event\n      sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, e)\n    } else if(e <= -BLUE_FLAG) {\n      //blue create event\n      e = (-e-BLUE_FLAG)|0\n      for(var j=0; j<redActive; ++j) {\n        var retval = visit(RED_SWEEP_QUEUE[j], e)\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n      sqPush(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive++, e)\n    } else {\n      //red create event\n      e = (-e-1)|0\n      for(var j=0; j<blueActive; ++j) {\n        var retval = visit(e, BLUE_SWEEP_QUEUE[j])\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n      sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, e)\n    }\n  }\n}\n\n//Complete sweep\nfunction sweepComplete(d, visit, \n  redStart, redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = d-1\n  var iend     = elemSize-1\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = (redIndex[i]+1)<<1\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = (blueIndex[i]+1)<<1\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = (-idx)|1\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx|1\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  var blueActive   = 0\n  var commonActive = 0\n  for(var i=0; i<n; ++i) {\n    var e     = SWEEP_EVENTS[2*i+1]|0\n    var color = e&1\n    if(i < n-1 && (e>>1) === (SWEEP_EVENTS[2*i+3]>>1)) {\n      color = 2\n      i += 1\n    }\n    \n    if(e < 0) {\n      //Create event\n      var id = -(e>>1) - 1\n\n      //Intersect with common\n      for(var j=0; j<commonActive; ++j) {\n        var retval = visit(COMMON_SWEEP_QUEUE[j], id)\n        if(retval !== void 0) {\n          return retval\n        }\n      }\n\n      if(color !== 0) {\n        //Intersect with red\n        for(var j=0; j<redActive; ++j) {\n          var retval = visit(RED_SWEEP_QUEUE[j], id)\n          if(retval !== void 0) {\n            return retval\n          }\n        }\n      }\n\n      if(color !== 1) {\n        //Intersect with blue\n        for(var j=0; j<blueActive; ++j) {\n          var retval = visit(BLUE_SWEEP_QUEUE[j], id)\n          if(retval !== void 0) {\n            return retval\n          }\n        }\n      }\n\n      if(color === 0) {\n        //Red\n        sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, id)\n      } else if(color === 1) {\n        //Blue\n        sqPush(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive++, id)\n      } else if(color === 2) {\n        //Both\n        sqPush(COMMON_SWEEP_QUEUE, COMMON_SWEEP_INDEX, commonActive++, id)\n      }\n    } else {\n      //Destroy event\n      var id = (e>>1) - 1\n      if(color === 0) {\n        //Red\n        sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, id)\n      } else if(color === 1) {\n        //Blue\n        sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, id)\n      } else if(color === 2) {\n        //Both\n        sqPop(COMMON_SWEEP_QUEUE, COMMON_SWEEP_INDEX, commonActive--, id)\n      }\n    }\n  }\n}\n\n//Sweep and prune/scanline algorithm:\n//  Scan along axis, detect intersections\n//  Brute force all boxes along axis\nfunction scanBipartite(\n  d, axis, visit, flip,\n  redStart,  redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n  \n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = axis\n  var iend     = axis+d\n\n  var redShift  = 1\n  var blueShift = 1\n  if(flip) {\n    blueShift = BLUE_FLAG\n  } else {\n    redShift  = BLUE_FLAG\n  }\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = i + redShift\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = i + blueShift\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e < 0) {\n      var idx   = -e\n      var isRed = false\n      if(idx >= BLUE_FLAG) {\n        isRed = !flip\n        idx -= BLUE_FLAG \n      } else {\n        isRed = !!flip\n        idx -= 1\n      }\n      if(isRed) {\n        sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, idx)\n      } else {\n        var blueId  = blueIndex[idx]\n        var bluePtr = elemSize * idx\n        \n        var b0 = blue[bluePtr+axis+1]\n        var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n        for(var j=0; j<redActive; ++j) {\n          var oidx   = RED_SWEEP_QUEUE[j]\n          var redPtr = elemSize * oidx\n\n          if(b1 < red[redPtr+axis+1] || \n             red[redPtr+axis+1+d] < b0) {\n            continue\n          }\n\n          for(var k=axis+2; k<d; ++k) {\n            if(blue[bluePtr + k + d] < red[redPtr + k] || \n               red[redPtr + k + d] < blue[bluePtr + k]) {\n              continue red_loop\n            }\n          }\n\n          var redId  = redIndex[oidx]\n          var retval\n          if(flip) {\n            retval = visit(blueId, redId)\n          } else {\n            retval = visit(redId, blueId)\n          }\n          if(retval !== void 0) {\n            return retval \n          }\n        }\n      }\n    } else {\n      sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, e - redShift)\n    }\n  }\n}\n\nfunction scanComplete(\n  d, axis, visit,\n  redStart,  redEnd, red, redIndex,\n  blueStart, blueEnd, blue, blueIndex) {\n\n  var ptr      = 0\n  var elemSize = 2*d\n  var istart   = axis\n  var iend     = axis+d\n\n  for(var i=redStart; i<redEnd; ++i) {\n    var idx = i + BLUE_FLAG\n    var redOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = red[redOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n    SWEEP_EVENTS[ptr++] = red[redOffset+iend]\n    SWEEP_EVENTS[ptr++] = idx\n  }\n  for(var i=blueStart; i<blueEnd; ++i) {\n    var idx = i + 1\n    var blueOffset = elemSize*i\n    SWEEP_EVENTS[ptr++] = blue[blueOffset+istart]\n    SWEEP_EVENTS[ptr++] = -idx\n  }\n\n  //process events from left->right\n  var n = ptr >>> 1\n  isort(SWEEP_EVENTS, n)\n  \n  var redActive    = 0\n  for(var i=0; i<n; ++i) {\n    var e = SWEEP_EVENTS[2*i+1]|0\n    if(e < 0) {\n      var idx   = -e\n      if(idx >= BLUE_FLAG) {\n        RED_SWEEP_QUEUE[redActive++] = idx - BLUE_FLAG\n      } else {\n        idx -= 1\n        var blueId  = blueIndex[idx]\n        var bluePtr = elemSize * idx\n\n        var b0 = blue[bluePtr+axis+1]\n        var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n        for(var j=0; j<redActive; ++j) {\n          var oidx   = RED_SWEEP_QUEUE[j]\n          var redId  = redIndex[oidx]\n\n          if(redId === blueId) {\n            break\n          }\n\n          var redPtr = elemSize * oidx\n          if(b1 < red[redPtr+axis+1] || \n            red[redPtr+axis+1+d] < b0) {\n            continue\n          }\n          for(var k=axis+2; k<d; ++k) {\n            if(blue[bluePtr + k + d] < red[redPtr + k] || \n               red[redPtr + k + d]   < blue[bluePtr + k]) {\n              continue red_loop\n            }\n          }\n\n          var retval = visit(redId, blueId)\n          if(retval !== void 0) {\n            return retval \n          }\n        }\n      }\n    } else {\n      var idx = e - BLUE_FLAG\n      for(var j=redActive-1; j>=0; --j) {\n        if(RED_SWEEP_QUEUE[j] === idx) {\n          for(var k=j+1; k<redActive; ++k) {\n            RED_SWEEP_QUEUE[k-1] = RED_SWEEP_QUEUE[k]\n          }\n          break\n        }\n      }\n      --redActive\n    }\n  }\n}","/**\n * Bit twiddling hacks for JavaScript.\n *\n * Author: Mikola Lysenko\n *\n * Ported from Stanford bit twiddling hack library:\n *    http://graphics.stanford.edu/~seander/bithacks.html\n */\n\n\"use strict\"; \"use restrict\";\n\n//Number of bits in an integer\nvar INT_BITS = 32;\n\n//Constants\nexports.INT_BITS  = INT_BITS;\nexports.INT_MAX   =  0x7fffffff;\nexports.INT_MIN   = -1<<(INT_BITS-1);\n\n//Returns -1, 0, +1 depending on sign of x\nexports.sign = function(v) {\n  return (v > 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n  var mask = v >> (INT_BITS-1);\n  return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n  return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n  return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n  return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n  var r, shift;\n  r =     (v > 0xFFFF) << 4; v >>>= r;\n  shift = (v > 0xFF  ) << 3; v >>>= shift; r |= shift;\n  shift = (v > 0xF   ) << 2; v >>>= shift; r |= shift;\n  shift = (v > 0x3   ) << 1; v >>>= shift; r |= shift;\n  return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n  return  (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n          (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n          (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n  v = v - ((v >>> 1) & 0x55555555);\n  v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n  return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n  var c = 32;\n  v &= -v;\n  if (v) c--;\n  if (v & 0x0000FFFF) c -= 16;\n  if (v & 0x00FF00FF) c -= 8;\n  if (v & 0x0F0F0F0F) c -= 4;\n  if (v & 0x33333333) c -= 2;\n  if (v & 0x55555555) c -= 1;\n  return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n  v += v === 0;\n  --v;\n  v |= v >>> 1;\n  v |= v >>> 2;\n  v |= v >>> 4;\n  v |= v >>> 8;\n  v |= v >>> 16;\n  return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n  v |= v >>> 1;\n  v |= v >>> 2;\n  v |= v >>> 4;\n  v |= v >>> 8;\n  v |= v >>> 16;\n  return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n  v ^= v >>> 16;\n  v ^= v >>> 8;\n  v ^= v >>> 4;\n  v &= 0xf;\n  return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n  for(var i=0; i<256; ++i) {\n    var v = i, r = i, s = 7;\n    for (v >>>= 1; v; v >>>= 1) {\n      r <<= 1;\n      r |= v & 1;\n      --s;\n    }\n    tab[i] = (r << s) & 0xff;\n  }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n  return  (REVERSE_TABLE[ v         & 0xff] << 24) |\n          (REVERSE_TABLE[(v >>> 8)  & 0xff] << 16) |\n          (REVERSE_TABLE[(v >>> 16) & 0xff] << 8)  |\n           REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits.  Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n  x &= 0xFFFF;\n  x = (x | (x << 8)) & 0x00FF00FF;\n  x = (x | (x << 4)) & 0x0F0F0F0F;\n  x = (x | (x << 2)) & 0x33333333;\n  x = (x | (x << 1)) & 0x55555555;\n\n  y &= 0xFFFF;\n  y = (y | (y << 8)) & 0x00FF00FF;\n  y = (y | (y << 4)) & 0x0F0F0F0F;\n  y = (y | (y << 2)) & 0x33333333;\n  y = (y | (y << 1)) & 0x55555555;\n\n  return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n  v = (v >>> n) & 0x55555555;\n  v = (v | (v >>> 1))  & 0x33333333;\n  v = (v | (v >>> 2))  & 0x0F0F0F0F;\n  v = (v | (v >>> 4))  & 0x00FF00FF;\n  v = (v | (v >>> 16)) & 0x000FFFF;\n  return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits.  Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n  x &= 0x3FF;\n  x  = (x | (x<<16)) & 4278190335;\n  x  = (x | (x<<8))  & 251719695;\n  x  = (x | (x<<4))  & 3272356035;\n  x  = (x | (x<<2))  & 1227133513;\n\n  y &= 0x3FF;\n  y  = (y | (y<<16)) & 4278190335;\n  y  = (y | (y<<8))  & 251719695;\n  y  = (y | (y<<4))  & 3272356035;\n  y  = (y | (y<<2))  & 1227133513;\n  x |= (y << 1);\n  \n  z &= 0x3FF;\n  z  = (z | (z<<16)) & 4278190335;\n  z  = (z | (z<<8))  & 251719695;\n  z  = (z | (z<<4))  & 3272356035;\n  z  = (z | (z<<2))  & 1227133513;\n  \n  return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n  v = (v >>> n)       & 1227133513;\n  v = (v | (v>>>2))   & 3272356035;\n  v = (v | (v>>>4))   & 251719695;\n  v = (v | (v>>>8))   & 4278190335;\n  v = (v | (v>>>16))  & 0x3FF;\n  return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n  var t = v | (v - 1);\n  return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n","\"use strict\"\n\nfunction dupe_array(count, value, i) {\n  var c = count[i]|0\n  if(c <= 0) {\n    return []\n  }\n  var result = new Array(c), j\n  if(i === count.length-1) {\n    for(j=0; j<c; ++j) {\n      result[j] = value\n    }\n  } else {\n    for(j=0; j<c; ++j) {\n      result[j] = dupe_array(count, value, i+1)\n    }\n  }\n  return result\n}\n\nfunction dupe_number(count, value) {\n  var result, i\n  result = new Array(count)\n  for(i=0; i<count; ++i) {\n    result[i] = value\n  }\n  return result\n}\n\nfunction dupe(count, value) {\n  if(typeof value === \"undefined\") {\n    value = 0\n  }\n  switch(typeof count) {\n    case \"number\":\n      if(count > 0) {\n        return dupe_number(count|0, value)\n      }\n    break\n    case \"object\":\n      if(typeof (count.length) === \"number\") {\n        return dupe_array(count, value, 0)\n      }\n    break\n  }\n  return []\n}\n\nmodule.exports = dupe","(function (global,Buffer){\n'use strict'\n\nvar bits = require('bit-twiddle')\nvar dup = require('dup')\n\n//Legacy pool support\nif(!global.__TYPEDARRAY_POOL) {\n  global.__TYPEDARRAY_POOL = {\n      UINT8   : dup([32, 0])\n    , UINT16  : dup([32, 0])\n    , UINT32  : dup([32, 0])\n    , INT8    : dup([32, 0])\n    , INT16   : dup([32, 0])\n    , INT32   : dup([32, 0])\n    , FLOAT   : dup([32, 0])\n    , DOUBLE  : dup([32, 0])\n    , DATA    : dup([32, 0])\n    , UINT8C  : dup([32, 0])\n    , BUFFER  : dup([32, 0])\n  }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar POOL = global.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n  POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n  POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA    = POOL.DATA\n  , BUFFER  = POOL.BUFFER\n\nexports.free = function free(array) {\n  if(Buffer.isBuffer(array)) {\n    BUFFER[bits.log2(array.length)].push(array)\n  } else {\n    if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n      array = array.buffer\n    }\n    if(!array) {\n      return\n    }\n    var n = array.length || array.byteLength\n    var log_n = bits.log2(n)|0\n    DATA[log_n].push(array)\n  }\n}\n\nfunction freeArrayBuffer(buffer) {\n  if(!buffer) {\n    return\n  }\n  var n = buffer.length || buffer.byteLength\n  var log_n = bits.log2(n)\n  DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n  freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n  BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n  if(dtype === undefined || dtype === 'arraybuffer') {\n    return mallocArrayBuffer(n)\n  } else {\n    switch(dtype) {\n      case 'uint8':\n        return mallocUint8(n)\n      case 'uint16':\n        return mallocUint16(n)\n      case 'uint32':\n        return mallocUint32(n)\n      case 'int8':\n        return mallocInt8(n)\n      case 'int16':\n        return mallocInt16(n)\n      case 'int32':\n        return mallocInt32(n)\n      case 'float':\n      case 'float32':\n        return mallocFloat(n)\n      case 'double':\n      case 'float64':\n        return mallocDouble(n)\n      case 'uint8_clamped':\n        return mallocUint8Clamped(n)\n      case 'buffer':\n        return mallocBuffer(n)\n      case 'data':\n      case 'dataview':\n        return mallocDataView(n)\n\n      default:\n        return null\n    }\n  }\n  return null\n}\n\nfunction mallocArrayBuffer(n) {\n  var n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var d = DATA[log_n]\n  if(d.length > 0) {\n    return d.pop()\n  }\n  return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n  return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n  return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n  return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n  return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n  return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n  return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n  return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n  return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n  if(hasUint8C) {\n    return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n  } else {\n    return mallocUint8(n)\n  }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocDataView(n) {\n  return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n  n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var cache = BUFFER[log_n]\n  if(cache.length > 0) {\n    return cache.pop()\n  }\n  return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n  for(var i=0; i<32; ++i) {\n    POOL.UINT8[i].length = 0\n    POOL.UINT16[i].length = 0\n    POOL.UINT32[i].length = 0\n    POOL.INT8[i].length = 0\n    POOL.INT16[i].length = 0\n    POOL.INT32[i].length = 0\n    POOL.FLOAT[i].length = 0\n    POOL.DOUBLE[i].length = 0\n    POOL.UINT8C[i].length = 0\n    DATA[i].length = 0\n    BUFFER[i].length = 0\n  }\n}\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {},require(\"buffer\").Buffer)\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/box-intersect/node_modules/typedarray-pool/pool.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["'use strict'\n\nvar bits = require('bit-twiddle')\nvar dup = require('dup')\n\n//Legacy pool support\nif(!global.__TYPEDARRAY_POOL) {\n  global.__TYPEDARRAY_POOL = {\n      UINT8   : dup([32, 0])\n    , UINT16  : dup([32, 0])\n    , UINT32  : dup([32, 0])\n    , INT8    : dup([32, 0])\n    , INT16   : dup([32, 0])\n    , INT32   : dup([32, 0])\n    , FLOAT   : dup([32, 0])\n    , DOUBLE  : dup([32, 0])\n    , DATA    : dup([32, 0])\n    , UINT8C  : dup([32, 0])\n    , BUFFER  : dup([32, 0])\n  }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar POOL = global.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n  POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n  POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA    = POOL.DATA\n  , BUFFER  = POOL.BUFFER\n\nexports.free = function free(array) {\n  if(Buffer.isBuffer(array)) {\n    BUFFER[bits.log2(array.length)].push(array)\n  } else {\n    if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n      array = array.buffer\n    }\n    if(!array) {\n      return\n    }\n    var n = array.length || array.byteLength\n    var log_n = bits.log2(n)|0\n    DATA[log_n].push(array)\n  }\n}\n\nfunction freeArrayBuffer(buffer) {\n  if(!buffer) {\n    return\n  }\n  var n = buffer.length || buffer.byteLength\n  var log_n = bits.log2(n)\n  DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n  freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n  BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n  if(dtype === undefined || dtype === 'arraybuffer') {\n    return mallocArrayBuffer(n)\n  } else {\n    switch(dtype) {\n      case 'uint8':\n        return mallocUint8(n)\n      case 'uint16':\n        return mallocUint16(n)\n      case 'uint32':\n        return mallocUint32(n)\n      case 'int8':\n        return mallocInt8(n)\n      case 'int16':\n        return mallocInt16(n)\n      case 'int32':\n        return mallocInt32(n)\n      case 'float':\n      case 'float32':\n        return mallocFloat(n)\n      case 'double':\n      case 'float64':\n        return mallocDouble(n)\n      case 'uint8_clamped':\n        return mallocUint8Clamped(n)\n      case 'buffer':\n        return mallocBuffer(n)\n      case 'data':\n      case 'dataview':\n        return mallocDataView(n)\n\n      default:\n        return null\n    }\n  }\n  return null\n}\n\nfunction mallocArrayBuffer(n) {\n  var n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var d = DATA[log_n]\n  if(d.length > 0) {\n    return d.pop()\n  }\n  return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n  return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n  return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n  return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n  return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n  return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n  return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n  return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n  return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n  if(hasUint8C) {\n    return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n  } else {\n    return mallocUint8(n)\n  }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocDataView(n) {\n  return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n  n = bits.nextPow2(n)\n  var log_n = bits.log2(n)\n  var cache = BUFFER[log_n]\n  if(cache.length > 0) {\n    return cache.pop()\n  }\n  return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n  for(var i=0; i<32; ++i) {\n    POOL.UINT8[i].length = 0\n    POOL.UINT16[i].length = 0\n    POOL.UINT32[i].length = 0\n    POOL.INT8[i].length = 0\n    POOL.INT16[i].length = 0\n    POOL.INT32[i].length = 0\n    POOL.FLOAT[i].length = 0\n    POOL.DOUBLE[i].length = 0\n    POOL.UINT8C[i].length = 0\n    DATA[i].length = 0\n    BUFFER[i].length = 0\n  }\n}"]}",null,"/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('is-array')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = Buffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192 // not used by this implementation\n\nvar kMaxLength = 0x3fffffff\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Note:\n *\n * - Implementation must support adding new properties to `Uint8Array` instances.\n *   Firefox 4-29 lacked support, fixed in Firefox 30+.\n *   See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *  - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *  - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *    incorrect length in some situations.\n *\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they will\n * get the Object implementation, which is slower but will work correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = (function () {\n  try {\n    var buf = new ArrayBuffer(0)\n    var arr = new Uint8Array(buf)\n    arr.foo = function () { return 42 }\n    return 42 === arr.foo() && // typed array instances can be augmented\n        typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n        new Uint8Array(1).subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  } catch (e) {\n    return false\n  }\n})()\n\n/**\n * Class: Buffer\n * =============\n *\n * The Buffer constructor returns instances of `Uint8Array` that are augmented\n * with function properties for all the node `Buffer` API functions. We use\n * `Uint8Array` so that square bracket notation works as expected -- it returns\n * a single octet.\n *\n * By augmenting the instances, we can avoid modifying the `Uint8Array`\n * prototype.\n */\nfunction Buffer (subject, encoding, noZero) {\n  if (!(this instanceof Buffer))\n    return new Buffer(subject, encoding, noZero)\n\n  var type = typeof subject\n\n  // Find the length\n  var length\n  if (type === 'number')\n    length = subject > 0 ? subject >>> 0 : 0\n  else if (type === 'string') {\n    if (encoding === 'base64')\n      subject = base64clean(subject)\n    length = Buffer.byteLength(subject, encoding)\n  } else if (type === 'object' && subject !== null) { // assume object is array-like\n    if (subject.type === 'Buffer' && isArray(subject.data))\n      subject = subject.data\n    length = +subject.length > 0 ? Math.floor(+subject.length) : 0\n  } else\n    throw new TypeError('must start with number, buffer, array or string')\n\n  if (this.length > kMaxLength)\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n      'size: 0x' + kMaxLength.toString(16) + ' bytes')\n\n  var buf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Preferred: Return an augmented `Uint8Array` instance for best performance\n    buf = Buffer._augment(new Uint8Array(length))\n  } else {\n    // Fallback: Return THIS instance of Buffer (created by `new`)\n    buf = this\n    buf.length = length\n    buf._isBuffer = true\n  }\n\n  var i\n  if (Buffer.TYPED_ARRAY_SUPPORT && typeof subject.byteLength === 'number') {\n    // Speed optimization -- use set if we're copying from a typed array\n    buf._set(subject)\n  } else if (isArrayish(subject)) {\n    // Treat array-ish objects as a byte array\n    if (Buffer.isBuffer(subject)) {\n      for (i = 0; i < length; i++)\n        buf[i] = subject.readUInt8(i)\n    } else {\n      for (i = 0; i < length; i++)\n        buf[i] = ((subject[i] % 256) + 256) % 256\n    }\n  } else if (type === 'string') {\n    buf.write(subject, 0, encoding)\n  } else if (type === 'number' && !Buffer.TYPED_ARRAY_SUPPORT && !noZero) {\n    for (i = 0; i < length; i++) {\n      buf[i] = 0\n    }\n  }\n\n  return buf\n}\n\nBuffer.isBuffer = function (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b))\n    throw new TypeError('Arguments must be Buffers')\n\n  var x = a.length\n  var y = b.length\n  for (var i = 0, len = Math.min(x, y); i < len && a[i] === b[i]; i++) {}\n  if (i !== len) {\n    x = a[i]\n    y = b[i]\n  }\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'binary':\n    case 'base64':\n    case 'raw':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function (list, totalLength) {\n  if (!isArray(list)) throw new TypeError('Usage: Buffer.concat(list[, length])')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  } else if (list.length === 1) {\n    return list[0]\n  }\n\n  var i\n  if (totalLength === undefined) {\n    totalLength = 0\n    for (i = 0; i < list.length; i++) {\n      totalLength += list[i].length\n    }\n  }\n\n  var buf = new Buffer(totalLength)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\nBuffer.byteLength = function (str, encoding) {\n  var ret\n  str = str + ''\n  switch (encoding || 'utf8') {\n    case 'ascii':\n    case 'binary':\n    case 'raw':\n      ret = str.length\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = str.length * 2\n      break\n    case 'hex':\n      ret = str.length >>> 1\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8ToBytes(str).length\n      break\n    case 'base64':\n      ret = base64ToBytes(str).length\n      break\n    default:\n      ret = str.length\n  }\n  return ret\n}\n\n// pre-set for values that may exist in the future\nBuffer.prototype.length = undefined\nBuffer.prototype.parent = undefined\n\n// toString(encoding, start=0, end=buffer.length)\nBuffer.prototype.toString = function (encoding, start, end) {\n  var loweredCase = false\n\n  start = start >>> 0\n  end = end === undefined || end === Infinity ? this.length : end >>> 0\n\n  if (!encoding) encoding = 'utf8'\n  if (start < 0) start = 0\n  if (end > this.length) end = this.length\n  if (end <= start) return ''\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'binary':\n        return binarySlice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase)\n          throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.equals = function (b) {\n  if(!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function () {\n  var str = ''\n  var max = exports.INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max)\n      str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  return Buffer.compare(this, b)\n}\n\n// `get` will be removed in Node 0.13+\nBuffer.prototype.get = function (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` will be removed in Node 0.13+\nBuffer.prototype.set = function (v, offset) {\n  console.log('.set() is deprecated. Access using array indexes instead.')\n  return this.writeUInt8(v, offset)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new Error('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; i++) {\n    var byte = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(byte)) throw new Error('Invalid hex string')\n    buf[offset + i] = byte\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  var charsWritten = blitBuffer(utf8ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  var charsWritten = blitBuffer(asciiToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction binaryWrite (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  var charsWritten = blitBuffer(base64ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction utf16leWrite (buf, string, offset, length) {\n  var charsWritten = blitBuffer(utf16leToBytes(string), buf, offset, length, 2)\n  return charsWritten\n}\n\nBuffer.prototype.write = function (string, offset, length, encoding) {\n  // Support both (string, offset, length, encoding)\n  // and the legacy (string, encoding, offset, length)\n  if (isFinite(offset)) {\n    if (!isFinite(length)) {\n      encoding = length\n      length = undefined\n    }\n  } else {  // legacy\n    var swap = encoding\n    encoding = offset\n    offset = length\n    length = swap\n  }\n\n  offset = Number(offset) || 0\n  var remaining = this.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n  encoding = String(encoding || 'utf8').toLowerCase()\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = hexWrite(this, string, offset, length)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8Write(this, string, offset, length)\n      break\n    case 'ascii':\n      ret = asciiWrite(this, string, offset, length)\n      break\n    case 'binary':\n      ret = binaryWrite(this, string, offset, length)\n      break\n    case 'base64':\n      ret = base64Write(this, string, offset, length)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = utf16leWrite(this, string, offset, length)\n      break\n    default:\n      throw new TypeError('Unknown encoding: ' + encoding)\n  }\n  return ret\n}\n\nBuffer.prototype.toJSON = function () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  var res = ''\n  var tmp = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    if (buf[i] <= 0x7F) {\n      res += decodeUtf8Char(tmp) + String.fromCharCode(buf[i])\n      tmp = ''\n    } else {\n      tmp += '%' + buf[i].toString(16)\n    }\n  }\n\n  return res + decodeUtf8Char(tmp)\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction binarySlice (buf, start, end) {\n  return asciiSlice(buf, start, end)\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; i++) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len;\n    if (start < 0)\n      start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0)\n      end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start)\n    end = start\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    return Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    var newBuf = new Buffer(sliceLen, undefined, true)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n    return newBuf\n  }\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0)\n    throw new RangeError('offset is not uint')\n  if (offset + ext > length)\n    throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUInt8 = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n      ((this[offset + 1] << 16) |\n      (this[offset + 2] << 8) |\n      this[offset + 3])\n}\n\nBuffer.prototype.readInt8 = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80))\n    return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16) |\n      (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n      (this[offset + 1] << 16) |\n      (this[offset + 2] << 8) |\n      (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function (offset, noAssert) {\n  if (!noAssert)\n    checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance')\n  if (value > max || value < min) throw new TypeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new TypeError('index out of range')\n}\n\nBuffer.prototype.writeUInt8 = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = value\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else objectWriteUInt16(this, value, offset, true)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else objectWriteUInt16(this, value, offset, false)\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = value\n  } else objectWriteUInt32(this, value, offset, true)\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else objectWriteUInt32(this, value, offset, false)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt8 = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = value\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else objectWriteUInt16(this, value, offset, true)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else objectWriteUInt16(this, value, offset, false)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else objectWriteUInt32(this, value, offset, true)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert)\n    checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else objectWriteUInt32(this, value, offset, false)\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (value > max || value < min) throw new TypeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new TypeError('index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert)\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert)\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function (target, target_start, start, end) {\n  var source = this\n\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (!target_start) target_start = 0\n\n  // Copy 0 bytes; we're done\n  if (end === start) return\n  if (target.length === 0 || source.length === 0) return\n\n  // Fatal error conditions\n  if (end < start) throw new TypeError('sourceEnd < sourceStart')\n  if (target_start < 0 || target_start >= target.length)\n    throw new TypeError('targetStart out of bounds')\n  if (start < 0 || start >= source.length) throw new TypeError('sourceStart out of bounds')\n  if (end < 0 || end > source.length) throw new TypeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length)\n    end = this.length\n  if (target.length - target_start < end - start)\n    end = target.length - target_start + start\n\n  var len = end - start\n\n  if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < len; i++) {\n      target[i + target_start] = this[i + start]\n    }\n  } else {\n    target._set(this.subarray(start, start + len), target_start)\n  }\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (end < start) throw new TypeError('end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  if (start < 0 || start >= this.length) throw new TypeError('start out of bounds')\n  if (end < 0 || end > this.length) throw new TypeError('end out of bounds')\n\n  var i\n  if (typeof value === 'number') {\n    for (i = start; i < end; i++) {\n      this[i] = value\n    }\n  } else {\n    var bytes = utf8ToBytes(value.toString())\n    var len = bytes.length\n    for (i = start; i < end; i++) {\n      this[i] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n/**\n * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.\n * Added in Node 0.12. Only available in browsers that support ArrayBuffer.\n */\nBuffer.prototype.toArrayBuffer = function () {\n  if (typeof Uint8Array !== 'undefined') {\n    if (Buffer.TYPED_ARRAY_SUPPORT) {\n      return (new Buffer(this)).buffer\n    } else {\n      var buf = new Uint8Array(this.length)\n      for (var i = 0, len = buf.length; i < len; i += 1) {\n        buf[i] = this[i]\n      }\n      return buf.buffer\n    }\n  } else {\n    throw new TypeError('Buffer.toArrayBuffer not supported in this browser')\n  }\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar BP = Buffer.prototype\n\n/**\n * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods\n */\nBuffer._augment = function (arr) {\n  arr.constructor = Buffer\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array get/set methods before overwriting\n  arr._get = arr.get\n  arr._set = arr.set\n\n  // deprecated, will be removed in node 0.13+\n  arr.get = BP.get\n  arr.set = BP.set\n\n  arr.write = BP.write\n  arr.toString = BP.toString\n  arr.toLocaleString = BP.toString\n  arr.toJSON = BP.toJSON\n  arr.equals = BP.equals\n  arr.compare = BP.compare\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUInt8 = BP.readUInt8\n  arr.readUInt16LE = BP.readUInt16LE\n  arr.readUInt16BE = BP.readUInt16BE\n  arr.readUInt32LE = BP.readUInt32LE\n  arr.readUInt32BE = BP.readUInt32BE\n  arr.readInt8 = BP.readInt8\n  arr.readInt16LE = BP.readInt16LE\n  arr.readInt16BE = BP.readInt16BE\n  arr.readInt32LE = BP.readInt32LE\n  arr.readInt32BE = BP.readInt32BE\n  arr.readFloatLE = BP.readFloatLE\n  arr.readFloatBE = BP.readFloatBE\n  arr.readDoubleLE = BP.readDoubleLE\n  arr.readDoubleBE = BP.readDoubleBE\n  arr.writeUInt8 = BP.writeUInt8\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeInt8 = BP.writeInt8\n  arr.writeInt16LE = BP.writeInt16LE\n  arr.writeInt16BE = BP.writeInt16BE\n  arr.writeInt32LE = BP.writeInt32LE\n  arr.writeInt32BE = BP.writeInt32BE\n  arr.writeFloatLE = BP.writeFloatLE\n  arr.writeFloatBE = BP.writeFloatBE\n  arr.writeDoubleLE = BP.writeDoubleLE\n  arr.writeDoubleBE = BP.writeDoubleBE\n  arr.fill = BP.fill\n  arr.inspect = BP.inspect\n  arr.toArrayBuffer = BP.toArrayBuffer\n\n  return arr\n}\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-z]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction isArrayish (subject) {\n  return isArray(subject) || Buffer.isBuffer(subject) ||\n      subject && typeof subject === 'object' &&\n      typeof subject.length === 'number'\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    var b = str.charCodeAt(i)\n    if (b <= 0x7F) {\n      byteArray.push(b)\n    } else {\n      var start = i\n      if (b >= 0xD800 && b <= 0xDFFF) i++\n      var h = encodeURIComponent(str.slice(start, i+1)).substr(1).split('%')\n      for (var j = 0; j < h.length; j++) {\n        byteArray.push(parseInt(h[j], 16))\n      }\n    }\n  }\n  return byteArray\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(str)\n}\n\nfunction blitBuffer (src, dst, offset, length, unitSize) {\n  if (unitSize) length -= length % unitSize;\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length))\n      break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction decodeUtf8Char (str) {\n  try {\n    return decodeURIComponent(str)\n  } catch (err) {\n    return String.fromCharCode(0xFFFD) // UTF 8 invalid char\n  }\n}\n","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH)\n\t\t\treturn 63 // '/'\n\t\tif (code < NUMBER)\n\t\t\treturn -1 //no match\n\t\tif (code < NUMBER + 10)\n\t\t\treturn code - NUMBER + 26 + 26\n\t\tif (code < UPPER + 26)\n\t\t\treturn code - UPPER\n\t\tif (code < LOWER + 26)\n\t\t\treturn code - LOWER + 26\n\t}\n\n\tfunction b64ToByteArray (b64) {\n\t\tvar i, j, l, tmp, placeHolders, arr\n\n\t\tif (b64.length % 4 > 0) {\n\t\t\tthrow new Error('Invalid string. Length must be a multiple of 4')\n\t\t}\n\n\t\t// the number of equal signs (place holders)\n\t\t// if there are two placeholders, than the two characters before it\n\t\t// represent one byte\n\t\t// if there is only one, then the three characters before it represent 2 bytes\n\t\t// this is just a cheap hack to not do indexOf twice\n\t\tvar len = b64.length\n\t\tplaceHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0\n\n\t\t// base64 is 4/3 + up to two characters of the original data\n\t\tarr = new Arr(b64.length * 3 / 4 - placeHolders)\n\n\t\t// if there are placeholders, only get up to the last complete 4 chars\n\t\tl = placeHolders > 0 ? b64.length - 4 : b64.length\n\n\t\tvar L = 0\n\n\t\tfunction push (v) {\n\t\t\tarr[L++] = v\n\t\t}\n\n\t\tfor (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))\n\t\t\tpush((tmp & 0xFF0000) >> 16)\n\t\t\tpush((tmp & 0xFF00) >> 8)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\tif (placeHolders === 2) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)\n\t\t\tpush(tmp & 0xFF)\n\t\t} else if (placeHolders === 1) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)\n\t\t\tpush((tmp >> 8) & 0xFF)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\treturn arr\n\t}\n\n\tfunction uint8ToBase64 (uint8) {\n\t\tvar i,\n\t\t\textraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes\n\t\t\toutput = \"\",\n\t\t\ttemp, length\n\n\t\tfunction encode (num) {\n\t\t\treturn lookup.charAt(num)\n\t\t}\n\n\t\tfunction tripletToBase64 (num) {\n\t\t\treturn encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)\n\t\t}\n\n\t\t// go through the array every three bytes, we'll deal with trailing stuff later\n\t\tfor (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {\n\t\t\ttemp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t\t\toutput += tripletToBase64(temp)\n\t\t}\n\n\t\t// pad the end with zeros, but make sure to not forget the extra bytes\n\t\tswitch (extraBytes) {\n\t\t\tcase 1:\n\t\t\t\ttemp = uint8[uint8.length - 1]\n\t\t\t\toutput += encode(temp >> 2)\n\t\t\t\toutput += encode((temp << 4) & 0x3F)\n\t\t\t\toutput += '=='\n\t\t\t\tbreak\n\t\t\tcase 2:\n\t\t\t\ttemp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])\n\t\t\t\toutput += encode(temp >> 10)\n\t\t\t\toutput += encode((temp >> 4) & 0x3F)\n\t\t\t\toutput += encode((temp << 2) & 0x3F)\n\t\t\t\toutput += '='\n\t\t\t\tbreak\n\t\t}\n\n\t\treturn output\n\t}\n\n\texports.toByteArray = b64ToByteArray\n\texports.fromByteArray = uint8ToBase64\n}(typeof exports === 'undefined' ? (this.base64js = {}) : exports))\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","\n/**\n * isArray\n */\n\nvar isArray = Array.isArray;\n\n/**\n * toString\n */\n\nvar str = Object.prototype.toString;\n\n/**\n * Whether or not the given `val`\n * is an array.\n *\n * example:\n *\n *        isArray([]);\n *        // > true\n *        isArray(arguments);\n *        // > false\n *        isArray('');\n *        // > false\n *\n * @param {mixed} val\n * @return {bool}\n */\n\nmodule.exports = isArray || function (val) {\n  return !! val && '[object Array]' == str.call(val);\n};\n","// (c) Dean McNamee <dean@gmail.com>, 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n  \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n  \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n  \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n  \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n  \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n  \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n  \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n  \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n  \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n  \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n  \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n  \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n  \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n  \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n  \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n  \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n  \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n  \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n  \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n  \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n  \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n  \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n  \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n  \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n  \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n  \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n  \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n  \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n  \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n  \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n  \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n  \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n  \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n  \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n  \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n  \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n  \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n  \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n  \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n  \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n  \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n  \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n  \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n  \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n  \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n  \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n  \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n  \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n  \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n  \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n  \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n  \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n  \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n  \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n  \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n  \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n  \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n  \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n  \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n  \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n  \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n  \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n  \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n  \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n  \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n  \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n  \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n  \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n  \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n  \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n  \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n  \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n  \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n  \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) {  // Clamp to integer 0 .. 255.\n  i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n  return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) {  // Clamp to float 0.0 .. 1.0.\n  return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) {  // int or percentage.\n  if (str[str.length - 1] === '%')\n    return clamp_css_byte(parseFloat(str) / 100 * 255);\n  return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) {  // float or percentage.\n  if (str[str.length - 1] === '%')\n    return clamp_css_float(parseFloat(str) / 100);\n  return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n  if (h < 0) h += 1;\n  else if (h > 1) h -= 1;\n\n  if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n  if (h * 2 < 1) return m2;\n  if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n  return m1;\n}\n\nfunction parseCSSColor(css_str) {\n  // Remove all whitespace, not compliant, but should just be more accepting.\n  var str = css_str.replace(/ /g, '').toLowerCase();\n\n  // Color keywords (and transparent) lookup.\n  if (str in kCSSColorTable) return kCSSColorTable[str].slice();  // dup.\n\n  // #abc and #abc123 syntax.\n  if (str[0] === '#') {\n    if (str.length === 4) {\n      var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n      if (!(iv >= 0 && iv <= 0xfff)) return null;  // Covers NaN.\n      return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n              (iv & 0xf0) | ((iv & 0xf0) >> 4),\n              (iv & 0xf) | ((iv & 0xf) << 4),\n              1];\n    } else if (str.length === 7) {\n      var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n      if (!(iv >= 0 && iv <= 0xffffff)) return null;  // Covers NaN.\n      return [(iv & 0xff0000) >> 16,\n              (iv & 0xff00) >> 8,\n              iv & 0xff,\n              1];\n    }\n\n    return null;\n  }\n\n  var op = str.indexOf('('), ep = str.indexOf(')');\n  if (op !== -1 && ep + 1 === str.length) {\n    var fname = str.substr(0, op);\n    var params = str.substr(op+1, ep-(op+1)).split(',');\n    var alpha = 1;  // To allow case fallthrough.\n    switch (fname) {\n      case 'rgba':\n        if (params.length !== 4) return null;\n        alpha = parse_css_float(params.pop());\n        // Fall through.\n      case 'rgb':\n        if (params.length !== 3) return null;\n        return [parse_css_int(params[0]),\n                parse_css_int(params[1]),\n                parse_css_int(params[2]),\n                alpha];\n      case 'hsla':\n        if (params.length !== 4) return null;\n        alpha = parse_css_float(params.pop());\n        // Fall through.\n      case 'hsl':\n        if (params.length !== 3) return null;\n        var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360;  // 0 .. 1\n        // NOTE(deanm): According to the CSS spec s/l should only be\n        // percentages, but we don't bother and let float or percentage.\n        var s = parse_css_float(params[1]);\n        var l = parse_css_float(params[2]);\n        var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n        var m1 = l * 2 - m2;\n        return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n                clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n                clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n                alpha];\n      default:\n        return null;\n    }\n  }\n\n  return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","'use strict';\n\nmodule.exports = earcut;\n\nfunction earcut(points) {\n\n    var outerNode = linkedList(points[0], true),\n        node, minX, minY, maxX, maxY, x, y, size,\n        len = 0,\n        threshold = 80;\n\n    for (var i = 0; len < threshold && i < points.length; i++) len += points[i].length;\n\n    // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n    if (len >= threshold) {\n        node = outerNode.next;\n        minX = maxX = node.p[0];\n        minY = maxY = node.p[1];\n        do {\n            x = node.p[0];\n            y = node.p[1];\n            if (x < minX) minX = x;\n            if (y < minY) minY = y;\n            if (x > maxX) maxX = x;\n            if (y > maxY) maxY = y;\n            node = node.next;\n        } while (node !== outerNode);\n\n        // minX, minY and size are later used to transform coords into integers for z-order calculation\n        size = Math.max(maxX - minX, maxY - minY);\n    }\n\n    if (points.length > 1) outerNode = eliminateHoles(points, outerNode);\n\n    var triangles = [];\n    if (outerNode) earcutLinked(outerNode, triangles, minX, minY, size);\n\n    return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(points, clockwise) {\n    var sum = 0,\n        len = points.length,\n        i, j, last;\n\n    // calculate original winding order of a polygon ring\n    for (i = 0, j = len - 1; i < len; j = i++) {\n        var p1 = points[i],\n            p2 = points[j];\n        sum += (p2[0] - p1[0]) * (p1[1] + p2[1]);\n    }\n\n    // link points into circular doubly-linked list in the specified winding order\n    if (clockwise === (sum > 0)) {\n        for (i = 0; i < len; i++) last = insertNode(points[i], last);\n    } else {\n        for (i = len - 1; i >= 0; i--) last = insertNode(points[i], last);\n    }\n\n    return last;\n}\n\nfunction filterPoints(start) {\n    // eliminate colinear or duplicate points\n    var node = start,\n        again;\n    do {\n        again = false;\n\n        if (equals(node.p, node.next.p) || orient(node.prev.p, node.p, node.next.p) === 0) {\n\n            node.prev.next = node.next;\n            node.next.prev = node.prev;\n\n            if (node.prevZ) node.prevZ.nextZ = node.nextZ;\n            if (node.nextZ) node.nextZ.prevZ = node.prevZ;\n\n            node = start = node.prev;\n\n            if (node === node.next) return null;\n            again = true;\n\n        } else {\n            node = node.next;\n        }\n    } while (again || node !== start);\n\n    return start;\n}\n\nfunction earcutLinked(ear, triangles, minX, minY, size, secondPass) {\n    ear = filterPoints(ear);\n    if (!ear) return;\n\n    if (!secondPass && minX !== undefined) indexCurve(ear, minX, minY, size);\n\n    var stop = ear,\n        prev, next;\n\n    // iterate through ears, slicing them one by one\n    while (ear.prev !== ear.next) {\n        prev = ear.prev;\n        next = ear.next;\n\n        if (isEar(ear, minX, minY, size)) {\n            triangles.push(prev.p, ear.p, next.p);\n\n            next.prev = prev;\n            prev.next = next;\n\n            if (ear.prevZ) ear.prevZ.nextZ = ear.nextZ;\n            if (ear.nextZ) ear.nextZ.prevZ = ear.prevZ;\n\n            ear = next.next;\n            stop = next.next;\n\n            continue;\n        }\n\n        ear = next;\n\n        if (ear === stop) {\n            // if we can't find any more ears, try filtering points and cutting again\n            if (!secondPass) earcutLinked(ear, triangles, minX, minY, size, true);\n            // if this didn't work, try splitting the remaining polygon into two\n            else splitEarcut(ear, triangles, minX, minY, size);\n            break;\n        }\n    }\n}\n\nfunction isEar(ear, minX, minY, size) {\n\n    var a = ear.prev.p,\n        b = ear.p,\n        c = ear.next.p,\n\n        ax = a[0], bx = b[0], cx = c[0],\n        ay = a[1], by = b[1], cy = c[1],\n\n        abd = ax * by - ay * bx,\n        acd = ax * cy - ay * cx,\n        cbd = cx * by - cy * bx,\n        A = abd - acd - cbd;\n\n    if (A <= 0) return false; // reflex, can't be an ear\n\n    // now make sure we don't have other points inside the potential ear\n\n    var cay = cy - ay,\n        acx = ax - cx,\n        aby = ay - by,\n        bax = bx - ax,\n        p, px, py, s, t, k, node;\n\n    // if we use z-order curve hashing, iterate through the curve\n    if (minX !== undefined) {\n\n        // triangle bbox; min & max are calculated like this for speed\n        var minTX = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n            minTY = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n            maxTX = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n            maxTY = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy),\n\n            // z-order range for the current triangle bbox;\n            minZ = zOrder(minTX, minTY, minX, minY, size),\n            maxZ = zOrder(maxTX, maxTY, minX, minY, size);\n\n        // first look for points inside the triangle in increasing z-order\n        node = ear.nextZ;\n\n        while (node && node.z <= maxZ) {\n            p = node.p;\n            node = node.nextZ;\n            if (p === a || p === c) continue;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n\n        // then look for points in decreasing z-order\n        node = ear.prevZ;\n\n        while (node && node.z >= minZ) {\n            p = node.p;\n            node = node.prevZ;\n            if (p === a || p === c) continue;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n\n    // if we don't use z-order curve hash, simply iterate through all other points\n    } else {\n        node = ear.next.next;\n\n        while (node !== ear.prev) {\n            p = node.p;\n            node = node.next;\n\n            px = p[0];\n            py = p[1];\n\n            s = cay * px + acx * py - acd;\n            if (s >= 0) {\n                t = aby * px + bax * py + abd;\n                if (t >= 0) {\n                    k = A - s - t;\n                    if ((k >= 0) && ((s && t) || (s && k) || (t && k))) return false;\n                }\n            }\n        }\n    }\n\n    return true;\n}\n\nfunction splitEarcut(start, triangles, minX, minY, size) {\n    // find a valid diagonal that divides the polygon into two\n    var a = start;\n    do {\n        var b = a.next.next;\n        while (b !== a.prev) {\n            if (isValidDiagonal(a, b)) {\n                // split the polygon in two by the diagonal\n                var c = splitPolygon(a, b);\n\n                // run earcut on each half\n                earcutLinked(a, triangles, minX, minY, size);\n                earcutLinked(c, triangles, minX, minY, size);\n                return;\n            }\n            b = b.next;\n        }\n        a = a.next;\n    } while (a !== start);\n}\n\nfunction eliminateHoles(points, outerNode) {\n    var len = points.length;\n\n    var queue = [];\n    for (var i = 1; i < len; i++) {\n        var list = filterPoints(linkedList(points[i], false));\n        if (list) queue.push(getLeftmost(list));\n    }\n    queue.sort(compareX);\n\n    // process holes from left to right\n    for (i = 0; i < queue.length; i++) {\n        eliminateHole(queue[i], outerNode);\n        outerNode = filterPoints(outerNode);\n    }\n\n    return outerNode;\n}\n\nfunction eliminateHole(holeNode, outerNode) {\n    outerNode = findHoleBridge(holeNode, outerNode);\n    if (outerNode) splitPolygon(holeNode, outerNode);\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(holeNode, outerNode) {\n    var node = outerNode,\n        p = holeNode.p,\n        px = p[0],\n        py = p[1],\n        qMax = -Infinity,\n        mNode, a, b;\n\n    // find a segment intersected by a ray from the hole's leftmost point to the left;\n    // segment's endpoint with lesser x will be potential connection point\n    do {\n        a = node.p;\n        b = node.next.p;\n\n        if (py <= a[1] && py >= b[1]) {\n            var qx = a[0] + (py - a[1]) * (b[0] - a[0]) / (b[1] - a[1]);\n            if (qx <= px && qx > qMax) {\n                qMax = qx;\n                mNode = a[0] < b[0] ? node : node.next;\n            }\n        }\n        node = node.next;\n    } while (node !== outerNode);\n\n    if (!mNode) return null;\n\n    // look for points strictly inside the triangle of hole point, segment intersection and endpoint;\n    // if there are no points found, we have a valid connection;\n    // otherwise choose the point of the minimum angle with the ray as connection point\n\n    var bx = mNode.p[0],\n        by = mNode.p[1],\n        pbd = px * by - py * bx,\n        pcd = px * py - py * qMax,\n        cpy = py - py,\n        pcx = px - qMax,\n        pby = py - by,\n        bpx = bx - px,\n        A = pbd - pcd - (qMax * by - py * bx),\n        sign = A <= 0 ? -1 : 1,\n        stop = mNode,\n        tanMin = Infinity,\n        mx, my, amx, s, t, tan;\n\n    node = mNode.next;\n\n    while (node !== stop) {\n\n        mx = node.p[0];\n        my = node.p[1];\n        amx = px - mx;\n\n        if (amx >= 0 && mx >= bx) {\n            s = (cpy * mx + pcx * my - pcd) * sign;\n            if (s >= 0) {\n                t = (pby * mx + bpx * my + pbd) * sign;\n\n                if (t >= 0 && A * sign - s - t >= 0) {\n                    tan = Math.abs(py - my) / amx; // tangential\n                    if (tan < tanMin && locallyInside(node, holeNode)) {\n                        mNode = node;\n                        tanMin = tan;\n                    }\n                }\n            }\n        }\n\n        node = node.next;\n    }\n\n    return mNode;\n}\n\nfunction indexCurve(start, minX, minY, size) {\n    var node = start;\n\n    do {\n        node.z = node.z || zOrder(node.p[0], node.p[1], minX, minY, size);\n        node.prevZ = node.prev;\n        node.nextZ = node.next;\n        node = node.next;\n    } while (node !== start);\n\n    node.prevZ.nextZ = null;\n    node.prevZ = null;\n\n    sortLinked(node);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n    var i, p, q, e, tail, numMerges, pSize, qSize,\n        inSize = 1;\n\n    while (true) {\n        p = list;\n        list = null;\n        tail = null;\n        numMerges = 0;\n\n        while (p) {\n            numMerges++;\n            q = p;\n            pSize = 0;\n            for (i = 0; i < inSize; i++) {\n                pSize++;\n                q = q.nextZ;\n                if (!q) break;\n            }\n\n            qSize = inSize;\n\n            while (pSize > 0 || (qSize > 0 && q)) {\n\n                if (pSize === 0) {\n                    e = q;\n                    q = q.nextZ;\n                    qSize--;\n                } else if (qSize === 0 || !q) {\n                    e = p;\n                    p = p.nextZ;\n                    pSize--;\n                } else if (p.z <= q.z) {\n                    e = p;\n                    p = p.nextZ;\n                    pSize--;\n                } else {\n                    e = q;\n                    q = q.nextZ;\n                    qSize--;\n                }\n\n                if (tail) tail.nextZ = e;\n                else list = e;\n\n                e.prevZ = tail;\n                tail = e;\n            }\n\n            p = q;\n        }\n\n        tail.nextZ = null;\n\n        if (numMerges <= 1) return list;\n\n        inSize *= 2;\n    }\n}\n\n// z-order of a point given coords and bbox\nfunction zOrder(x, y, minX, minY, size) {\n    // coords are transformed into (0..1000) integer range\n    x = 1000 * (x - minX) / size;\n    x = (x | (x << 8)) & 0x00FF00FF;\n    x = (x | (x << 4)) & 0x0F0F0F0F;\n    x = (x | (x << 2)) & 0x33333333;\n    x = (x | (x << 1)) & 0x55555555;\n\n    y = 1000 * (y - minY) / size;\n    y = (y | (y << 8)) & 0x00FF00FF;\n    y = (y | (y << 4)) & 0x0F0F0F0F;\n    y = (y | (y << 2)) & 0x33333333;\n    y = (y | (y << 1)) & 0x55555555;\n\n    return x | (y << 1);\n}\n\nfunction getLeftmost(start) {\n    var node = start,\n        leftmost = start;\n    do {\n        if (node.p[0] < leftmost.p[0]) leftmost = node;\n        node = node.next;\n    } while (node !== start);\n\n    return leftmost;\n}\n\nfunction isValidDiagonal(a, b) {\n    return !intersectsPolygon(a, a.p, b.p) &&\n           locallyInside(a, b) && locallyInside(b, a) &&\n           middleInside(a, a.p, b.p);\n}\n\n// winding order of triangle formed by 3 given points\nfunction orient(p, q, r) {\n    var o = (q[1] - p[1]) * (r[0] - q[0]) - (q[0] - p[0]) * (r[1] - q[1]);\n    return o > 0 ? 1 :\n           o < 0 ? -1 : 0;\n}\n\nfunction equals(p1, p2) {\n    return p1[0] === p2[0] && p1[1] === p2[1];\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n    return orient(p1, q1, p2) !== orient(p1, q1, q2) &&\n           orient(p2, q2, p1) !== orient(p2, q2, q1);\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(start, a, b) {\n    var node = start;\n    do {\n        var p1 = node.p,\n            p2 = node.next.p;\n\n        if (p1 !== a && p2 !== a && p1 !== b && p2 !== b && intersects(p1, p2, a, b)) return true;\n\n        node = node.next;\n    } while (node !== start);\n\n    return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n    return orient(a.prev.p, a.p, a.next.p) === -1 ?\n        orient(a.p, b.p, a.next.p) !== -1 && orient(a.p, a.prev.p, b.p) !== -1 :\n        orient(a.p, b.p, a.prev.p) === -1 || orient(a.p, a.next.p, b.p) === -1;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(start, a, b) {\n    var node = start,\n        inside = false,\n        px = (a[0] + b[0]) / 2,\n        py = (a[1] + b[1]) / 2;\n    do {\n        var p1 = node.p,\n            p2 = node.next.p;\n\n        if (((p1[1] > py) !== (p2[1] > py)) &&\n            (px < (p2[0] - p1[0]) * (py - p1[1]) / (p2[1] - p1[1]) + p1[0])) inside = !inside;\n\n        node = node.next;\n    } while (node !== start);\n\n    return inside;\n}\n\nfunction compareX(a, b) {\n    return a.p[0] - b.p[0];\n}\n\n// split the polygon vertices circular doubly-linked linked list into two\nfunction splitPolygon(a, b) {\n    var a2 = new Node(a.p),\n        b2 = new Node(b.p),\n        an = a.next,\n        bp = b.prev;\n\n    a.next = b;\n    b.prev = a;\n\n    a2.next = an;\n    an.prev = a2;\n\n    b2.next = a2;\n    a2.prev = b2;\n\n    bp.next = b2;\n    b2.prev = bp;\n\n    return a2;\n}\n\nfunction insertNode(point, last) {\n    var node = new Node(point);\n\n    if (!last) {\n        node.prev = node;\n        node.next = node;\n\n    } else {\n        node.next = last.next;\n        node.prev = last;\n        last.next.prev = node;\n        last.next = node;\n    }\n    return node;\n}\n\nfunction Node(p) {\n    this.p = p;\n    this.prev = null;\n    this.next = null;\n\n    this.z = null;\n    this.prevZ = null;\n    this.nextZ = null;\n}\n","'use strict';\n\nmodule.exports = clip;\n\n/* clip features between two axis-parallel lines:\n *     |        |\n *  ___|___     |     /\n * /   |   \\____|____/\n *     |        |\n */\n\nfunction clip(features, scale, k1, k2, axis, intersect, minAll, maxAll) {\n\n    k1 /= scale;\n    k2 /= scale;\n\n    if (minAll >= k1 && maxAll <= k2) return features; // trivial accept\n    else if (minAll > k2 || maxAll < k1) return null; // trivial reject\n\n    var clipped = [];\n\n    for (var i = 0; i < features.length; i++) {\n\n        var feature = features[i],\n            geometry = feature.geometry,\n            type = feature.type,\n            min, max;\n\n        min = feature.min[axis];\n        max = feature.max[axis];\n\n        if (min >= k1 && max <= k2) { // trivial accept\n            clipped.push(feature);\n            continue;\n        } else if (min > k2 || max < k1) continue; // trivial reject\n\n        var slices = type === 1 ?\n                clipPoints(geometry, k1, k2, axis) :\n                clipGeometry(geometry, k1, k2, axis, intersect, type === 3);\n\n        if (slices.length) {\n            // if a feature got clipped, it will likely get clipped on the next zoom level as well,\n            // so there's no need to recalculate bboxes\n            clipped.push({\n                geometry: slices,\n                type: type,\n                tags: features[i].tags || null,\n                min: feature.min,\n                max: feature.max\n            });\n        }\n    }\n\n    return clipped.length ? clipped : null;\n}\n\nfunction clipPoints(geometry, k1, k2, axis) {\n    var slice = [];\n\n    for (var i = 0; i < geometry.length; i++) {\n        var a = geometry[i],\n            ak = a[axis];\n\n        if (ak >= k1 && ak <= k2) slice.push(a);\n    }\n    return slice;\n}\n\nfunction clipGeometry(geometry, k1, k2, axis, intersect, closed) {\n\n    var slices = [];\n\n    for (var i = 0; i < geometry.length; i++) {\n\n        var ak = 0,\n            bk = 0,\n            b = null,\n            points = geometry[i],\n            area = points.area,\n            dist = points.dist,\n            len = points.length,\n            a, j, last;\n\n        var slice = [];\n\n        for (j = 0; j < len - 1; j++) {\n            a = b || points[j];\n            b = points[j + 1];\n            ak = bk || a[axis];\n            bk = b[axis];\n\n            if (ak < k1) {\n\n                if ((bk > k2)) { // ---|-----|-->\n                    slice.push(intersect(a, b, k1), intersect(a, b, k2));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk >= k1) slice.push(intersect(a, b, k1)); // ---|-->  |\n\n            } else if (ak > k2) {\n\n                if ((bk < k1)) { // <--|-----|---\n                    slice.push(intersect(a, b, k2), intersect(a, b, k1));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk <= k2) slice.push(intersect(a, b, k2)); // |  <--|---\n\n            } else {\n\n                slice.push(a);\n\n                if (bk < k1) { // <--|---  |\n                    slice.push(intersect(a, b, k1));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n\n                } else if (bk > k2) { // |  ---|-->\n                    slice.push(intersect(a, b, k2));\n                    if (!closed) slice = newSlice(slices, slice, area, dist);\n                }\n                // | --> |\n            }\n        }\n\n        // add the last point\n        a = points[len - 1];\n        ak = a[axis];\n        if (ak >= k1 && ak <= k2) slice.push(a);\n\n        // close the polygon if its endpoints are not the same after clipping\n\n        last = slice[slice.length - 1];\n        if (closed && last && (slice[0][0] !== last[0] || slice[0][1] !== last[1])) slice.push(slice[0]);\n\n        // add the final slice\n        newSlice(slices, slice, area, dist);\n    }\n\n    return slices;\n}\n\nfunction newSlice(slices, slice, area, dist) {\n    if (slice.length) {\n        // we don't recalculate the area/length of the unclipped geometry because the case where it goes\n        // below the visibility threshold as a result of clipping is rare, so we avoid doing unnecessary work\n        slice.area = area;\n        slice.dist = dist;\n\n        slices.push(slice);\n    }\n    return [];\n}\n","'use strict';\n\nmodule.exports = convert;\n\nvar simplify = require('./simplify');\n\n// converts GeoJSON feature into an intermediate projected JSON vector format with simplification data\n\nfunction convert(data, tolerance) {\n    var features = [];\n\n    if (data.type === 'FeatureCollection') {\n        for (var i = 0; i < data.features.length; i++) {\n            convertFeature(features, data.features[i], tolerance);\n        }\n    } else if (data.type === 'Feature') {\n        convertFeature(features, data, tolerance);\n\n    } else {\n        // single geometry or a geometry collection\n        convertFeature(features, {geometry: data}, tolerance);\n    }\n    return features;\n}\n\nfunction convertFeature(features, feature, tolerance) {\n    var geom = feature.geometry,\n        type = geom.type,\n        coords = geom.coordinates,\n        tags = feature.properties,\n        i, j, rings;\n\n    if (type === 'Point') {\n        features.push(create(tags, 1, [projectPoint(coords)]));\n\n    } else if (type === 'MultiPoint') {\n        features.push(create(tags, 1, project(coords)));\n\n    } else if (type === 'LineString') {\n        features.push(create(tags, 2, [project(coords, tolerance)]));\n\n    } else if (type === 'MultiLineString' || type === 'Polygon') {\n        rings = [];\n        for (i = 0; i < coords.length; i++) {\n            rings.push(project(coords[i], tolerance));\n        }\n        features.push(create(tags, type === 'Polygon' ? 3 : 2, rings));\n\n    } else if (type === 'MultiPolygon') {\n        rings = [];\n        for (i = 0; i < coords.length; i++) {\n            for (j = 0; j < coords[i].length; j++) {\n                rings.push(project(coords[i][j], tolerance));\n            }\n        }\n        features.push(create(tags, 3, rings));\n\n    } else if (type === 'GeometryCollection') {\n        for (i = 0; i < geom.geometries.length; i++) {\n            convertFeature(features, {\n                geometry: geom.geometries[i],\n                properties: tags\n            }, tolerance);\n        }\n\n    } else {\n        throw new Error('Input data is not a valid GeoJSON object.');\n    }\n}\n\nfunction create(tags, type, geometry) {\n    var feature = {\n        geometry: geometry,\n        type: type,\n        tags: tags || null,\n        min: [2, 1], // initial bbox values;\n        max: [-1, 0]  // note that coords are usually in [0..1] range\n    };\n    calcBBox(feature);\n    return feature;\n}\n\nfunction project(lonlats, tolerance) {\n    var projected = [];\n    for (var i = 0; i < lonlats.length; i++) {\n        projected.push(projectPoint(lonlats[i]));\n    }\n    if (tolerance) {\n        simplify(projected, tolerance);\n        calcSize(projected);\n    }\n    return projected;\n}\n\nfunction projectPoint(p) {\n    var sin = Math.sin(p[1] * Math.PI / 180),\n        x = (p[0] / 360 + 0.5),\n        y = (0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI);\n\n    y = y < -1 ? -1 :\n        y > 1 ? 1 : y;\n\n    return [x, y, 0];\n}\n\n// calculate area and length of the poly\nfunction calcSize(points) {\n    var area = 0,\n        dist = 0;\n\n    for (var i = 0, a, b; i < points.length - 1; i++) {\n        a = b || points[i];\n        b = points[i + 1];\n\n        area += a[0] * b[1] - b[0] * a[1];\n\n        // use Manhattan distance instead of Euclidian one to avoid expensive square root computation\n        dist += Math.abs(b[0] - a[0]) + Math.abs(b[1] - a[1]);\n    }\n    points.area = Math.abs(area / 2);\n    points.dist = dist;\n}\n\n// calculate the feature bounding box for faster clipping later\nfunction calcBBox(feature) {\n    var geometry = feature.geometry,\n        min = feature.min,\n        max = feature.max;\n\n    if (feature.type === 1) calcRingBBox(min, max, geometry);\n    else for (var i = 0; i < geometry.length; i++) calcRingBBox(min, max, geometry[i]);\n\n    return feature;\n}\n\nfunction calcRingBBox(min, max, points) {\n    for (var i = 0, p; i < points.length; i++) {\n        p = points[i];\n        min[0] = Math.min(p[0], min[0]);\n        max[0] = Math.max(p[0], max[0]);\n        min[1] = Math.min(p[1], min[1]);\n        max[1] = Math.max(p[1], max[1]);\n    }\n}\n","'use strict';\n\nmodule.exports = geojsonvt;\n\nvar convert = require('./convert'), // GeoJSON conversion and preprocessing\n    clip = require('./clip'),       // stripe clipping algorithm\n    wrap = require('./wrap'),       // date line processing\n    createTile = require('./tile'); // final simplified tile generation\n\n\nfunction geojsonvt(data, options) {\n    return new GeoJSONVT(data, options);\n}\n\nfunction GeoJSONVT(data, options) {\n    options = this.options = extend(Object.create(this.options), options);\n\n    var debug = options.debug;\n\n    if (debug) console.time('preprocess data');\n\n    var z2 = 1 << options.maxZoom, // 2^z\n        features = convert(data, options.tolerance / (z2 * options.extent));\n\n    this.tiles = {};\n\n    if (debug) {\n        console.timeEnd('preprocess data');\n        console.log('index: maxZoom: %d, maxPoints: %d', options.indexMaxZoom, options.indexMaxPoints);\n        console.time('generate tiles');\n        this.stats = {};\n        this.total = 0;\n    }\n\n    features = wrap(features, options.buffer / options.extent, intersectX);\n\n    // start slicing from the top tile down\n    this.splitTile(features, 0, 0, 0);\n\n    if (debug) {\n        console.log('features: %d, points: %d', this.tiles[0].numFeatures, this.tiles[0].numPoints);\n        console.timeEnd('generate tiles');\n        console.log('tiles generated:', this.total, JSON.stringify(this.stats));\n    }\n}\n\nGeoJSONVT.prototype.options = {\n    maxZoom: 14,            // max zoom to preserve detail on\n    indexMaxZoom: 5,        // max zoom in the tile index\n    indexMaxPoints: 100000, // max number of points per tile in the tile index\n    tolerance: 3,           // simplification tolerance (higher means simpler)\n    extent: 4096,           // tile extent\n    buffer: 64,             // tile buffer on each side\n    debug: 0                // logging level (0, 1 or 2)\n};\n\nGeoJSONVT.prototype.splitTile = function (features, z, x, y, cz, cx, cy) {\n\n    var stack = [features, z, x, y],\n        options = this.options,\n        debug = options.debug,\n        extent = options.extent,\n        buffer = options.buffer;\n\n    // avoid recursion by using a processing queue\n    while (stack.length) {\n        features = stack.shift();\n        z = stack.shift();\n        x = stack.shift();\n        y = stack.shift();\n\n        var z2 = 1 << z,\n            id = toID(z, x, y),\n            tile = this.tiles[id],\n            tileTolerance = z === options.maxZoom ? 0 : options.tolerance / (z2 * extent);\n\n        if (!tile) {\n            if (debug > 1) console.time('creation');\n\n            tile = this.tiles[id] = createTile(features, z2, x, y, tileTolerance, z === options.maxZoom);\n\n            if (debug) {\n                if (debug > 1) {\n                    console.log('tile z%d-%d-%d (features: %d, points: %d, simplified: %d)',\n                        z, x, y, tile.numFeatures, tile.numPoints, tile.numSimplified);\n                    console.timeEnd('creation');\n                }\n                var key = 'z' + z;\n                this.stats[key] = (this.stats[key] || 0) + 1;\n                this.total++;\n            }\n        }\n\n        // save reference to original geometry in tile so that we can drill down later if we stop now\n        tile.source = features;\n\n        // stop tiling if the tile is degenerate\n        if (isClippedSquare(tile.features, extent, buffer)) continue;\n\n        // if it's the first-pass tiling\n        if (!cz) {\n            // stop tiling if we reached max zoom, or if the tile is too simple\n            if (z === options.indexMaxZoom || tile.numPoints <= options.indexMaxPoints) continue;\n\n        // if a drilldown to a specific tile\n        } else {\n            // stop tiling if we reached base zoom or our target tile zoom\n            if (z === options.maxZoom || z === cz) continue;\n\n            // stop tiling if it's not an ancestor of the target tile\n            var m = 1 << (cz - z);\n            if (x !== Math.floor(cx / m) && y !== Math.floor(cy / m)) continue;\n        }\n\n        // if we slice further down, no need to keep source geometry\n        tile.source = null;\n\n        if (debug > 1) console.time('clipping');\n\n        // values we'll use for clipping\n        var k1 = 0.5 * buffer / extent,\n            k2 = 0.5 - k1,\n            k3 = 0.5 + k1,\n            k4 = 1 + k1,\n            tl, bl, tr, br, left, right;\n\n        tl = bl = tr = br = null;\n\n        left  = clip(features, z2, x - k1, x + k3, 0, intersectX, tile.min[0], tile.max[0]);\n        right = clip(features, z2, x + k2, x + k4, 0, intersectX, tile.min[0], tile.max[0]);\n\n        if (left) {\n            tl = clip(left, z2, y - k1, y + k3, 1, intersectY, tile.min[1], tile.max[1]);\n            bl = clip(left, z2, y + k2, y + k4, 1, intersectY, tile.min[1], tile.max[1]);\n        }\n\n        if (right) {\n            tr = clip(right, z2, y - k1, y + k3, 1, intersectY, tile.min[1], tile.max[1]);\n            br = clip(right, z2, y + k2, y + k4, 1, intersectY, tile.min[1], tile.max[1]);\n        }\n\n        if (debug > 1) console.timeEnd('clipping');\n\n        if (tl) stack.push(tl, z + 1, x * 2,     y * 2);\n        if (bl) stack.push(bl, z + 1, x * 2,     y * 2 + 1);\n        if (tr) stack.push(tr, z + 1, x * 2 + 1, y * 2);\n        if (br) stack.push(br, z + 1, x * 2 + 1, y * 2 + 1);\n    }\n};\n\nGeoJSONVT.prototype.getTile = function (z, x, y) {\n    var options = this.options,\n        extent = options.extent,\n        debug = options.debug;\n\n    var z2 = 1 << z;\n    x = ((x % z2) + z2) % z2; // wrap tile x coordinate\n\n    var id = toID(z, x, y);\n    if (this.tiles[id]) return transformTile(this.tiles[id], extent);\n\n    if (debug > 1) console.log('drilling down to z%d-%d-%d', z, x, y);\n\n    var z0 = z,\n        x0 = x,\n        y0 = y,\n        parent;\n\n    while (!parent && z0 > 0) {\n        z0--;\n        x0 = Math.floor(x0 / 2);\n        y0 = Math.floor(y0 / 2);\n        parent = this.tiles[toID(z0, x0, y0)];\n    }\n\n    if (debug > 1) console.log('found parent tile z%d-%d-%d', z0, x0, y0);\n\n    // if we found a parent tile containing the original geometry, we can drill down from it\n    if (parent.source) {\n        if (isClippedSquare(parent.features, options.extent, options.buffer)) return transformTile(parent, extent);\n\n        if (debug > 1) console.time('drilling down');\n        this.splitTile(parent.source, z0, x0, y0, z, x, y);\n        if (debug > 1) console.timeEnd('drilling down');\n    }\n\n    return transformTile(this.tiles[id], extent);\n};\n\nfunction transformTile(tile, extent) {\n    if (!tile || tile.transformed) return tile;\n\n    var z2 = tile.z2,\n        tx = tile.x,\n        ty = tile.y,\n        i, j, k;\n\n    for (i = 0; i < tile.features.length; i++) {\n        var feature = tile.features[i],\n            geom = feature.geometry,\n            type = feature.type;\n\n        if (type === 1) {\n            for (j = 0; j < geom.length; j++) geom[j] = transformPoint(geom[j], extent, z2, tx, ty);\n\n        } else {\n            for (j = 0; j < geom.length; j++) {\n                var ring = geom[j];\n                for (k = 0; k < ring.length; k++) ring[k] = transformPoint(ring[k], extent, z2, tx, ty);\n            }\n        }\n    }\n\n    tile.transformed = true;\n\n    return tile;\n}\n\nfunction transformPoint(p, extent, z2, tx, ty) {\n    var x = Math.round(extent * (p[0] * z2 - tx)),\n        y = Math.round(extent * (p[1] * z2 - ty));\n    return [x, y];\n}\n\n// checks whether a tile is a whole-area fill after clipping; if it is, there's no sense slicing it further\nfunction isClippedSquare(features, extent, buffer) {\n    if (features.length !== 1) return false;\n\n    var feature = features[0];\n    if (feature.type !== 3 || feature.geometry.length > 1) return false;\n\n    for (var i = 0; i < feature.geometry[0].length; i++) {\n        var p = feature.geometry[0][i];\n        if ((p[0] !== -buffer && p[0] !== extent + buffer) ||\n            (p[1] !== -buffer && p[1] !== extent + buffer)) return false;\n    }\n    return true;\n}\n\nfunction toID(z, x, y) {\n    return (((1 << z) * y + x) * 32) + z;\n}\n\nfunction intersectX(a, b, x) {\n    return [x, (x - a[0]) * (b[1] - a[1]) / (b[0] - a[0]) + a[1], 1];\n}\nfunction intersectY(a, b, y) {\n    return [(y - a[1]) * (b[0] - a[0]) / (b[1] - a[1]) + a[0], y, 1];\n}\n\nfunction extend(dest, src) {\n    for (var i in src) dest[i] = src[i];\n    return dest;\n}\n","'use strict';\n\nmodule.exports = simplify;\n\n// calculate simplification data using optimized Douglas-Peucker algorithm\n\nfunction simplify(points, tolerance) {\n\n    var sqTolerance = tolerance * tolerance,\n        len = points.length,\n        first = 0,\n        last = len - 1,\n        stack = [],\n        i, maxSqDist, sqDist, index;\n\n    // always retain the endpoints (1 is the max value)\n    points[first][2] = 1;\n    points[last][2] = 1;\n\n    // avoid recursion by using a stack\n    while (last) {\n\n        maxSqDist = 0;\n\n        for (i = first + 1; i < last; i++) {\n            sqDist = getSqSegDist(points[i], points[first], points[last]);\n\n            if (sqDist > maxSqDist) {\n                index = i;\n                maxSqDist = sqDist;\n            }\n        }\n\n        if (maxSqDist > sqTolerance) {\n            points[index][2] = maxSqDist; // save the point importance in squared pixels as a z coordinate\n            stack.push(first);\n            stack.push(index);\n            first = index;\n\n        } else {\n            last = stack.pop();\n            first = stack.pop();\n        }\n    }\n}\n\n// square distance from a point to a segment\nfunction getSqSegDist(p, a, b) {\n\n    var x = a[0], y = a[1],\n        bx = b[0], by = b[1],\n        px = p[0], py = p[1],\n        dx = bx - x,\n        dy = by - y;\n\n    if (dx !== 0 || dy !== 0) {\n\n        var t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);\n\n        if (t > 1) {\n            x = bx;\n            y = by;\n\n        } else if (t > 0) {\n            x += dx * t;\n            y += dy * t;\n        }\n    }\n\n    dx = px - x;\n    dy = py - y;\n\n    return dx * dx + dy * dy;\n}\n","'use strict';\n\nmodule.exports = createTile;\n\nfunction createTile(features, z2, tx, ty, tolerance, noSimplify) {\n    var tile = {\n        features: [],\n        numPoints: 0,\n        numSimplified: 0,\n        numFeatures: 0,\n        source: null,\n        x: tx,\n        y: ty,\n        z2: z2,\n        transformed: false,\n        min: [2, 1],\n        max: [-1, 0]\n    };\n    for (var i = 0; i < features.length; i++) {\n        tile.numFeatures++;\n        addFeature(tile, features[i], tolerance, noSimplify);\n\n        var min = features[i].min,\n            max = features[i].max;\n\n        if (min[0] < tile.min[0]) tile.min[0] = min[0];\n        if (min[1] < tile.min[1]) tile.min[1] = min[1];\n        if (max[0] > tile.max[0]) tile.max[0] = max[0];\n        if (max[1] > tile.max[1]) tile.max[1] = max[1];\n    }\n    return tile;\n}\n\nfunction addFeature(tile, feature, tolerance, noSimplify) {\n\n    var geom = feature.geometry,\n        type = feature.type,\n        simplified = [],\n        sqTolerance = tolerance * tolerance,\n        i, j, ring, p;\n\n    if (type === 1) {\n        for (i = 0; i < geom.length; i++) {\n            simplified.push(geom[i]);\n            tile.numPoints++;\n            tile.numSimplified++;\n        }\n\n    } else {\n\n        // simplify and transform projected coordinates for tile geometry\n        for (i = 0; i < geom.length; i++) {\n            ring = geom[i];\n\n            // filter out tiny polylines & polygons\n            if (!noSimplify && ((type === 2 && ring.dist < tolerance) ||\n                                (type === 3 && ring.area < sqTolerance))) {\n                tile.numPoints += ring.length;\n                continue;\n            }\n\n            var simplifiedRing = [];\n\n            for (j = 0; j < ring.length; j++) {\n                p = ring[j];\n                // keep points with importance > tolerance\n                if (noSimplify || p[2] > sqTolerance) {\n                    simplifiedRing.push(p);\n                    tile.numSimplified++;\n                }\n                tile.numPoints++;\n            }\n\n            simplified.push(simplifiedRing);\n        }\n    }\n\n    if (simplified.length) {\n        tile.features.push({\n            geometry: simplified,\n            type: type,\n            tags: feature.tags || null\n        });\n    }\n}\n","'use strict';\n\nvar clip = require('./clip');\n\nmodule.exports = wrap;\n\nfunction wrap(features, buffer, intersectX) {\n    var merged = features,\n        left  = clip(features, 1, -1 - buffer, buffer,     0, intersectX, -1, 2), // left world copy\n        right = clip(features, 1,  1 - buffer, 2 + buffer, 0, intersectX, -1, 2); // right world copy\n\n    if (left || right) {\n        merged = clip(features, 1, -buffer, 1 + buffer, 0, intersectX, -1, 2); // center world copy\n\n        if (left) merged = shiftFeatureCoords(left, 1).concat(merged); // merge left into center\n        if (right) merged = merged.concat(shiftFeatureCoords(right, -1)); // merge right into center\n    }\n\n    return merged;\n}\n\nfunction shiftFeatureCoords(features, offset) {\n    var newFeatures = [];\n\n    for (var i = 0; i < features.length; i++) {\n        var feature = features[i],\n            type = feature.type;\n\n        var newGeometry;\n\n        if (type === 1) {\n            newGeometry = shiftCoords(feature.geometry, offset);\n        } else {\n            newGeometry = [];\n            for (var j = 0; j < feature.geometry.length; j++) {\n                newGeometry.push(shiftCoords(feature.geometry[j], offset));\n            }\n        }\n\n        newFeatures.push({\n            geometry: newGeometry,\n            type: type,\n            tags: feature.tags,\n            min: [feature.min[0] + offset, feature.min[1]],\n            max: [feature.max[0] + offset, feature.max[1]]\n        });\n    }\n\n    return newFeatures;\n}\n\nfunction shiftCoords(points, offset) {\n    var newPoints = [];\n    newPoints.area = points.area;\n    newPoints.dist = points.dist;\n\n    for (var i = 0; i < points.length; i++) {\n        newPoints.push([points[i][0] + offset, points[i][1], points[i][2]]);\n    }\n    return newPoints;\n}\n","/**\n * @fileoverview gl-matrix - High performance matrix and vector operations\n * @author Brandon Jones\n * @author Colin MacKenzie IV\n * @version 2.2.1\n */\n\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\n(function(_global) {\n  \"use strict\";\n\n  var shim = {};\n  if (typeof(exports) === 'undefined') {\n    if(typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n      shim.exports = {};\n      define(function() {\n        return shim.exports;\n      });\n    } else {\n      // gl-matrix lives in a browser, define its namespaces in global\n      shim.exports = typeof(window) !== 'undefined' ? window : _global;\n    }\n  }\n  else {\n    // gl-matrix lives in commonjs, define its namespaces in exports\n    shim.exports = exports;\n  }\n\n  (function(exports) {\n    /* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\nif(!GLMAT_EPSILON) {\n    var GLMAT_EPSILON = 0.000001;\n}\n\nif(!GLMAT_ARRAY_TYPE) {\n    var GLMAT_ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;\n}\n\nif(!GLMAT_RANDOM) {\n    var GLMAT_RANDOM = Math.random;\n}\n\n/**\n * @class Common utilities\n * @name glMatrix\n */\nvar glMatrix = {};\n\n/**\n * Sets the type of array used when creating new vectors and matricies\n *\n * @param {Type} type Array type, such as Float32Array or Array\n */\nglMatrix.setMatrixArrayType = function(type) {\n    GLMAT_ARRAY_TYPE = type;\n}\n\nif(typeof(exports) !== 'undefined') {\n    exports.glMatrix = glMatrix;\n}\n\nvar degree = Math.PI / 180;\n\n/**\n* Convert Degree To Radian\n*\n* @param {Number} Angle in Degrees\n*/\nglMatrix.toRadian = function(a){\n     return a * degree;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2 Dimensional Vector\n * @name vec2\n */\n\nvar vec2 = {};\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nvec2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = 0;\n    out[1] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nvec2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nvec2.fromValues = function(x, y) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nvec2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nvec2.set = function(out, x, y) {\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nvec2.sub = vec2.subtract;\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nvec2.mul = vec2.multiply;\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nvec2.div = vec2.divide;\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    return out;\n};\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nvec2.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    return out;\n};\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nvec2.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nvec2.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nvec2.dist = vec2.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec2.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nvec2.sqrDist = vec2.squaredDistance;\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec2.length = function (a) {\n    var x = a[0],\n        y = a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nvec2.len = vec2.length;\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec2.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nvec2.sqrLen = vec2.squaredLength;\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nvec2.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    return out;\n};\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nvec2.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1];\n    var len = x*x + y*y;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec2.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1];\n};\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nvec2.cross = function(out, a, b) {\n    var z = a[0] * b[1] - a[1] * b[0];\n    out[0] = out[1] = 0;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nvec2.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nvec2.random = function (out, scale) {\n    scale = scale || 1.0;\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    out[0] = Math.cos(r) * scale;\n    out[1] = Math.sin(r) * scale;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y;\n    out[1] = m[1] * x + m[3] * y;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2d = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y + m[4];\n    out[1] = m[1] * x + m[3] * y + m[5];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat3 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[3] * y + m[6];\n    out[1] = m[1] * x + m[4] * y + m[7];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat4 = function(out, a, m) {\n    var x = a[0], \n        y = a[1];\n    out[0] = m[0] * x + m[4] * y + m[12];\n    out[1] = m[1] * x + m[5] * y + m[13];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec2.forEach = (function() {\n    var vec = vec2.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 2;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec2} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec2.str = function (a) {\n    return 'vec2(' + a[0] + ', ' + a[1] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec2 = vec2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3 Dimensional Vector\n * @name vec3\n */\n\nvar vec3 = {};\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nvec3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nvec3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nvec3.fromValues = function(x, y, z) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nvec3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nvec3.set = function(out, x, y, z) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nvec3.sub = vec3.subtract;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nvec3.mul = vec3.multiply;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nvec3.div = vec3.divide;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    return out;\n};\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nvec3.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    return out;\n};\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nvec3.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nvec3.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nvec3.dist = vec3.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec3.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nvec3.sqrDist = vec3.squaredDistance;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec3.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nvec3.len = vec3.length;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec3.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nvec3.sqrLen = vec3.squaredLength;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nvec3.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    return out;\n};\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nvec3.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    var len = x*x + y*y + z*z;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec3.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n};\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.cross = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2],\n        bx = b[0], by = b[1], bz = b[2];\n\n    out[0] = ay * bz - az * by;\n    out[1] = az * bx - ax * bz;\n    out[2] = ax * by - ay * bx;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nvec3.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    var z = (GLMAT_RANDOM() * 2.0) - 1.0;\n    var zScale = Math.sqrt(1.0-z*z) * scale;\n\n    out[0] = Math.cos(r) * zScale;\n    out[1] = Math.sin(r) * zScale;\n    out[2] = z * scale;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12];\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13];\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat3 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = x * m[0] + y * m[3] + z * m[6];\n    out[1] = x * m[1] + y * m[4] + z * m[7];\n    out[2] = x * m[2] + y * m[5] + z * m[8];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nvec3.transformQuat = function(out, a, q) {\n    // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/*\n* Rotate a 3D vector around the x-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateX = function(out, a, b, c){\n   var p = [], r=[];\n\t  //Translate point to the origin\n\t  p[0] = a[0] - b[0];\n\t  p[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n\n\t  //perform rotation\n\t  r[0] = p[0];\n\t  r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c);\n\t  r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c);\n\n\t  //translate to correct position\n\t  out[0] = r[0] + b[0];\n\t  out[1] = r[1] + b[1];\n\t  out[2] = r[2] + b[2];\n\n  \treturn out;\n};\n\n/*\n* Rotate a 3D vector around the y-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateY = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c);\n  \tr[1] = p[1];\n  \tr[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c);\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/*\n* Rotate a 3D vector around the z-axis\n* @param {vec3} out The receiving vec3\n* @param {vec3} a The vec3 point to rotate\n* @param {vec3} b The origin of the rotation\n* @param {Number} c The angle of rotation\n* @returns {vec3} out\n*/\nvec3.rotateZ = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c);\n  \tr[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c);\n  \tr[2] = p[2];\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec3.forEach = (function() {\n    var vec = vec3.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 3;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec3} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec3.str = function (a) {\n    return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec3 = vec3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4 Dimensional Vector\n * @name vec4\n */\n\nvar vec4 = {};\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nvec4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nvec4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nvec4.fromValues = function(x, y, z, w) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nvec4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nvec4.set = function(out, x, y, z, w) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    out[3] = a[3] + b[3];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    out[3] = a[3] - b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\nvec4.sub = vec4.subtract;\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    out[3] = a[3] * b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\nvec4.mul = vec4.multiply;\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    out[3] = a[3] / b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\nvec4.div = vec4.divide;\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    out[3] = Math.min(a[3], b[3]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    out[3] = Math.max(a[3], b[3]);\n    return out;\n};\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nvec4.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    out[3] = a[3] * b;\n    return out;\n};\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nvec4.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    out[3] = a[3] + (b[3] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nvec4.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\nvec4.dist = vec4.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec4.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\nvec4.sqrDist = vec4.squaredDistance;\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec4.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.length}\n * @function\n */\nvec4.len = vec4.length;\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec4.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\nvec4.sqrLen = vec4.squaredLength;\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nvec4.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = -a[3];\n    return out;\n};\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nvec4.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    var len = x*x + y*y + z*z + w*w;\n    if (len > 0) {\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n        out[3] = a[3] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec4.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n};\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nvec4.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2],\n        aw = a[3];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    out[3] = aw + t * (b[3] - aw);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nvec4.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    //TODO: This is a pretty awful way of doing this. Find something better.\n    out[0] = GLMAT_RANDOM();\n    out[1] = GLMAT_RANDOM();\n    out[2] = GLMAT_RANDOM();\n    out[3] = GLMAT_RANDOM();\n    vec4.normalize(out, out);\n    vec4.scale(out, out, scale);\n    return out;\n};\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nvec4.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2], w = a[3];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n    out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n    return out;\n};\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nvec4.transformQuat = function(out, a, q) {\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec4.forEach = (function() {\n    var vec = vec4.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 4;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec4} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec4.str = function (a) {\n    return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec4 = vec4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x2 Matrix\n * @name mat2\n */\n\nvar mat2 = {};\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {mat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nmat2.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a1 = a[1];\n        out[1] = a[2];\n        out[2] = a1;\n    } else {\n        out[0] = a[0];\n        out[1] = a[2];\n        out[2] = a[1];\n        out[3] = a[3];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n\n        // Calculate the determinant\n        det = a0 * a3 - a2 * a1;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n    \n    out[0] =  a3 * det;\n    out[1] = -a1 * det;\n    out[2] = -a2 * det;\n    out[3] =  a0 * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.adjoint = function(out, a) {\n    // Caching this value is nessecary if out == a\n    var a0 = a[0];\n    out[0] =  a[3];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] =  a0;\n\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {mat2} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2.determinant = function (a) {\n    return a[0] * a[3] - a[2] * a[1];\n};\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the first operand\n * @param {mat2} b the second operand\n * @returns {mat2} out\n */\nmat2.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n    var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    return out;\n};\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nmat2.mul = mat2.multiply;\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    return out;\n};\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nmat2.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {mat2} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2.str = function (a) {\n    return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {mat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2)))\n};\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {mat2} L the lower triangular matrix \n * @param {mat2} D the diagonal matrix \n * @param {mat2} U the upper triangular matrix \n * @param {mat2} a the input matrix to factorize\n */\n\nmat2.LDU = function (L, D, U, a) { \n    L[2] = a[2]/a[0]; \n    U[0] = a[0]; \n    U[1] = a[1]; \n    U[3] = a[3] - L[2] * U[1]; \n    return [L, D, U];       \n}; \n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2 = mat2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x3 Matrix\n * @name mat2d\n * \n * @description \n * A mat2d contains six elements defined as:\n * <pre>\n * [a, c, tx,\n *  b, d, ty]\n * </pre>\n * This is a short form for the 3x3 matrix:\n * <pre>\n * [a, c, tx,\n *  b, d, ty,\n *  0, 0, 1]\n * </pre>\n * The last row is ignored so the array is shorter and operations are faster.\n */\n\nvar mat2d = {};\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {mat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\nmat2d.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.invert = function(out, a) {\n    var aa = a[0], ab = a[1], ac = a[2], ad = a[3],\n        atx = a[4], aty = a[5];\n\n    var det = aa * ad - ab * ac;\n    if(!det){\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = ad * det;\n    out[1] = -ab * det;\n    out[2] = -ac * det;\n    out[3] = aa * det;\n    out[4] = (ac * aty - ad * atx) * det;\n    out[5] = (ab * atx - aa * aty) * det;\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {mat2d} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2d.determinant = function (a) {\n    return a[0] * a[3] - a[1] * a[2];\n};\n\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the first operand\n * @param {mat2d} b the second operand\n * @returns {mat2d} out\n */\nmat2d.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    out[4] = a0 * b4 + a2 * b5 + a4;\n    out[5] = a1 * b4 + a3 * b5 + a5;\n    return out;\n};\n\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\nmat2d.mul = mat2d.multiply;\n\n\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\nmat2d.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\nmat2d.translate = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0;\n    out[1] = a1;\n    out[2] = a2;\n    out[3] = a3;\n    out[4] = a0 * v0 + a2 * v1 + a4;\n    out[5] = a1 * v0 + a3 * v1 + a5;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2d\n *\n * @param {mat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2d.str = function (a) {\n    return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {mat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2d.frob = function (a) { \n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1))\n}; \n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2d = mat2d;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3x3 Matrix\n * @name mat3\n */\n\nvar mat3 = {};\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {mat4} a   the source 4x4 matrix\n * @returns {mat3} out\n */\nmat3.fromMat4 = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[4];\n    out[4] = a[5];\n    out[5] = a[6];\n    out[6] = a[8];\n    out[7] = a[9];\n    out[8] = a[10];\n    return out;\n};\n\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {mat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nmat3.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a12 = a[5];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a01;\n        out[5] = a[7];\n        out[6] = a02;\n        out[7] = a12;\n    } else {\n        out[0] = a[0];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a[1];\n        out[4] = a[4];\n        out[5] = a[7];\n        out[6] = a[2];\n        out[7] = a[5];\n        out[8] = a[8];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b01 = a22 * a11 - a12 * a21,\n        b11 = -a22 * a10 + a12 * a20,\n        b21 = a21 * a10 - a11 * a20,\n\n        // Calculate the determinant\n        det = a00 * b01 + a01 * b11 + a02 * b21;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = b01 * det;\n    out[1] = (-a22 * a01 + a02 * a21) * det;\n    out[2] = (a12 * a01 - a02 * a11) * det;\n    out[3] = b11 * det;\n    out[4] = (a22 * a00 - a02 * a20) * det;\n    out[5] = (-a12 * a00 + a02 * a10) * det;\n    out[6] = b21 * det;\n    out[7] = (-a21 * a00 + a01 * a20) * det;\n    out[8] = (a11 * a00 - a01 * a10) * det;\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    out[0] = (a11 * a22 - a12 * a21);\n    out[1] = (a02 * a21 - a01 * a22);\n    out[2] = (a01 * a12 - a02 * a11);\n    out[3] = (a12 * a20 - a10 * a22);\n    out[4] = (a00 * a22 - a02 * a20);\n    out[5] = (a02 * a10 - a00 * a12);\n    out[6] = (a10 * a21 - a11 * a20);\n    out[7] = (a01 * a20 - a00 * a21);\n    out[8] = (a00 * a11 - a01 * a10);\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat3\n *\n * @param {mat3} a the source matrix\n * @returns {Number} determinant of a\n */\nmat3.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n};\n\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the first operand\n * @param {mat3} b the second operand\n * @returns {mat3} out\n */\nmat3.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b00 = b[0], b01 = b[1], b02 = b[2],\n        b10 = b[3], b11 = b[4], b12 = b[5],\n        b20 = b[6], b21 = b[7], b22 = b[8];\n\n    out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n    out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n    out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n    out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n    out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n    out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n    out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n    out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n    out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n    return out;\n};\n\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nmat3.mul = mat3.multiply;\n\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to translate\n * @param {vec2} v vector to translate by\n * @returns {mat3} out\n */\nmat3.translate = function(out, a, v) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n        x = v[0], y = v[1];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n\n    out[3] = a10;\n    out[4] = a11;\n    out[5] = a12;\n\n    out[6] = x * a00 + y * a10 + a20;\n    out[7] = x * a01 + y * a11 + a21;\n    out[8] = x * a02 + y * a12 + a22;\n    return out;\n};\n\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.rotate = function (out, a, rad) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n\n    out[0] = c * a00 + s * a10;\n    out[1] = c * a01 + s * a11;\n    out[2] = c * a02 + s * a12;\n\n    out[3] = c * a10 - s * a00;\n    out[4] = c * a11 - s * a01;\n    out[5] = c * a12 - s * a02;\n\n    out[6] = a20;\n    out[7] = a21;\n    out[8] = a22;\n    return out;\n};\n\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nmat3.scale = function(out, a, v) {\n    var x = v[0], y = v[1];\n\n    out[0] = x * a[0];\n    out[1] = x * a[1];\n    out[2] = x * a[2];\n\n    out[3] = y * a[3];\n    out[4] = y * a[4];\n    out[5] = y * a[5];\n\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nmat3.fromMat2d = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = 0;\n\n    out[3] = a[2];\n    out[4] = a[3];\n    out[5] = 0;\n\n    out[6] = a[4];\n    out[7] = a[5];\n    out[8] = 1;\n    return out;\n};\n\n/**\n* Calculates a 3x3 matrix from the given quaternion\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {quat} q Quaternion to create matrix from\n*\n* @returns {mat3} out\n*/\nmat3.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[3] = yx - wz;\n    out[6] = zx + wy;\n\n    out[1] = yx + wz;\n    out[4] = 1 - xx - zz;\n    out[7] = zy - wx;\n\n    out[2] = zx - wy;\n    out[5] = zy + wx;\n    out[8] = 1 - xx - yy;\n\n    return out;\n};\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {mat4} a Mat4 to derive the normal matrix from\n*\n* @returns {mat3} out\n*/\nmat3.normalFromMat4 = function (out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n\n    out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n\n    out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat3\n *\n * @param {mat3} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat3.str = function (a) {\n    return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ', ' + \n                    a[6] + ', ' + a[7] + ', ' + a[8] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {mat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat3.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2)))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat3 = mat3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4x4 Matrix\n * @name mat4\n */\n\nvar mat4 = {};\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nmat4.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a03 = a[3],\n            a12 = a[6], a13 = a[7],\n            a23 = a[11];\n\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a01;\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a02;\n        out[9] = a12;\n        out[11] = a[14];\n        out[12] = a03;\n        out[13] = a13;\n        out[14] = a23;\n    } else {\n        out[0] = a[0];\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a[1];\n        out[5] = a[5];\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a[2];\n        out[9] = a[6];\n        out[10] = a[10];\n        out[11] = a[14];\n        out[12] = a[3];\n        out[13] = a[7];\n        out[14] = a[11];\n        out[15] = a[15];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n    out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n    out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n    out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n    out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n    out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n    out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n    out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n    out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n    out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    out[0]  =  (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n    out[1]  = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n    out[2]  =  (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n    out[3]  = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n    out[4]  = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n    out[5]  =  (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n    out[6]  = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n    out[7]  =  (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n    out[8]  =  (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n    out[9]  = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n    out[10] =  (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n    out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n    out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n    out[13] =  (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n    out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n    out[15] =  (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nmat4.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32;\n\n    // Calculate the determinant\n    return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2], b3 = b[3];  \n    out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n    out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n    out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n    return out;\n};\n\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\nmat4.mul = mat4.multiply;\n\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nmat4.translate = function (out, a, v) {\n    var x = v[0], y = v[1], z = v[2],\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23;\n\n    if (a === out) {\n        out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n        out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n        out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n        out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n    } else {\n        a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n        a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n        a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n        out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n        out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n        out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n        out[12] = a00 * x + a10 * y + a20 * z + a[12];\n        out[13] = a01 * x + a11 * y + a21 * z + a[13];\n        out[14] = a02 * x + a12 * y + a22 * z + a[14];\n        out[15] = a03 * x + a13 * y + a23 * z + a[15];\n    }\n\n    return out;\n};\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nmat4.scale = function(out, a, v) {\n    var x = v[0], y = v[1], z = v[2];\n\n    out[0] = a[0] * x;\n    out[1] = a[1] * x;\n    out[2] = a[2] * x;\n    out[3] = a[3] * x;\n    out[4] = a[4] * y;\n    out[5] = a[5] * y;\n    out[6] = a[6] * y;\n    out[7] = a[7] * y;\n    out[8] = a[8] * z;\n    out[9] = a[9] * z;\n    out[10] = a[10] * z;\n    out[11] = a[11] * z;\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.rotate = function (out, a, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t,\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23,\n        b00, b01, b02,\n        b10, b11, b12,\n        b20, b21, b22;\n\n    if (Math.abs(len) < GLMAT_EPSILON) { return null; }\n    \n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n\n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n\n    a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n    a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n    a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n    // Construct the elements of the rotation matrix\n    b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n    b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n    b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n    // Perform rotation-specific matrix multiplication\n    out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n    out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n    out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n    out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n    out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n    out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n    out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n    out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n    out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n    out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n    out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n    out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateX = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[0]  = a[0];\n        out[1]  = a[1];\n        out[2]  = a[2];\n        out[3]  = a[3];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[4] = a10 * c + a20 * s;\n    out[5] = a11 * c + a21 * s;\n    out[6] = a12 * c + a22 * s;\n    out[7] = a13 * c + a23 * s;\n    out[8] = a20 * c - a10 * s;\n    out[9] = a21 * c - a11 * s;\n    out[10] = a22 * c - a12 * s;\n    out[11] = a23 * c - a13 * s;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateY = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[4]  = a[4];\n        out[5]  = a[5];\n        out[6]  = a[6];\n        out[7]  = a[7];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c - a20 * s;\n    out[1] = a01 * c - a21 * s;\n    out[2] = a02 * c - a22 * s;\n    out[3] = a03 * c - a23 * s;\n    out[8] = a00 * s + a20 * c;\n    out[9] = a01 * s + a21 * c;\n    out[10] = a02 * s + a22 * c;\n    out[11] = a03 * s + a23 * c;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateZ = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[8]  = a[8];\n        out[9]  = a[9];\n        out[10] = a[10];\n        out[11] = a[11];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c + a10 * s;\n    out[1] = a01 * c + a11 * s;\n    out[2] = a02 * c + a12 * s;\n    out[3] = a03 * c + a13 * s;\n    out[4] = a10 * c - a00 * s;\n    out[5] = a11 * c - a01 * s;\n    out[6] = a12 * c - a02 * s;\n    out[7] = a13 * c - a03 * s;\n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslation = function (out, q, v) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - (yy + zz);\n    out[1] = xy + wz;\n    out[2] = xz - wy;\n    out[3] = 0;\n    out[4] = xy - wz;\n    out[5] = 1 - (xx + zz);\n    out[6] = yz + wx;\n    out[7] = 0;\n    out[8] = xz + wy;\n    out[9] = yz - wx;\n    out[10] = 1 - (xx + yy);\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n    \n    return out;\n};\n\nmat4.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[1] = yx + wz;\n    out[2] = zx - wy;\n    out[3] = 0;\n\n    out[4] = yx - wz;\n    out[5] = 1 - xx - zz;\n    out[6] = zy + wx;\n    out[7] = 0;\n\n    out[8] = zx + wy;\n    out[9] = zy - wx;\n    out[10] = 1 - xx - yy;\n    out[11] = 0;\n\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.frustum = function (out, left, right, bottom, top, near, far) {\n    var rl = 1 / (right - left),\n        tb = 1 / (top - bottom),\n        nf = 1 / (near - far);\n    out[0] = (near * 2) * rl;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = (near * 2) * tb;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = (right + left) * rl;\n    out[9] = (top + bottom) * tb;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (far * near * 2) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspective = function (out, fovy, aspect, near, far) {\n    var f = 1.0 / Math.tan(fovy / 2),\n        nf = 1 / (near - far);\n    out[0] = f / aspect;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = f;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (2 * far * near) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.ortho = function (out, left, right, bottom, top, near, far) {\n    var lr = 1 / (left - right),\n        bt = 1 / (bottom - top),\n        nf = 1 / (near - far);\n    out[0] = -2 * lr;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = -2 * bt;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 2 * nf;\n    out[11] = 0;\n    out[12] = (left + right) * lr;\n    out[13] = (top + bottom) * bt;\n    out[14] = (far + near) * nf;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nmat4.lookAt = function (out, eye, center, up) {\n    var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n        eyex = eye[0],\n        eyey = eye[1],\n        eyez = eye[2],\n        upx = up[0],\n        upy = up[1],\n        upz = up[2],\n        centerx = center[0],\n        centery = center[1],\n        centerz = center[2];\n\n    if (Math.abs(eyex - centerx) < GLMAT_EPSILON &&\n        Math.abs(eyey - centery) < GLMAT_EPSILON &&\n        Math.abs(eyez - centerz) < GLMAT_EPSILON) {\n        return mat4.identity(out);\n    }\n\n    z0 = eyex - centerx;\n    z1 = eyey - centery;\n    z2 = eyez - centerz;\n\n    len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n    z0 *= len;\n    z1 *= len;\n    z2 *= len;\n\n    x0 = upy * z2 - upz * z1;\n    x1 = upz * z0 - upx * z2;\n    x2 = upx * z1 - upy * z0;\n    len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n    if (!len) {\n        x0 = 0;\n        x1 = 0;\n        x2 = 0;\n    } else {\n        len = 1 / len;\n        x0 *= len;\n        x1 *= len;\n        x2 *= len;\n    }\n\n    y0 = z1 * x2 - z2 * x1;\n    y1 = z2 * x0 - z0 * x2;\n    y2 = z0 * x1 - z1 * x0;\n\n    len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n    if (!len) {\n        y0 = 0;\n        y1 = 0;\n        y2 = 0;\n    } else {\n        len = 1 / len;\n        y0 *= len;\n        y1 *= len;\n        y2 *= len;\n    }\n\n    out[0] = x0;\n    out[1] = y0;\n    out[2] = z0;\n    out[3] = 0;\n    out[4] = x1;\n    out[5] = y1;\n    out[6] = z1;\n    out[7] = 0;\n    out[8] = x2;\n    out[9] = y2;\n    out[10] = z2;\n    out[11] = 0;\n    out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n    out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n    out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat4.str = function (a) {\n    return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n                    a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n                    a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' + \n                    a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {mat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat4.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) ))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat4 = mat4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation \n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE \nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class Quaternion\n * @name quat\n */\n\nvar quat = {};\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nquat.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {vec3} a the initial vector\n * @param {vec3} b the destination vector\n * @returns {quat} out\n */\nquat.rotationTo = (function() {\n    var tmpvec3 = vec3.create();\n    var xUnitVec3 = vec3.fromValues(1,0,0);\n    var yUnitVec3 = vec3.fromValues(0,1,0);\n\n    return function(out, a, b) {\n        var dot = vec3.dot(a, b);\n        if (dot < -0.999999) {\n            vec3.cross(tmpvec3, xUnitVec3, a);\n            if (vec3.length(tmpvec3) < 0.000001)\n                vec3.cross(tmpvec3, yUnitVec3, a);\n            vec3.normalize(tmpvec3, tmpvec3);\n            quat.setAxisAngle(out, tmpvec3, Math.PI);\n            return out;\n        } else if (dot > 0.999999) {\n            out[0] = 0;\n            out[1] = 0;\n            out[2] = 0;\n            out[3] = 1;\n            return out;\n        } else {\n            vec3.cross(tmpvec3, a, b);\n            out[0] = tmpvec3[0];\n            out[1] = tmpvec3[1];\n            out[2] = tmpvec3[2];\n            out[3] = 1 + dot;\n            return quat.normalize(out, out);\n        }\n    };\n})();\n\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {vec3} view  the vector representing the viewing direction\n * @param {vec3} right the vector representing the local \"right\" direction\n * @param {vec3} up    the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nquat.setAxes = (function() {\n    var matr = mat3.create();\n\n    return function(out, view, right, up) {\n        matr[0] = right[0];\n        matr[3] = right[1];\n        matr[6] = right[2];\n\n        matr[1] = up[0];\n        matr[4] = up[1];\n        matr[7] = up[2];\n\n        matr[2] = -view[0];\n        matr[5] = -view[1];\n        matr[8] = -view[2];\n\n        return quat.normalize(out, quat.fromMat3(out, matr));\n    };\n})();\n\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {quat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nquat.clone = vec4.clone;\n\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nquat.fromValues = vec4.fromValues;\n\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nquat.copy = vec4.copy;\n\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nquat.set = vec4.set;\n\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nquat.identity = function(out) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {vec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nquat.setAxisAngle = function(out, axis, rad) {\n    rad = rad * 0.5;\n    var s = Math.sin(rad);\n    out[0] = s * axis[0];\n    out[1] = s * axis[1];\n    out[2] = s * axis[2];\n    out[3] = Math.cos(rad);\n    return out;\n};\n\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n * @function\n */\nquat.add = vec4.add;\n\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n */\nquat.multiply = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    out[0] = ax * bw + aw * bx + ay * bz - az * by;\n    out[1] = ay * bw + aw * by + az * bx - ax * bz;\n    out[2] = az * bw + aw * bz + ax * by - ay * bx;\n    out[3] = aw * bw - ax * bx - ay * by - az * bz;\n    return out;\n};\n\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nquat.mul = quat.multiply;\n\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {quat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nquat.scale = vec4.scale;\n\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateX = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + aw * bx;\n    out[1] = ay * bw + az * bx;\n    out[2] = az * bw - ay * bx;\n    out[3] = aw * bw - ax * bx;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateY = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        by = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw - az * by;\n    out[1] = ay * bw + aw * by;\n    out[2] = az * bw + ax * by;\n    out[3] = aw * bw - ay * by;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateZ = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bz = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + ay * bz;\n    out[1] = ay * bw - ax * bz;\n    out[2] = az * bw + aw * bz;\n    out[3] = aw * bw - az * bz;\n    return out;\n};\n\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate W component of\n * @returns {quat} out\n */\nquat.calculateW = function (out, a) {\n    var x = a[0], y = a[1], z = a[2];\n\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = -Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n    return out;\n};\n\n/**\n * Calculates the dot product of two quat's\n *\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nquat.dot = vec4.dot;\n\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n * @function\n */\nquat.lerp = vec4.lerp;\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nquat.slerp = function (out, a, b, t) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    var        omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if ( cosom < 0.0 ) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ( (1.0 - cosom) > 0.000001 ) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    } else {        \n        // \"from\" and \"to\" quaternions are very close \n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n    \n    return out;\n};\n\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate inverse of\n * @returns {quat} out\n */\nquat.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        dot = a0*a0 + a1*a1 + a2*a2 + a3*a3,\n        invDot = dot ? 1.0/dot : 0;\n    \n    // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n    out[0] = -a0*invDot;\n    out[1] = -a1*invDot;\n    out[2] = -a2*invDot;\n    out[3] = a3*invDot;\n    return out;\n};\n\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nquat.conjugate = function (out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Calculates the length of a quat\n *\n * @param {quat} a vector to calculate length of\n * @returns {Number} length of a\n * @function\n */\nquat.length = vec4.length;\n\n/**\n * Alias for {@link quat.length}\n * @function\n */\nquat.len = quat.length;\n\n/**\n * Calculates the squared length of a quat\n *\n * @param {quat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nquat.squaredLength = vec4.squaredLength;\n\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nquat.sqrLen = quat.squaredLength;\n\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nquat.normalize = vec4.normalize;\n\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {mat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nquat.fromMat3 = function(out, m) {\n    // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n    // article \"Quaternion Calculus and Fast Animation\".\n    var fTrace = m[0] + m[4] + m[8];\n    var fRoot;\n\n    if ( fTrace > 0.0 ) {\n        // |w| > 1/2, may as well choose w > 1/2\n        fRoot = Math.sqrt(fTrace + 1.0);  // 2w\n        out[3] = 0.5 * fRoot;\n        fRoot = 0.5/fRoot;  // 1/(4w)\n        out[0] = (m[7]-m[5])*fRoot;\n        out[1] = (m[2]-m[6])*fRoot;\n        out[2] = (m[3]-m[1])*fRoot;\n    } else {\n        // |w| <= 1/2\n        var i = 0;\n        if ( m[4] > m[0] )\n          i = 1;\n        if ( m[8] > m[i*3+i] )\n          i = 2;\n        var j = (i+1)%3;\n        var k = (i+2)%3;\n        \n        fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0);\n        out[i] = 0.5 * fRoot;\n        fRoot = 0.5 / fRoot;\n        out[3] = (m[k*3+j] - m[j*3+k]) * fRoot;\n        out[j] = (m[j*3+i] + m[i*3+j]) * fRoot;\n        out[k] = (m[k*3+i] + m[i*3+k]) * fRoot;\n    }\n    \n    return out;\n};\n\n/**\n * Returns a string representation of a quatenion\n *\n * @param {quat} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nquat.str = function (a) {\n    return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.quat = quat;\n}\n;\n\n\n\n\n\n\n\n\n\n\n\n\n\n  })(shim.exports);\n})(this);\n","module.exports = parseErrors\n\nfunction parseErrors(log) {\n  log = String(log)\n\n  var logs = []\n  var result\n\n  while (result = log.match(/ERROR\\:([^\\n]+)/)) {\n    log = log.slice(result.index + 1)\n\n    var line = result[1].trim()\n    var seps = line.split(':')\n    var emsg = seps.slice(2).join(':').trim()\n    var file = parseInt(seps[0], 10)\n    var line = parseInt(seps[1], 10)\n\n    logs.push({\n        message: emsg\n      , file: file\n      , line: line\n    })\n  }\n\n  return logs\n}\n","'use strict';\n\n\nvar yaml = require('./lib/js-yaml.js');\n\n\nmodule.exports = yaml;\n","'use strict';\n\n\nvar loader = require('./js-yaml/loader');\nvar dumper = require('./js-yaml/dumper');\n\n\nfunction deprecated(name) {\n  return function () {\n    throw new Error('Function ' + name + ' is deprecated and cannot be used.');\n  };\n}\n\n\nmodule.exports.Type                = require('./js-yaml/type');\nmodule.exports.Schema              = require('./js-yaml/schema');\nmodule.exports.FAILSAFE_SCHEMA     = require('./js-yaml/schema/failsafe');\nmodule.exports.JSON_SCHEMA         = require('./js-yaml/schema/json');\nmodule.exports.CORE_SCHEMA         = require('./js-yaml/schema/core');\nmodule.exports.DEFAULT_SAFE_SCHEMA = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_FULL_SCHEMA = require('./js-yaml/schema/default_full');\nmodule.exports.load                = loader.load;\nmodule.exports.loadAll             = loader.loadAll;\nmodule.exports.safeLoad            = loader.safeLoad;\nmodule.exports.safeLoadAll         = loader.safeLoadAll;\nmodule.exports.dump                = dumper.dump;\nmodule.exports.safeDump            = dumper.safeDump;\nmodule.exports.YAMLException       = require('./js-yaml/exception');\n\n// Deprecared schema names from JS-YAML 2.0.x\nmodule.exports.MINIMAL_SCHEMA = require('./js-yaml/schema/failsafe');\nmodule.exports.SAFE_SCHEMA    = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_SCHEMA = require('./js-yaml/schema/default_full');\n\n// Deprecated functions from JS-YAML 1.x.x\nmodule.exports.scan           = deprecated('scan');\nmodule.exports.parse          = deprecated('parse');\nmodule.exports.compose        = deprecated('compose');\nmodule.exports.addConstructor = deprecated('addConstructor');\n","'use strict';\n\n\nfunction isNothing(subject) {\n  return (typeof subject === 'undefined') || (null === subject);\n}\n\n\nfunction isObject(subject) {\n  return (typeof subject === 'object') && (null !== subject);\n}\n\n\nfunction toArray(sequence) {\n  if (Array.isArray(sequence)) {\n    return sequence;\n  } else if (isNothing(sequence)) {\n    return [];\n  }\n  return [ sequence ];\n}\n\n\nfunction extend(target, source) {\n  var index, length, key, sourceKeys;\n\n  if (source) {\n    sourceKeys = Object.keys(source);\n\n    for (index = 0, length = sourceKeys.length; index < length; index += 1) {\n      key = sourceKeys[index];\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\n\nfunction repeat(string, count) {\n  var result = '', cycle;\n\n  for (cycle = 0; cycle < count; cycle += 1) {\n    result += string;\n  }\n\n  return result;\n}\n\n\nfunction isNegativeZero(number) {\n  return (0 === number) && (Number.NEGATIVE_INFINITY === 1 / number);\n}\n\n\nmodule.exports.isNothing      = isNothing;\nmodule.exports.isObject       = isObject;\nmodule.exports.toArray        = toArray;\nmodule.exports.repeat         = repeat;\nmodule.exports.isNegativeZero = isNegativeZero;\nmodule.exports.extend         = extend;\n","'use strict';\n\n/*eslint-disable no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\n\nvar _toString       = Object.prototype.toString;\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar CHAR_TAB                  = 0x09; /* Tab */\nvar CHAR_LINE_FEED            = 0x0A; /* LF */\nvar CHAR_CARRIAGE_RETURN      = 0x0D; /* CR */\nvar CHAR_SPACE                = 0x20; /* Space */\nvar CHAR_EXCLAMATION          = 0x21; /* ! */\nvar CHAR_DOUBLE_QUOTE         = 0x22; /* \" */\nvar CHAR_SHARP                = 0x23; /* # */\nvar CHAR_PERCENT              = 0x25; /* % */\nvar CHAR_AMPERSAND            = 0x26; /* & */\nvar CHAR_SINGLE_QUOTE         = 0x27; /* ' */\nvar CHAR_ASTERISK             = 0x2A; /* * */\nvar CHAR_COMMA                = 0x2C; /* , */\nvar CHAR_MINUS                = 0x2D; /* - */\nvar CHAR_COLON                = 0x3A; /* : */\nvar CHAR_GREATER_THAN         = 0x3E; /* > */\nvar CHAR_QUESTION             = 0x3F; /* ? */\nvar CHAR_COMMERCIAL_AT        = 0x40; /* @ */\nvar CHAR_LEFT_SQUARE_BRACKET  = 0x5B; /* [ */\nvar CHAR_RIGHT_SQUARE_BRACKET = 0x5D; /* ] */\nvar CHAR_GRAVE_ACCENT         = 0x60; /* ` */\nvar CHAR_LEFT_CURLY_BRACKET   = 0x7B; /* { */\nvar CHAR_VERTICAL_LINE        = 0x7C; /* | */\nvar CHAR_RIGHT_CURLY_BRACKET  = 0x7D; /* } */\n\nvar ESCAPE_SEQUENCES = {};\n\nESCAPE_SEQUENCES[0x00]   = '\\\\0';\nESCAPE_SEQUENCES[0x07]   = '\\\\a';\nESCAPE_SEQUENCES[0x08]   = '\\\\b';\nESCAPE_SEQUENCES[0x09]   = '\\\\t';\nESCAPE_SEQUENCES[0x0A]   = '\\\\n';\nESCAPE_SEQUENCES[0x0B]   = '\\\\v';\nESCAPE_SEQUENCES[0x0C]   = '\\\\f';\nESCAPE_SEQUENCES[0x0D]   = '\\\\r';\nESCAPE_SEQUENCES[0x1B]   = '\\\\e';\nESCAPE_SEQUENCES[0x22]   = '\\\\\"';\nESCAPE_SEQUENCES[0x5C]   = '\\\\\\\\';\nESCAPE_SEQUENCES[0x85]   = '\\\\N';\nESCAPE_SEQUENCES[0xA0]   = '\\\\_';\nESCAPE_SEQUENCES[0x2028] = '\\\\L';\nESCAPE_SEQUENCES[0x2029] = '\\\\P';\n\nvar DEPRECATED_BOOLEANS_SYNTAX = [\n  'y', 'Y', 'yes', 'Yes', 'YES', 'on', 'On', 'ON',\n  'n', 'N', 'no', 'No', 'NO', 'off', 'Off', 'OFF'\n];\n\nfunction compileStyleMap(schema, map) {\n  var result, keys, index, length, tag, style, type;\n\n  if (null === map) {\n    return {};\n  }\n\n  result = {};\n  keys = Object.keys(map);\n\n  for (index = 0, length = keys.length; index < length; index += 1) {\n    tag = keys[index];\n    style = String(map[tag]);\n\n    if ('!!' === tag.slice(0, 2)) {\n      tag = 'tag:yaml.org,2002:' + tag.slice(2);\n    }\n\n    type = schema.compiledTypeMap[tag];\n\n    if (type && _hasOwnProperty.call(type.styleAliases, style)) {\n      style = type.styleAliases[style];\n    }\n\n    result[tag] = style;\n  }\n\n  return result;\n}\n\nfunction encodeHex(character) {\n  var string, handle, length;\n\n  string = character.toString(16).toUpperCase();\n\n  if (character <= 0xFF) {\n    handle = 'x';\n    length = 2;\n  } else if (character <= 0xFFFF) {\n    handle = 'u';\n    length = 4;\n  } else if (character <= 0xFFFFFFFF) {\n    handle = 'U';\n    length = 8;\n  } else {\n    throw new YAMLException('code point within a string may not be greater than 0xFFFFFFFF');\n  }\n\n  return '\\\\' + handle + common.repeat('0', length - string.length) + string;\n}\n\nfunction State(options) {\n  this.schema      = options['schema'] || DEFAULT_FULL_SCHEMA;\n  this.indent      = Math.max(1, (options['indent'] || 2));\n  this.skipInvalid = options['skipInvalid'] || false;\n  this.flowLevel   = (common.isNothing(options['flowLevel']) ? -1 : options['flowLevel']);\n  this.styleMap    = compileStyleMap(this.schema, options['styles'] || null);\n  this.sortKeys    = options['sortKeys'] || false;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.explicitTypes = this.schema.compiledExplicit;\n\n  this.tag = null;\n  this.result = '';\n\n  this.duplicates = [];\n  this.usedDuplicates = null;\n}\n\nfunction indentString(string, spaces) {\n  var ind = common.repeat(' ', spaces),\n      position = 0,\n      next = -1,\n      result = '',\n      line,\n      length = string.length;\n\n  while (position < length) {\n    next = string.indexOf('\\n', position);\n    if (next === -1) {\n      line = string.slice(position);\n      position = length;\n    } else {\n      line = string.slice(position, next + 1);\n      position = next + 1;\n    }\n    if (line.length && line !== '\\n') {\n      result += ind;\n    }\n    result += line;\n  }\n\n  return result;\n}\n\nfunction generateNextLine(state, level) {\n  return '\\n' + common.repeat(' ', state.indent * level);\n}\n\nfunction testImplicitResolving(state, str) {\n  var index, length, type;\n\n  for (index = 0, length = state.implicitTypes.length; index < length; index += 1) {\n    type = state.implicitTypes[index];\n\n    if (type.resolve(str)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction StringBuilder(source) {\n  this.source = source;\n  this.result = '';\n  this.checkpoint = 0;\n}\n\nStringBuilder.prototype.takeUpTo = function (position) {\n  var er;\n\n  if (position < this.checkpoint) {\n    er = new Error('position should be > checkpoint');\n    er.position = position;\n    er.checkpoint = this.checkpoint;\n    throw er;\n  }\n\n  this.result += this.source.slice(this.checkpoint, position);\n  this.checkpoint = position;\n  return this;\n};\n\nStringBuilder.prototype.escapeChar = function () {\n  var character, esc;\n\n  character = this.source.charCodeAt(this.checkpoint);\n  esc = ESCAPE_SEQUENCES[character] || encodeHex(character);\n  this.result += esc;\n  this.checkpoint += 1;\n\n  return this;\n};\n\nStringBuilder.prototype.finish = function () {\n  if (this.source.length > this.checkpoint) {\n    this.takeUpTo(this.source.length);\n  }\n};\n\nfunction writeScalar(state, object, level) {\n  var simple, first, spaceWrap, folded, literal, single, double,\n      sawLineFeed, linePosition, longestLine, indent, max, character,\n      position, escapeSeq, hexEsc, previous, lineLength, modifier,\n      trailingLineBreaks, result;\n\n  if (0 === object.length) {\n    state.dump = \"''\";\n    return;\n  }\n\n  if (-1 !== DEPRECATED_BOOLEANS_SYNTAX.indexOf(object)) {\n    state.dump = \"'\" + object + \"'\";\n    return;\n  }\n\n  simple = true;\n  first = object.length ? object.charCodeAt(0) : 0;\n  spaceWrap = (CHAR_SPACE === first ||\n               CHAR_SPACE === object.charCodeAt(object.length - 1));\n\n  // Simplified check for restricted first characters\n  // http://www.yaml.org/spec/1.2/spec.html#ns-plain-first%28c%29\n  if (CHAR_MINUS         === first ||\n      CHAR_QUESTION      === first ||\n      CHAR_COMMERCIAL_AT === first ||\n      CHAR_GRAVE_ACCENT  === first) {\n    simple = false;\n  }\n\n  // can only use > and | if not wrapped in spaces.\n  if (spaceWrap) {\n    simple = false;\n    folded = false;\n    literal = false;\n  } else {\n    folded = true;\n    literal = true;\n  }\n\n  single = true;\n  double = new StringBuilder(object);\n\n  sawLineFeed = false;\n  linePosition = 0;\n  longestLine = 0;\n\n  indent = state.indent * level;\n  max = 80;\n  if (indent < 40) {\n    max -= indent;\n  } else {\n    max = 40;\n  }\n\n  for (position = 0; position < object.length; position++) {\n    character = object.charCodeAt(position);\n    if (simple) {\n      // Characters that can never appear in the simple scalar\n      if (!simpleChar(character)) {\n        simple = false;\n      } else {\n        // Still simple.  If we make it all the way through like\n        // this, then we can just dump the string as-is.\n        continue;\n      }\n    }\n\n    if (single && character === CHAR_SINGLE_QUOTE) {\n      single = false;\n    }\n\n    escapeSeq = ESCAPE_SEQUENCES[character];\n    hexEsc = needsHexEscape(character);\n\n    if (!escapeSeq && !hexEsc) {\n      continue;\n    }\n\n    if (character !== CHAR_LINE_FEED &&\n        character !== CHAR_DOUBLE_QUOTE &&\n        character !== CHAR_SINGLE_QUOTE) {\n      folded = false;\n      literal = false;\n    } else if (character === CHAR_LINE_FEED) {\n      sawLineFeed = true;\n      single = false;\n      if (position > 0) {\n        previous = object.charCodeAt(position - 1);\n        if (previous === CHAR_SPACE) {\n          literal = false;\n          folded = false;\n        }\n      }\n      if (folded) {\n        lineLength = position - linePosition;\n        linePosition = position;\n        if (lineLength > longestLine) {\n          longestLine = lineLength;\n        }\n      }\n    }\n\n    if (character !== CHAR_DOUBLE_QUOTE) {\n      single = false;\n    }\n\n    double.takeUpTo(position);\n    double.escapeChar();\n  }\n\n  if (simple && testImplicitResolving(state, object)) {\n    simple = false;\n  }\n\n  modifier = '';\n  if (folded || literal) {\n    trailingLineBreaks = 0;\n    if (object.charCodeAt(object.length - 1) === CHAR_LINE_FEED) {\n      trailingLineBreaks += 1;\n      if (object.charCodeAt(object.length - 2) === CHAR_LINE_FEED) {\n        trailingLineBreaks += 1;\n      }\n    }\n\n    if (trailingLineBreaks === 0) {\n      modifier = '-';\n    } else if (trailingLineBreaks === 2) {\n      modifier = '+';\n    }\n  }\n\n  if (literal && longestLine < max) {\n    folded = false;\n  }\n\n  // If it's literally one line, then don't bother with the literal.\n  // We may still want to do a fold, though, if it's a super long line.\n  if (!sawLineFeed) {\n    literal = false;\n  }\n\n  if (simple) {\n    state.dump = object;\n  } else if (single) {\n    state.dump = '\\'' + object + '\\'';\n  } else if (folded) {\n    result = fold(object, max);\n    state.dump = '>' + modifier + '\\n' + indentString(result, indent);\n  } else if (literal) {\n    if (!modifier) {\n      object = object.replace(/\\n$/, '');\n    }\n    state.dump = '|' + modifier + '\\n' + indentString(object, indent);\n  } else if (double) {\n    double.finish();\n    state.dump = '\"' + double.result + '\"';\n  } else {\n    throw new Error('Failed to dump scalar value');\n  }\n\n  return;\n}\n\n// The `trailing` var is a regexp match of any trailing `\\n` characters.\n//\n// There are three cases we care about:\n//\n// 1. One trailing `\\n` on the string.  Just use `|` or `>`.\n//    This is the assumed default. (trailing = null)\n// 2. No trailing `\\n` on the string.  Use `|-` or `>-` to \"chomp\" the end.\n// 3. More than one trailing `\\n` on the string.  Use `|+` or `>+`.\n//\n// In the case of `>+`, these line breaks are *not* doubled (like the line\n// breaks within the string), so it's important to only end with the exact\n// same number as we started.\nfunction fold(object, max) {\n  var result = '',\n      position = 0,\n      length = object.length,\n      trailing = /\\n+$/.exec(object),\n      newLine;\n\n  if (trailing) {\n    length = trailing.index + 1;\n  }\n\n  while (position < length) {\n    newLine = object.indexOf('\\n', position);\n    if (newLine > length || newLine === -1) {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, length), max);\n      position = length;\n    } else {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, newLine), max);\n      position = newLine + 1;\n    }\n  }\n  if (trailing && trailing[0] !== '\\n') {\n    result += trailing[0];\n  }\n\n  return result;\n}\n\nfunction foldLine(line, max) {\n  if (line === '') {\n    return line;\n  }\n\n  var foldRe = /[^\\s] [^\\s]/g,\n      result = '',\n      prevMatch = 0,\n      foldStart = 0,\n      match = foldRe.exec(line),\n      index,\n      foldEnd,\n      folded;\n\n  while (match) {\n    index = match.index;\n\n    // when we cross the max len, if the previous match would've\n    // been ok, use that one, and carry on.  If there was no previous\n    // match on this fold section, then just have a long line.\n    if (index - foldStart > max) {\n      if (prevMatch !== foldStart) {\n        foldEnd = prevMatch;\n      } else {\n        foldEnd = index;\n      }\n\n      if (result) {\n        result += '\\n';\n      }\n      folded = line.slice(foldStart, foldEnd);\n      result += folded;\n      foldStart = foldEnd + 1;\n    }\n    prevMatch = index + 1;\n    match = foldRe.exec(line);\n  }\n\n  if (result) {\n    result += '\\n';\n  }\n\n  // if we end up with one last word at the end, then the last bit might\n  // be slightly bigger than we wanted, because we exited out of the loop.\n  if (foldStart !== prevMatch && line.length - foldStart > max) {\n    result += line.slice(foldStart, prevMatch) + '\\n' +\n              line.slice(prevMatch + 1);\n  } else {\n    result += line.slice(foldStart);\n  }\n\n  return result;\n}\n\n// Returns true if character can be found in a simple scalar\nfunction simpleChar(character) {\n  return CHAR_TAB                  !== character &&\n         CHAR_LINE_FEED            !== character &&\n         CHAR_CARRIAGE_RETURN      !== character &&\n         CHAR_COMMA                !== character &&\n         CHAR_LEFT_SQUARE_BRACKET  !== character &&\n         CHAR_RIGHT_SQUARE_BRACKET !== character &&\n         CHAR_LEFT_CURLY_BRACKET   !== character &&\n         CHAR_RIGHT_CURLY_BRACKET  !== character &&\n         CHAR_SHARP                !== character &&\n         CHAR_AMPERSAND            !== character &&\n         CHAR_ASTERISK             !== character &&\n         CHAR_EXCLAMATION          !== character &&\n         CHAR_VERTICAL_LINE        !== character &&\n         CHAR_GREATER_THAN         !== character &&\n         CHAR_SINGLE_QUOTE         !== character &&\n         CHAR_DOUBLE_QUOTE         !== character &&\n         CHAR_PERCENT              !== character &&\n         CHAR_COLON                !== character &&\n         !ESCAPE_SEQUENCES[character]            &&\n         !needsHexEscape(character);\n}\n\n// Returns true if the character code needs to be escaped.\nfunction needsHexEscape(character) {\n  return !((0x00020 <= character && character <= 0x00007E) ||\n           (0x00085 === character)                         ||\n           (0x000A0 <= character && character <= 0x00D7FF) ||\n           (0x0E000 <= character && character <= 0x00FFFD) ||\n           (0x10000 <= character && character <= 0x10FFFF));\n}\n\nfunction writeFlowSequence(state, level, object) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level, object[index], false, false)) {\n      if (0 !== index) {\n        _result += ', ';\n      }\n      _result += state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = '[' + _result + ']';\n}\n\nfunction writeBlockSequence(state, level, object, compact) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level + 1, object[index], true, true)) {\n      if (!compact || 0 !== index) {\n        _result += generateNextLine(state, level);\n      }\n      _result += '- ' + state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '[]'; // Empty sequence if no valid values.\n}\n\nfunction writeFlowMapping(state, level, object) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      pairBuffer;\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (0 !== index) {\n      pairBuffer += ', ';\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level, objectKey, false, false)) {\n      continue; // Skip this pair because of invalid key;\n    }\n\n    if (state.dump.length > 1024) {\n      pairBuffer += '? ';\n    }\n\n    pairBuffer += state.dump + ': ';\n\n    if (!writeNode(state, level, objectValue, false, false)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = '{' + _result + '}';\n}\n\nfunction writeBlockMapping(state, level, object, compact) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      explicitPair,\n      pairBuffer;\n\n  // Allow sorting keys so that the output file is deterministic\n  if (state.sortKeys === true) {\n    // Default sorting\n    objectKeyList.sort();\n  } else if (typeof state.sortKeys === 'function') {\n    // Custom sort function\n    objectKeyList.sort(state.sortKeys);\n  } else if (state.sortKeys) {\n    // Something is wrong\n    throw new YAMLException('sortKeys must be a boolean or a function');\n  }\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (!compact || 0 !== index) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level + 1, objectKey, true, true)) {\n      continue; // Skip this pair because of invalid key.\n    }\n\n    explicitPair = (null !== state.tag && '?' !== state.tag) ||\n                   (state.dump && state.dump.length > 1024);\n\n    if (explicitPair) {\n      if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n        pairBuffer += '?';\n      } else {\n        pairBuffer += '? ';\n      }\n    }\n\n    pairBuffer += state.dump;\n\n    if (explicitPair) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    if (!writeNode(state, level + 1, objectValue, true, explicitPair)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n      pairBuffer += ':';\n    } else {\n      pairBuffer += ': ';\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '{}'; // Empty mapping if no valid pairs.\n}\n\nfunction detectType(state, object, explicit) {\n  var _result, typeList, index, length, type, style;\n\n  typeList = explicit ? state.explicitTypes : state.implicitTypes;\n\n  for (index = 0, length = typeList.length; index < length; index += 1) {\n    type = typeList[index];\n\n    if ((type.instanceOf  || type.predicate) &&\n        (!type.instanceOf || (('object' === typeof object) && (object instanceof type.instanceOf))) &&\n        (!type.predicate  || type.predicate(object))) {\n\n      state.tag = explicit ? type.tag : '?';\n\n      if (type.represent) {\n        style = state.styleMap[type.tag] || type.defaultStyle;\n\n        if ('[object Function]' === _toString.call(type.represent)) {\n          _result = type.represent(object, style);\n        } else if (_hasOwnProperty.call(type.represent, style)) {\n          _result = type.represent[style](object, style);\n        } else {\n          throw new YAMLException('!<' + type.tag + '> tag resolver accepts not \"' + style + '\" style');\n        }\n\n        state.dump = _result;\n      }\n\n      return true;\n    }\n  }\n\n  return false;\n}\n\n// Serializes `object` and writes it to global `result`.\n// Returns true on success, or false on invalid object.\n//\nfunction writeNode(state, level, object, block, compact) {\n  state.tag = null;\n  state.dump = object;\n\n  if (!detectType(state, object, false)) {\n    detectType(state, object, true);\n  }\n\n  var type = _toString.call(state.dump);\n\n  if (block) {\n    block = (0 > state.flowLevel || state.flowLevel > level);\n  }\n\n  if ((null !== state.tag && '?' !== state.tag) || (2 !== state.indent && level > 0)) {\n    compact = false;\n  }\n\n  var objectOrArray = '[object Object]' === type || '[object Array]' === type,\n      duplicateIndex,\n      duplicate;\n\n  if (objectOrArray) {\n    duplicateIndex = state.duplicates.indexOf(object);\n    duplicate = duplicateIndex !== -1;\n  }\n\n  if (duplicate && state.usedDuplicates[duplicateIndex]) {\n    state.dump = '*ref_' + duplicateIndex;\n  } else {\n    if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) {\n      state.usedDuplicates[duplicateIndex] = true;\n    }\n    if ('[object Object]' === type) {\n      if (block && (0 !== Object.keys(state.dump).length)) {\n        writeBlockMapping(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + (0 === level ? '\\n' : '') + state.dump;\n        }\n      } else {\n        writeFlowMapping(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object Array]' === type) {\n      if (block && (0 !== state.dump.length)) {\n        writeBlockSequence(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + (0 === level ? '\\n' : '') + state.dump;\n        }\n      } else {\n        writeFlowSequence(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object String]' === type) {\n      if ('?' !== state.tag) {\n        writeScalar(state, state.dump, level);\n      }\n    } else {\n      if (state.skipInvalid) {\n        return false;\n      }\n      throw new YAMLException('unacceptable kind of an object to dump ' + type);\n    }\n\n    if (null !== state.tag && '?' !== state.tag) {\n      state.dump = '!<' + state.tag + '> ' + state.dump;\n    }\n  }\n\n  return true;\n}\n\nfunction getDuplicateReferences(object, state) {\n  var objects = [],\n      duplicatesIndexes = [],\n      index,\n      length;\n\n  inspectNode(object, objects, duplicatesIndexes);\n\n  for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) {\n    state.duplicates.push(objects[duplicatesIndexes[index]]);\n  }\n  state.usedDuplicates = new Array(length);\n}\n\nfunction inspectNode(object, objects, duplicatesIndexes) {\n  var type = _toString.call(object),\n      objectKeyList,\n      index,\n      length;\n\n  if (null !== object && 'object' === typeof object) {\n    index = objects.indexOf(object);\n    if (-1 !== index) {\n      if (-1 === duplicatesIndexes.indexOf(index)) {\n        duplicatesIndexes.push(index);\n      }\n    } else {\n      objects.push(object);\n\n      if (Array.isArray(object)) {\n        for (index = 0, length = object.length; index < length; index += 1) {\n          inspectNode(object[index], objects, duplicatesIndexes);\n        }\n      } else {\n        objectKeyList = Object.keys(object);\n\n        for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n          inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes);\n        }\n      }\n    }\n  }\n}\n\nfunction dump(input, options) {\n  options = options || {};\n\n  var state = new State(options);\n\n  getDuplicateReferences(input, state);\n\n  if (writeNode(state, 0, input, true, true)) {\n    return state.dump + '\\n';\n  }\n  return '';\n}\n\nfunction safeDump(input, options) {\n  return dump(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\nmodule.exports.dump     = dump;\nmodule.exports.safeDump = safeDump;\n","'use strict';\n\n\nfunction YAMLException(reason, mark) {\n  this.name    = 'YAMLException';\n  this.reason  = reason;\n  this.mark    = mark;\n  this.message = this.toString(false);\n}\n\n\nYAMLException.prototype.toString = function toString(compact) {\n  var result;\n\n  result = 'JS-YAML: ' + (this.reason || '(unknown reason)');\n\n  if (!compact && this.mark) {\n    result += ' ' + this.mark.toString();\n  }\n\n  return result;\n};\n\n\nmodule.exports = YAMLException;\n","'use strict';\n\n/*eslint-disable max-len,no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar Mark                = require('./mark');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\n\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\n\nvar CONTEXT_FLOW_IN   = 1;\nvar CONTEXT_FLOW_OUT  = 2;\nvar CONTEXT_BLOCK_IN  = 3;\nvar CONTEXT_BLOCK_OUT = 4;\n\n\nvar CHOMPING_CLIP  = 1;\nvar CHOMPING_STRIP = 2;\nvar CHOMPING_KEEP  = 3;\n\n\nvar PATTERN_NON_PRINTABLE         = /[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7F-\\x84\\x86-\\x9F\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\nvar PATTERN_NON_ASCII_LINE_BREAKS = /[\\x85\\u2028\\u2029]/;\nvar PATTERN_FLOW_INDICATORS       = /[,\\[\\]\\{\\}]/;\nvar PATTERN_TAG_HANDLE            = /^(?:!|!!|![a-z\\-]+!)$/i;\nvar PATTERN_TAG_URI               = /^(?:!|[^,\\[\\]\\{\\}])(?:%[0-9a-f]{2}|[0-9a-z\\-#;\\/\\?:@&=\\+\\$,_\\.!~\\*'\\(\\)\\[\\]])*$/i;\n\n\nfunction is_EOL(c) {\n  return (c === 0x0A/* LF */) || (c === 0x0D/* CR */);\n}\n\nfunction is_WHITE_SPACE(c) {\n  return (c === 0x09/* Tab */) || (c === 0x20/* Space */);\n}\n\nfunction is_WS_OR_EOL(c) {\n  return (c === 0x09/* Tab */) ||\n         (c === 0x20/* Space */) ||\n         (c === 0x0A/* LF */) ||\n         (c === 0x0D/* CR */);\n}\n\nfunction is_FLOW_INDICATOR(c) {\n  return 0x2C/* , */ === c ||\n         0x5B/* [ */ === c ||\n         0x5D/* ] */ === c ||\n         0x7B/* { */ === c ||\n         0x7D/* } */ === c;\n}\n\nfunction fromHexCode(c) {\n  var lc;\n\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  /*eslint-disable no-bitwise*/\n  lc = c | 0x20;\n\n  if ((0x61/* a */ <= lc) && (lc <= 0x66/* f */)) {\n    return lc - 0x61 + 10;\n  }\n\n  return -1;\n}\n\nfunction escapedHexLen(c) {\n  if (c === 0x78/* x */) { return 2; }\n  if (c === 0x75/* u */) { return 4; }\n  if (c === 0x55/* U */) { return 8; }\n  return 0;\n}\n\nfunction fromDecimalCode(c) {\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  return -1;\n}\n\nfunction simpleEscapeSequence(c) {\n  return (c === 0x30/* 0 */) ? '\\x00' :\n        (c === 0x61/* a */) ? '\\x07' :\n        (c === 0x62/* b */) ? '\\x08' :\n        (c === 0x74/* t */) ? '\\x09' :\n        (c === 0x09/* Tab */) ? '\\x09' :\n        (c === 0x6E/* n */) ? '\\x0A' :\n        (c === 0x76/* v */) ? '\\x0B' :\n        (c === 0x66/* f */) ? '\\x0C' :\n        (c === 0x72/* r */) ? '\\x0D' :\n        (c === 0x65/* e */) ? '\\x1B' :\n        (c === 0x20/* Space */) ? ' ' :\n        (c === 0x22/* \" */) ? '\\x22' :\n        (c === 0x2F/* / */) ? '/' :\n        (c === 0x5C/* \\ */) ? '\\x5C' :\n        (c === 0x4E/* N */) ? '\\x85' :\n        (c === 0x5F/* _ */) ? '\\xA0' :\n        (c === 0x4C/* L */) ? '\\u2028' :\n        (c === 0x50/* P */) ? '\\u2029' : '';\n}\n\nfunction charFromCodepoint(c) {\n  if (c <= 0xFFFF) {\n    return String.fromCharCode(c);\n  }\n  // Encode UTF-16 surrogate pair\n  // https://en.wikipedia.org/wiki/UTF-16#Code_points_U.2B010000_to_U.2B10FFFF\n  return String.fromCharCode(((c - 0x010000) >> 10) + 0xD800,\n                             ((c - 0x010000) & 0x03FF) + 0xDC00);\n}\n\nvar simpleEscapeCheck = new Array(256); // integer, for fast access\nvar simpleEscapeMap = new Array(256);\nfor (var i = 0; i < 256; i++) {\n  simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0;\n  simpleEscapeMap[i] = simpleEscapeSequence(i);\n}\n\n\nfunction State(input, options) {\n  this.input = input;\n\n  this.filename  = options['filename']  || null;\n  this.schema    = options['schema']    || DEFAULT_FULL_SCHEMA;\n  this.onWarning = options['onWarning'] || null;\n  this.legacy    = options['legacy']    || false;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.typeMap       = this.schema.compiledTypeMap;\n\n  this.length     = input.length;\n  this.position   = 0;\n  this.line       = 0;\n  this.lineStart  = 0;\n  this.lineIndent = 0;\n\n  this.documents = [];\n\n  /*\n  this.version;\n  this.checkLineBreaks;\n  this.tagMap;\n  this.anchorMap;\n  this.tag;\n  this.anchor;\n  this.kind;\n  this.result;*/\n\n}\n\n\nfunction generateError(state, message) {\n  return new YAMLException(\n    message,\n    new Mark(state.filename, state.input, state.position, state.line, (state.position - state.lineStart)));\n}\n\nfunction throwError(state, message) {\n  throw generateError(state, message);\n}\n\nfunction throwWarning(state, message) {\n  var error = generateError(state, message);\n\n  if (state.onWarning) {\n    state.onWarning.call(null, error);\n  } else {\n    throw error;\n  }\n}\n\n\nvar directiveHandlers = {\n\n  YAML: function handleYamlDirective(state, name, args) {\n\n      var match, major, minor;\n\n      if (null !== state.version) {\n        throwError(state, 'duplication of %YAML directive');\n      }\n\n      if (1 !== args.length) {\n        throwError(state, 'YAML directive accepts exactly one argument');\n      }\n\n      match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n      if (null === match) {\n        throwError(state, 'ill-formed argument of the YAML directive');\n      }\n\n      major = parseInt(match[1], 10);\n      minor = parseInt(match[2], 10);\n\n      if (1 !== major) {\n        throwError(state, 'unacceptable YAML version of the document');\n      }\n\n      state.version = args[0];\n      state.checkLineBreaks = (minor < 2);\n\n      if (1 !== minor && 2 !== minor) {\n        throwWarning(state, 'unsupported YAML version of the document');\n      }\n    },\n\n  TAG: function handleTagDirective(state, name, args) {\n\n      var handle, prefix;\n\n      if (2 !== args.length) {\n        throwError(state, 'TAG directive accepts exactly two arguments');\n      }\n\n      handle = args[0];\n      prefix = args[1];\n\n      if (!PATTERN_TAG_HANDLE.test(handle)) {\n        throwError(state, 'ill-formed tag handle (first argument) of the TAG directive');\n      }\n\n      if (_hasOwnProperty.call(state.tagMap, handle)) {\n        throwError(state, 'there is a previously declared suffix for \"' + handle + '\" tag handle');\n      }\n\n      if (!PATTERN_TAG_URI.test(prefix)) {\n        throwError(state, 'ill-formed tag prefix (second argument) of the TAG directive');\n      }\n\n      state.tagMap[handle] = prefix;\n    }\n};\n\n\nfunction captureSegment(state, start, end, checkJson) {\n  var _position, _length, _character, _result;\n\n  if (start < end) {\n    _result = state.input.slice(start, end);\n\n    if (checkJson) {\n      for (_position = 0, _length = _result.length;\n           _position < _length;\n           _position += 1) {\n        _character = _result.charCodeAt(_position);\n        if (!(0x09 === _character ||\n              0x20 <= _character && _character <= 0x10FFFF)) {\n          throwError(state, 'expected valid JSON character');\n        }\n      }\n    }\n\n    state.result += _result;\n  }\n}\n\nfunction mergeMappings(state, destination, source) {\n  var sourceKeys, key, index, quantity;\n\n  if (!common.isObject(source)) {\n    throwError(state, 'cannot merge mappings; the provided source object is unacceptable');\n  }\n\n  sourceKeys = Object.keys(source);\n\n  for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) {\n    key = sourceKeys[index];\n\n    if (!_hasOwnProperty.call(destination, key)) {\n      destination[key] = source[key];\n    }\n  }\n}\n\nfunction storeMappingPair(state, _result, keyTag, keyNode, valueNode) {\n  var index, quantity;\n\n  keyNode = String(keyNode);\n\n  if (null === _result) {\n    _result = {};\n  }\n\n  if ('tag:yaml.org,2002:merge' === keyTag) {\n    if (Array.isArray(valueNode)) {\n      for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n        mergeMappings(state, _result, valueNode[index]);\n      }\n    } else {\n      mergeMappings(state, _result, valueNode);\n    }\n  } else {\n    _result[keyNode] = valueNode;\n  }\n\n  return _result;\n}\n\nfunction readLineBreak(state) {\n  var ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x0A/* LF */ === ch) {\n    state.position++;\n  } else if (0x0D/* CR */ === ch) {\n    state.position++;\n    if (0x0A/* LF */ === state.input.charCodeAt(state.position)) {\n      state.position++;\n    }\n  } else {\n    throwError(state, 'a line break is expected');\n  }\n\n  state.line += 1;\n  state.lineStart = state.position;\n}\n\nfunction skipSeparationSpace(state, allowComments, checkIndent) {\n  var lineBreaks = 0,\n      ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    while (is_WHITE_SPACE(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (allowComments && 0x23/* # */ === ch) {\n      do {\n        ch = state.input.charCodeAt(++state.position);\n      } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && 0 !== ch);\n    }\n\n    if (is_EOL(ch)) {\n      readLineBreak(state);\n\n      ch = state.input.charCodeAt(state.position);\n      lineBreaks++;\n      state.lineIndent = 0;\n\n      while (0x20/* Space */ === ch) {\n        state.lineIndent++;\n        ch = state.input.charCodeAt(++state.position);\n      }\n    } else {\n      break;\n    }\n  }\n\n  if (-1 !== checkIndent && 0 !== lineBreaks && state.lineIndent < checkIndent) {\n    throwWarning(state, 'deficient indentation');\n  }\n\n  return lineBreaks;\n}\n\nfunction testDocumentSeparator(state) {\n  var _position = state.position,\n      ch;\n\n  ch = state.input.charCodeAt(_position);\n\n  // Condition state.position === state.lineStart is tested\n  // in parent on each call, for efficiency. No needs to test here again.\n  if ((0x2D/* - */ === ch || 0x2E/* . */ === ch) &&\n      state.input.charCodeAt(_position + 1) === ch &&\n      state.input.charCodeAt(_position + 2) === ch) {\n\n    _position += 3;\n\n    ch = state.input.charCodeAt(_position);\n\n    if (ch === 0 || is_WS_OR_EOL(ch)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction writeFoldedLines(state, count) {\n  if (1 === count) {\n    state.result += ' ';\n  } else if (count > 1) {\n    state.result += common.repeat('\\n', count - 1);\n  }\n}\n\n\nfunction readPlainScalar(state, nodeIndent, withinFlowCollection) {\n  var preceding,\n      following,\n      captureStart,\n      captureEnd,\n      hasPendingContent,\n      _line,\n      _lineStart,\n      _lineIndent,\n      _kind = state.kind,\n      _result = state.result,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (is_WS_OR_EOL(ch)             ||\n      is_FLOW_INDICATOR(ch)        ||\n      0x23/* # */           === ch ||\n      0x26/* & */           === ch ||\n      0x2A/* * */           === ch ||\n      0x21/* ! */           === ch ||\n      0x7C/* | */           === ch ||\n      0x3E/* > */           === ch ||\n      0x27/* ' */           === ch ||\n      0x22/* \" */           === ch ||\n      0x25/* % */           === ch ||\n      0x40/* @ */           === ch ||\n      0x60/* ` */           === ch) {\n    return false;\n  }\n\n  if (0x3F/* ? */ === ch || 0x2D/* - */ === ch) {\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (is_WS_OR_EOL(following) ||\n        withinFlowCollection && is_FLOW_INDICATOR(following)) {\n      return false;\n    }\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  captureStart = captureEnd = state.position;\n  hasPendingContent = false;\n\n  while (0 !== ch) {\n    if (0x3A/* : */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following) ||\n          withinFlowCollection && is_FLOW_INDICATOR(following)) {\n        break;\n      }\n\n    } else if (0x23/* # */ === ch) {\n      preceding = state.input.charCodeAt(state.position - 1);\n\n      if (is_WS_OR_EOL(preceding)) {\n        break;\n      }\n\n    } else if ((state.position === state.lineStart && testDocumentSeparator(state)) ||\n               withinFlowCollection && is_FLOW_INDICATOR(ch)) {\n      break;\n\n    } else if (is_EOL(ch)) {\n      _line = state.line;\n      _lineStart = state.lineStart;\n      _lineIndent = state.lineIndent;\n      skipSeparationSpace(state, false, -1);\n\n      if (state.lineIndent >= nodeIndent) {\n        hasPendingContent = true;\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      } else {\n        state.position = captureEnd;\n        state.line = _line;\n        state.lineStart = _lineStart;\n        state.lineIndent = _lineIndent;\n        break;\n      }\n    }\n\n    if (hasPendingContent) {\n      captureSegment(state, captureStart, captureEnd, false);\n      writeFoldedLines(state, state.line - _line);\n      captureStart = captureEnd = state.position;\n      hasPendingContent = false;\n    }\n\n    if (!is_WHITE_SPACE(ch)) {\n      captureEnd = state.position + 1;\n    }\n\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  captureSegment(state, captureStart, captureEnd, false);\n\n  if (state.result) {\n    return true;\n  }\n\n  state.kind = _kind;\n  state.result = _result;\n  return false;\n}\n\nfunction readSingleQuotedScalar(state, nodeIndent) {\n  var ch,\n      captureStart, captureEnd;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x27/* ' */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x27/* ' */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (0x27/* ' */ === ch) {\n        captureStart = captureEnd = state.position;\n        state.position++;\n      } else {\n        return true;\n      }\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a single quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a single quoted scalar');\n}\n\nfunction readDoubleQuotedScalar(state, nodeIndent) {\n  var captureStart,\n      captureEnd,\n      hexLength,\n      hexResult,\n      tmp, tmpEsc,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x22/* \" */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x22/* \" */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      state.position++;\n      return true;\n\n    } else if (0x5C/* \\ */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (is_EOL(ch)) {\n        skipSeparationSpace(state, false, nodeIndent);\n\n        // TODO: rework to inline fn with no type cast?\n      } else if (ch < 256 && simpleEscapeCheck[ch]) {\n        state.result += simpleEscapeMap[ch];\n        state.position++;\n\n      } else if ((tmp = escapedHexLen(ch)) > 0) {\n        hexLength = tmp;\n        hexResult = 0;\n\n        for (; hexLength > 0; hexLength--) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if ((tmp = fromHexCode(ch)) >= 0) {\n            hexResult = (hexResult << 4) + tmp;\n\n          } else {\n            throwError(state, 'expected hexadecimal character');\n          }\n        }\n\n        state.result += charFromCodepoint(hexResult);\n\n        state.position++;\n\n      } else {\n        throwError(state, 'unknown escape sequence');\n      }\n\n      captureStart = captureEnd = state.position;\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a double quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a double quoted scalar');\n}\n\nfunction readFlowCollection(state, nodeIndent) {\n  var readNext = true,\n      _line,\n      _tag     = state.tag,\n      _result,\n      _anchor  = state.anchor,\n      following,\n      terminator,\n      isPair,\n      isExplicitPair,\n      isMapping,\n      keyNode,\n      keyTag,\n      valueNode,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x5B/* [ */) {\n    terminator = 0x5D;/* ] */\n    isMapping = false;\n    _result = [];\n  } else if (ch === 0x7B/* { */) {\n    terminator = 0x7D;/* } */\n    isMapping = true;\n    _result = {};\n  } else {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  while (0 !== ch) {\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (ch === terminator) {\n      state.position++;\n      state.tag = _tag;\n      state.anchor = _anchor;\n      state.kind = isMapping ? 'mapping' : 'sequence';\n      state.result = _result;\n      return true;\n    } else if (!readNext) {\n      throwError(state, 'missed comma between flow collection entries');\n    }\n\n    keyTag = keyNode = valueNode = null;\n    isPair = isExplicitPair = false;\n\n    if (0x3F/* ? */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following)) {\n        isPair = isExplicitPair = true;\n        state.position++;\n        skipSeparationSpace(state, true, nodeIndent);\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n    keyTag = state.tag;\n    keyNode = state.result;\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((isExplicitPair || state.line === _line) && 0x3A/* : */ === ch) {\n      isPair = true;\n      ch = state.input.charCodeAt(++state.position);\n      skipSeparationSpace(state, true, nodeIndent);\n      composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n      valueNode = state.result;\n    }\n\n    if (isMapping) {\n      storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n    } else if (isPair) {\n      _result.push(storeMappingPair(state, null, keyTag, keyNode, valueNode));\n    } else {\n      _result.push(keyNode);\n    }\n\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (0x2C/* , */ === ch) {\n      readNext = true;\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      readNext = false;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a flow collection');\n}\n\nfunction readBlockScalar(state, nodeIndent) {\n  var captureStart,\n      folding,\n      chomping       = CHOMPING_CLIP,\n      detectedIndent = false,\n      textIndent     = nodeIndent,\n      emptyLines     = 0,\n      atMoreIndented = false,\n      tmp,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x7C/* | */) {\n    folding = false;\n  } else if (ch === 0x3E/* > */) {\n    folding = true;\n  } else {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n\n  while (0 !== ch) {\n    ch = state.input.charCodeAt(++state.position);\n\n    if (0x2B/* + */ === ch || 0x2D/* - */ === ch) {\n      if (CHOMPING_CLIP === chomping) {\n        chomping = (0x2B/* + */ === ch) ? CHOMPING_KEEP : CHOMPING_STRIP;\n      } else {\n        throwError(state, 'repeat of a chomping mode identifier');\n      }\n\n    } else if ((tmp = fromDecimalCode(ch)) >= 0) {\n      if (tmp === 0) {\n        throwError(state, 'bad explicit indentation width of a block scalar; it cannot be less than one');\n      } else if (!detectedIndent) {\n        textIndent = nodeIndent + tmp - 1;\n        detectedIndent = true;\n      } else {\n        throwError(state, 'repeat of an indentation width identifier');\n      }\n\n    } else {\n      break;\n    }\n  }\n\n  if (is_WHITE_SPACE(ch)) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (is_WHITE_SPACE(ch));\n\n    if (0x23/* # */ === ch) {\n      do { ch = state.input.charCodeAt(++state.position); }\n      while (!is_EOL(ch) && (0 !== ch));\n    }\n  }\n\n  while (0 !== ch) {\n    readLineBreak(state);\n    state.lineIndent = 0;\n\n    ch = state.input.charCodeAt(state.position);\n\n    while ((!detectedIndent || state.lineIndent < textIndent) &&\n           (0x20/* Space */ === ch)) {\n      state.lineIndent++;\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (!detectedIndent && state.lineIndent > textIndent) {\n      textIndent = state.lineIndent;\n    }\n\n    if (is_EOL(ch)) {\n      emptyLines++;\n      continue;\n    }\n\n    // End of the scalar.\n    if (state.lineIndent < textIndent) {\n\n      // Perform the chomping.\n      if (chomping === CHOMPING_KEEP) {\n        state.result += common.repeat('\\n', emptyLines);\n      } else if (chomping === CHOMPING_CLIP) {\n        if (detectedIndent) { // i.e. only if the scalar is not empty.\n          state.result += '\\n';\n        }\n      }\n\n      // Break this `while` cycle and go to the funciton's epilogue.\n      break;\n    }\n\n    // Folded style: use fancy rules to handle line breaks.\n    if (folding) {\n\n      // Lines starting with white space characters (more-indented lines) are not folded.\n      if (is_WHITE_SPACE(ch)) {\n        atMoreIndented = true;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // End of more-indented block.\n      } else if (atMoreIndented) {\n        atMoreIndented = false;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // Just one line break - perceive as the same line.\n      } else if (0 === emptyLines) {\n        if (detectedIndent) { // i.e. only if we have already read some scalar content.\n          state.result += ' ';\n        }\n\n      // Several line breaks - perceive as different lines.\n      } else {\n        state.result += common.repeat('\\n', emptyLines);\n      }\n\n    // Literal style: just add exact number of line breaks between content lines.\n    } else if (detectedIndent) {\n      // If current line isn't the first one - count line break from the last content line.\n      state.result += common.repeat('\\n', emptyLines + 1);\n    } else {\n      // In case of the first content line - count only empty lines.\n    }\n\n    detectedIndent = true;\n    emptyLines = 0;\n    captureStart = state.position;\n\n    while (!is_EOL(ch) && (0 !== ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    captureSegment(state, captureStart, state.position, false);\n  }\n\n  return true;\n}\n\nfunction readBlockSequence(state, nodeIndent) {\n  var _line,\n      _tag      = state.tag,\n      _anchor   = state.anchor,\n      _result   = [],\n      following,\n      detected  = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n\n    if (0x2D/* - */ !== ch) {\n      break;\n    }\n\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (!is_WS_OR_EOL(following)) {\n      break;\n    }\n\n    detected = true;\n    state.position++;\n\n    if (skipSeparationSpace(state, true, -1)) {\n      if (state.lineIndent <= nodeIndent) {\n        _result.push(null);\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true);\n    _result.push(state.result);\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((state.line === _line || state.lineIndent > nodeIndent) && (0 !== ch)) {\n      throwError(state, 'bad indentation of a sequence entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'sequence';\n    state.result = _result;\n    return true;\n  }\n  return false;\n}\n\nfunction readBlockMapping(state, nodeIndent, flowIndent) {\n  var following,\n      allowCompact,\n      _line,\n      _tag          = state.tag,\n      _anchor       = state.anchor,\n      _result       = {},\n      keyTag        = null,\n      keyNode       = null,\n      valueNode     = null,\n      atExplicitKey = false,\n      detected      = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    following = state.input.charCodeAt(state.position + 1);\n    _line = state.line; // Save the current line.\n\n    //\n    // Explicit notation case. There are two separate blocks:\n    // first for the key (denoted by \"?\") and second for the value (denoted by \":\")\n    //\n    if ((0x3F/* ? */ === ch || 0x3A/* : */  === ch) && is_WS_OR_EOL(following)) {\n\n      if (0x3F/* ? */ === ch) {\n        if (atExplicitKey) {\n          storeMappingPair(state, _result, keyTag, keyNode, null);\n          keyTag = keyNode = valueNode = null;\n        }\n\n        detected = true;\n        atExplicitKey = true;\n        allowCompact = true;\n\n      } else if (atExplicitKey) {\n        // i.e. 0x3A/* : */ === character after the explicit key.\n        atExplicitKey = false;\n        allowCompact = true;\n\n      } else {\n        throwError(state, 'incomplete explicit mapping pair; a key node is missed');\n      }\n\n      state.position += 1;\n      ch = following;\n\n    //\n    // Implicit notation case. Flow-style node as the key first, then \":\", and the value.\n    //\n    } else if (composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) {\n\n      if (state.line === _line) {\n        ch = state.input.charCodeAt(state.position);\n\n        while (is_WHITE_SPACE(ch)) {\n          ch = state.input.charCodeAt(++state.position);\n        }\n\n        if (0x3A/* : */ === ch) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if (!is_WS_OR_EOL(ch)) {\n            throwError(state, 'a whitespace character is expected after the key-value separator within a block mapping');\n          }\n\n          if (atExplicitKey) {\n            storeMappingPair(state, _result, keyTag, keyNode, null);\n            keyTag = keyNode = valueNode = null;\n          }\n\n          detected = true;\n          atExplicitKey = false;\n          allowCompact = false;\n          keyTag = state.tag;\n          keyNode = state.result;\n\n        } else if (detected) {\n          throwError(state, 'can not read an implicit mapping pair; a colon is missed');\n\n        } else {\n          state.tag = _tag;\n          state.anchor = _anchor;\n          return true; // Keep the result of `composeNode`.\n        }\n\n      } else if (detected) {\n        throwError(state, 'can not read a block mapping entry; a multiline key may not be an implicit key');\n\n      } else {\n        state.tag = _tag;\n        state.anchor = _anchor;\n        return true; // Keep the result of `composeNode`.\n      }\n\n    } else {\n      break; // Reading is done. Go to the epilogue.\n    }\n\n    //\n    // Common reading code for both explicit and implicit notations.\n    //\n    if (state.line === _line || state.lineIndent > nodeIndent) {\n      if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) {\n        if (atExplicitKey) {\n          keyNode = state.result;\n        } else {\n          valueNode = state.result;\n        }\n      }\n\n      if (!atExplicitKey) {\n        storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n        keyTag = keyNode = valueNode = null;\n      }\n\n      skipSeparationSpace(state, true, -1);\n      ch = state.input.charCodeAt(state.position);\n    }\n\n    if (state.lineIndent > nodeIndent && (0 !== ch)) {\n      throwError(state, 'bad indentation of a mapping entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  //\n  // Epilogue.\n  //\n\n  // Special case: last mapping's node contains only the key in explicit notation.\n  if (atExplicitKey) {\n    storeMappingPair(state, _result, keyTag, keyNode, null);\n  }\n\n  // Expose the resulting mapping.\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'mapping';\n    state.result = _result;\n  }\n\n  return detected;\n}\n\nfunction readTagProperty(state) {\n  var _position,\n      isVerbatim = false,\n      isNamed    = false,\n      tagHandle,\n      tagName,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x21/* ! */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.tag) {\n    throwError(state, 'duplication of a tag property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  if (0x3C/* < */ === ch) {\n    isVerbatim = true;\n    ch = state.input.charCodeAt(++state.position);\n\n  } else if (0x21/* ! */ === ch) {\n    isNamed = true;\n    tagHandle = '!!';\n    ch = state.input.charCodeAt(++state.position);\n\n  } else {\n    tagHandle = '!';\n  }\n\n  _position = state.position;\n\n  if (isVerbatim) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (0 !== ch && 0x3E/* > */ !== ch);\n\n    if (state.position < state.length) {\n      tagName = state.input.slice(_position, state.position);\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      throwError(state, 'unexpected end of the stream within a verbatim tag');\n    }\n  } else {\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n\n      if (0x21/* ! */ === ch) {\n        if (!isNamed) {\n          tagHandle = state.input.slice(_position - 1, state.position + 1);\n\n          if (!PATTERN_TAG_HANDLE.test(tagHandle)) {\n            throwError(state, 'named tag handle cannot contain such characters');\n          }\n\n          isNamed = true;\n          _position = state.position + 1;\n        } else {\n          throwError(state, 'tag suffix cannot contain exclamation marks');\n        }\n      }\n\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    tagName = state.input.slice(_position, state.position);\n\n    if (PATTERN_FLOW_INDICATORS.test(tagName)) {\n      throwError(state, 'tag suffix cannot contain flow indicator characters');\n    }\n  }\n\n  if (tagName && !PATTERN_TAG_URI.test(tagName)) {\n    throwError(state, 'tag name cannot contain such characters: ' + tagName);\n  }\n\n  if (isVerbatim) {\n    state.tag = tagName;\n\n  } else if (_hasOwnProperty.call(state.tagMap, tagHandle)) {\n    state.tag = state.tagMap[tagHandle] + tagName;\n\n  } else if ('!' === tagHandle) {\n    state.tag = '!' + tagName;\n\n  } else if ('!!' === tagHandle) {\n    state.tag = 'tag:yaml.org,2002:' + tagName;\n\n  } else {\n    throwError(state, 'undeclared tag handle \"' + tagHandle + '\"');\n  }\n\n  return true;\n}\n\nfunction readAnchorProperty(state) {\n  var _position,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x26/* & */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    throwError(state, 'duplication of an anchor property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an anchor node must contain at least one character');\n  }\n\n  state.anchor = state.input.slice(_position, state.position);\n  return true;\n}\n\nfunction readAlias(state) {\n  var _position, alias,\n      len = state.length,\n      input = state.input,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x2A/* * */ !== ch) {\n    return false;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an alias node must contain at least one character');\n  }\n\n  alias = state.input.slice(_position, state.position);\n\n  if (!state.anchorMap.hasOwnProperty(alias)) {\n    throwError(state, 'unidentified alias \"' + alias + '\"');\n  }\n\n  state.result = state.anchorMap[alias];\n  skipSeparationSpace(state, true, -1);\n  return true;\n}\n\nfunction composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) {\n  var allowBlockStyles,\n      allowBlockScalars,\n      allowBlockCollections,\n      indentStatus = 1, // 1: this>parent, 0: this=parent, -1: this<parent\n      atNewLine  = false,\n      hasContent = false,\n      typeIndex,\n      typeQuantity,\n      type,\n      flowIndent,\n      blockIndent,\n      _result;\n\n  state.tag    = null;\n  state.anchor = null;\n  state.kind   = null;\n  state.result = null;\n\n  allowBlockStyles = allowBlockScalars = allowBlockCollections =\n    CONTEXT_BLOCK_OUT === nodeContext ||\n    CONTEXT_BLOCK_IN  === nodeContext;\n\n  if (allowToSeek) {\n    if (skipSeparationSpace(state, true, -1)) {\n      atNewLine = true;\n\n      if (state.lineIndent > parentIndent) {\n        indentStatus = 1;\n      } else if (state.lineIndent === parentIndent) {\n        indentStatus = 0;\n      } else if (state.lineIndent < parentIndent) {\n        indentStatus = -1;\n      }\n    }\n  }\n\n  if (1 === indentStatus) {\n    while (readTagProperty(state) || readAnchorProperty(state)) {\n      if (skipSeparationSpace(state, true, -1)) {\n        atNewLine = true;\n        allowBlockCollections = allowBlockStyles;\n\n        if (state.lineIndent > parentIndent) {\n          indentStatus = 1;\n        } else if (state.lineIndent === parentIndent) {\n          indentStatus = 0;\n        } else if (state.lineIndent < parentIndent) {\n          indentStatus = -1;\n        }\n      } else {\n        allowBlockCollections = false;\n      }\n    }\n  }\n\n  if (allowBlockCollections) {\n    allowBlockCollections = atNewLine || allowCompact;\n  }\n\n  if (1 === indentStatus || CONTEXT_BLOCK_OUT === nodeContext) {\n    if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) {\n      flowIndent = parentIndent;\n    } else {\n      flowIndent = parentIndent + 1;\n    }\n\n    blockIndent = state.position - state.lineStart;\n\n    if (1 === indentStatus) {\n      if (allowBlockCollections &&\n          (readBlockSequence(state, blockIndent) ||\n           readBlockMapping(state, blockIndent, flowIndent)) ||\n          readFlowCollection(state, flowIndent)) {\n        hasContent = true;\n      } else {\n        if ((allowBlockScalars && readBlockScalar(state, flowIndent)) ||\n            readSingleQuotedScalar(state, flowIndent) ||\n            readDoubleQuotedScalar(state, flowIndent)) {\n          hasContent = true;\n\n        } else if (readAlias(state)) {\n          hasContent = true;\n\n          if (null !== state.tag || null !== state.anchor) {\n            throwError(state, 'alias node should not have any properties');\n          }\n\n        } else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) {\n          hasContent = true;\n\n          if (null === state.tag) {\n            state.tag = '?';\n          }\n        }\n\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else if (0 === indentStatus) {\n      // Special case: block sequences are allowed to have same indentation level as the parent.\n      // http://www.yaml.org/spec/1.2/spec.html#id2799784\n      hasContent = allowBlockCollections && readBlockSequence(state, blockIndent);\n    }\n  }\n\n  if (null !== state.tag && '!' !== state.tag) {\n    if ('?' === state.tag) {\n      for (typeIndex = 0, typeQuantity = state.implicitTypes.length;\n           typeIndex < typeQuantity;\n           typeIndex += 1) {\n        type = state.implicitTypes[typeIndex];\n\n        // Implicit resolving is not allowed for non-scalar types, and '?'\n        // non-specific tag is only assigned to plain scalars. So, it isn't\n        // needed to check for 'kind' conformity.\n\n        if (type.resolve(state.result)) { // `state.result` updated in resolver if matched\n          state.result = type.construct(state.result);\n          state.tag = type.tag;\n          if (null !== state.anchor) {\n            state.anchorMap[state.anchor] = state.result;\n          }\n          break;\n        }\n      }\n    } else if (_hasOwnProperty.call(state.typeMap, state.tag)) {\n      type = state.typeMap[state.tag];\n\n      if (null !== state.result && type.kind !== state.kind) {\n        throwError(state, 'unacceptable node kind for !<' + state.tag + '> tag; it should be \"' + type.kind + '\", not \"' + state.kind + '\"');\n      }\n\n      if (!type.resolve(state.result)) { // `state.result` updated in resolver if matched\n        throwError(state, 'cannot resolve a node with !<' + state.tag + '> explicit tag');\n      } else {\n        state.result = type.construct(state.result);\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else {\n      throwWarning(state, 'unknown tag !<' + state.tag + '>');\n    }\n  }\n\n  return null !== state.tag || null !== state.anchor || hasContent;\n}\n\nfunction readDocument(state) {\n  var documentStart = state.position,\n      _position,\n      directiveName,\n      directiveArgs,\n      hasDirectives = false,\n      ch;\n\n  state.version = null;\n  state.checkLineBreaks = state.legacy;\n  state.tagMap = {};\n  state.anchorMap = {};\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (state.lineIndent > 0 || 0x25/* % */ !== ch) {\n      break;\n    }\n\n    hasDirectives = true;\n    ch = state.input.charCodeAt(++state.position);\n    _position = state.position;\n\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    directiveName = state.input.slice(_position, state.position);\n    directiveArgs = [];\n\n    if (directiveName.length < 1) {\n      throwError(state, 'directive name must not be less than one character in length');\n    }\n\n    while (0 !== ch) {\n      while (is_WHITE_SPACE(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      if (0x23/* # */ === ch) {\n        do { ch = state.input.charCodeAt(++state.position); }\n        while (0 !== ch && !is_EOL(ch));\n        break;\n      }\n\n      if (is_EOL(ch)) {\n        break;\n      }\n\n      _position = state.position;\n\n      while (0 !== ch && !is_WS_OR_EOL(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      directiveArgs.push(state.input.slice(_position, state.position));\n    }\n\n    if (0 !== ch) {\n      readLineBreak(state);\n    }\n\n    if (_hasOwnProperty.call(directiveHandlers, directiveName)) {\n      directiveHandlers[directiveName](state, directiveName, directiveArgs);\n    } else {\n      throwWarning(state, 'unknown document directive \"' + directiveName + '\"');\n    }\n  }\n\n  skipSeparationSpace(state, true, -1);\n\n  if (0 === state.lineIndent &&\n      0x2D/* - */ === state.input.charCodeAt(state.position) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 1) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 2)) {\n    state.position += 3;\n    skipSeparationSpace(state, true, -1);\n\n  } else if (hasDirectives) {\n    throwError(state, 'directives end mark is expected');\n  }\n\n  composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true);\n  skipSeparationSpace(state, true, -1);\n\n  if (state.checkLineBreaks &&\n      PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) {\n    throwWarning(state, 'non-ASCII line breaks are interpreted as content');\n  }\n\n  state.documents.push(state.result);\n\n  if (state.position === state.lineStart && testDocumentSeparator(state)) {\n\n    if (0x2E/* . */ === state.input.charCodeAt(state.position)) {\n      state.position += 3;\n      skipSeparationSpace(state, true, -1);\n    }\n    return;\n  }\n\n  if (state.position < (state.length - 1)) {\n    throwError(state, 'end of the stream or a document separator is expected');\n  } else {\n    return;\n  }\n}\n\n\nfunction loadDocuments(input, options) {\n  input = String(input);\n  options = options || {};\n\n  if (input.length !== 0) {\n\n    // Add tailing `\\n` if not exists\n    if (0x0A/* LF */ !== input.charCodeAt(input.length - 1) &&\n        0x0D/* CR */ !== input.charCodeAt(input.length - 1)) {\n      input += '\\n';\n    }\n\n    // Strip BOM\n    if (input.charCodeAt(0) === 0xFEFF) {\n      input = input.slice(1);\n    }\n  }\n\n  var state = new State(input, options);\n\n  if (PATTERN_NON_PRINTABLE.test(state.input)) {\n    throwError(state, 'the stream contains non-printable characters');\n  }\n\n  // Use 0 as string terminator. That significantly simplifies bounds check.\n  state.input += '\\0';\n\n  while (0x20/* Space */ === state.input.charCodeAt(state.position)) {\n    state.lineIndent += 1;\n    state.position += 1;\n  }\n\n  while (state.position < (state.length - 1)) {\n    readDocument(state);\n  }\n\n  return state.documents;\n}\n\n\nfunction loadAll(input, iterator, options) {\n  var documents = loadDocuments(input, options), index, length;\n\n  for (index = 0, length = documents.length; index < length; index += 1) {\n    iterator(documents[index]);\n  }\n}\n\n\nfunction load(input, options) {\n  var documents = loadDocuments(input, options), index, length;\n\n  if (0 === documents.length) {\n    /*eslint-disable no-undefined*/\n    return undefined;\n  } else if (1 === documents.length) {\n    return documents[0];\n  }\n  throw new YAMLException('expected a single document in the stream, but found more');\n}\n\n\nfunction safeLoadAll(input, output, options) {\n  loadAll(input, output, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nfunction safeLoad(input, options) {\n  return load(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nmodule.exports.loadAll     = loadAll;\nmodule.exports.load        = load;\nmodule.exports.safeLoadAll = safeLoadAll;\nmodule.exports.safeLoad    = safeLoad;\n","'use strict';\n\n\nvar common = require('./common');\n\n\nfunction Mark(name, buffer, position, line, column) {\n  this.name     = name;\n  this.buffer   = buffer;\n  this.position = position;\n  this.line     = line;\n  this.column   = column;\n}\n\n\nMark.prototype.getSnippet = function getSnippet(indent, maxLength) {\n  var head, start, tail, end, snippet;\n\n  if (!this.buffer) {\n    return null;\n  }\n\n  indent = indent || 4;\n  maxLength = maxLength || 75;\n\n  head = '';\n  start = this.position;\n\n  while (start > 0 && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(start - 1))) {\n    start -= 1;\n    if (this.position - start > (maxLength / 2 - 1)) {\n      head = ' ... ';\n      start += 5;\n      break;\n    }\n  }\n\n  tail = '';\n  end = this.position;\n\n  while (end < this.buffer.length && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(end))) {\n    end += 1;\n    if (end - this.position > (maxLength / 2 - 1)) {\n      tail = ' ... ';\n      end -= 5;\n      break;\n    }\n  }\n\n  snippet = this.buffer.slice(start, end);\n\n  return common.repeat(' ', indent) + head + snippet + tail + '\\n' +\n         common.repeat(' ', indent + this.position - start + head.length) + '^';\n};\n\n\nMark.prototype.toString = function toString(compact) {\n  var snippet, where = '';\n\n  if (this.name) {\n    where += 'in \"' + this.name + '\" ';\n  }\n\n  where += 'at line ' + (this.line + 1) + ', column ' + (this.column + 1);\n\n  if (!compact) {\n    snippet = this.getSnippet();\n\n    if (snippet) {\n      where += ':\\n' + snippet;\n    }\n  }\n\n  return where;\n};\n\n\nmodule.exports = Mark;\n","'use strict';\n\n/*eslint-disable max-len*/\n\nvar common        = require('./common');\nvar YAMLException = require('./exception');\nvar Type          = require('./type');\n\n\nfunction compileList(schema, name, result) {\n  var exclude = [];\n\n  schema.include.forEach(function (includedSchema) {\n    result = compileList(includedSchema, name, result);\n  });\n\n  schema[name].forEach(function (currentType) {\n    result.forEach(function (previousType, previousIndex) {\n      if (previousType.tag === currentType.tag) {\n        exclude.push(previousIndex);\n      }\n    });\n\n    result.push(currentType);\n  });\n\n  return result.filter(function (type, index) {\n    return -1 === exclude.indexOf(index);\n  });\n}\n\n\nfunction compileMap(/* lists... */) {\n  var result = {}, index, length;\n\n  function collectType(type) {\n    result[type.tag] = type;\n  }\n\n  for (index = 0, length = arguments.length; index < length; index += 1) {\n    arguments[index].forEach(collectType);\n  }\n\n  return result;\n}\n\n\nfunction Schema(definition) {\n  this.include  = definition.include  || [];\n  this.implicit = definition.implicit || [];\n  this.explicit = definition.explicit || [];\n\n  this.implicit.forEach(function (type) {\n    if (type.loadKind && 'scalar' !== type.loadKind) {\n      throw new YAMLException('There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.');\n    }\n  });\n\n  this.compiledImplicit = compileList(this, 'implicit', []);\n  this.compiledExplicit = compileList(this, 'explicit', []);\n  this.compiledTypeMap  = compileMap(this.compiledImplicit, this.compiledExplicit);\n}\n\n\nSchema.DEFAULT = null;\n\n\nSchema.create = function createSchema() {\n  var schemas, types;\n\n  switch (arguments.length) {\n  case 1:\n    schemas = Schema.DEFAULT;\n    types = arguments[0];\n    break;\n\n  case 2:\n    schemas = arguments[0];\n    types = arguments[1];\n    break;\n\n  default:\n    throw new YAMLException('Wrong number of arguments for Schema.create function');\n  }\n\n  schemas = common.toArray(schemas);\n  types = common.toArray(types);\n\n  if (!schemas.every(function (schema) { return schema instanceof Schema; })) {\n    throw new YAMLException('Specified list of super schemas (or a single Schema object) contains a non-Schema object.');\n  }\n\n  if (!types.every(function (type) { return type instanceof Type; })) {\n    throw new YAMLException('Specified list of YAML types (or a single Type object) contains a non-Type object.');\n  }\n\n  return new Schema({\n    include: schemas,\n    explicit: types\n  });\n};\n\n\nmodule.exports = Schema;\n","// Standard YAML's Core schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2804923\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, Core schema has no distinctions from JSON schema is JS-YAML.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./json')\n  ]\n});\n","// JS-YAML's default schema for `load` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on JS-YAML's default safe schema and includes\n// JavaScript-specific types: !!js/undefined, !!js/regexp and !!js/function.\n//\n// Also this schema is used as default base schema at `Schema.create` function.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = Schema.DEFAULT = new Schema({\n  include: [\n    require('./default_safe')\n  ],\n  explicit: [\n    require('../type/js/undefined'),\n    require('../type/js/regexp'),\n    require('../type/js/function')\n  ]\n});\n","// JS-YAML's default schema for `safeLoad` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on standard YAML's Core schema and includes most of\n// extra types described at YAML tag repository. (http://yaml.org/type/)\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./core')\n  ],\n  implicit: [\n    require('../type/timestamp'),\n    require('../type/merge')\n  ],\n  explicit: [\n    require('../type/binary'),\n    require('../type/omap'),\n    require('../type/pairs'),\n    require('../type/set')\n  ]\n});\n","// Standard YAML's Failsafe schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2802346\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  explicit: [\n    require('../type/str'),\n    require('../type/seq'),\n    require('../type/map')\n  ]\n});\n","// Standard YAML's JSON schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2803231\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, this schema is not such strict as defined in the YAML specification.\n// It allows numbers in binary notaion, use `Null` and `NULL` as `null`, etc.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./failsafe')\n  ],\n  implicit: [\n    require('../type/null'),\n    require('../type/bool'),\n    require('../type/int'),\n    require('../type/float')\n  ]\n});\n","'use strict';\n\nvar YAMLException = require('./exception');\n\nvar TYPE_CONSTRUCTOR_OPTIONS = [\n  'kind',\n  'resolve',\n  'construct',\n  'instanceOf',\n  'predicate',\n  'represent',\n  'defaultStyle',\n  'styleAliases'\n];\n\nvar YAML_NODE_KINDS = [\n  'scalar',\n  'sequence',\n  'mapping'\n];\n\nfunction compileStyleAliases(map) {\n  var result = {};\n\n  if (null !== map) {\n    Object.keys(map).forEach(function (style) {\n      map[style].forEach(function (alias) {\n        result[String(alias)] = style;\n      });\n    });\n  }\n\n  return result;\n}\n\nfunction Type(tag, options) {\n  options = options || {};\n\n  Object.keys(options).forEach(function (name) {\n    if (-1 === TYPE_CONSTRUCTOR_OPTIONS.indexOf(name)) {\n      throw new YAMLException('Unknown option \"' + name + '\" is met in definition of \"' + tag + '\" YAML type.');\n    }\n  });\n\n  // TODO: Add tag format check.\n  this.tag          = tag;\n  this.kind         = options['kind']         || null;\n  this.resolve      = options['resolve']      || function () { return true; };\n  this.construct    = options['construct']    || function (data) { return data; };\n  this.instanceOf   = options['instanceOf']   || null;\n  this.predicate    = options['predicate']    || null;\n  this.represent    = options['represent']    || null;\n  this.defaultStyle = options['defaultStyle'] || null;\n  this.styleAliases = compileStyleAliases(options['styleAliases'] || null);\n\n  if (-1 === YAML_NODE_KINDS.indexOf(this.kind)) {\n    throw new YAMLException('Unknown kind \"' + this.kind + '\" is specified for \"' + tag + '\" YAML type.');\n  }\n}\n\nmodule.exports = Type;\n","'use strict';\n\n/*eslint-disable no-bitwise*/\n\n// A trick for browserified version.\n// Since we make browserifier to ignore `buffer` module, NodeBuffer will be undefined\nvar NodeBuffer = require('buffer').Buffer;\nvar Type       = require('../type');\n\n\n// [ 64, 65, 66 ] -> [ padding, CR, LF ]\nvar BASE64_MAP = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\\n\\r';\n\n\nfunction resolveYamlBinary(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var code, idx, bitlen = 0, len = 0, max = data.length, map = BASE64_MAP;\n\n  // Convert one by one.\n  for (idx = 0; idx < max; idx++) {\n    code = map.indexOf(data.charAt(idx));\n\n    // Skip CR/LF\n    if (code > 64) { continue; }\n\n    // Fail on illegal characters\n    if (code < 0) { return false; }\n\n    bitlen += 6;\n  }\n\n  // If there are any bits left, source was corrupted\n  return (bitlen % 8) === 0;\n}\n\nfunction constructYamlBinary(data) {\n  var code, idx, tailbits,\n      input = data.replace(/[\\r\\n=]/g, ''), // remove CR/LF & padding to simplify scan\n      max = input.length,\n      map = BASE64_MAP,\n      bits = 0,\n      result = [];\n\n  // Collect by 6*4 bits (3 bytes)\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 4 === 0) && idx) {\n      result.push((bits >> 16) & 0xFF);\n      result.push((bits >> 8) & 0xFF);\n      result.push(bits & 0xFF);\n    }\n\n    bits = (bits << 6) | map.indexOf(input.charAt(idx));\n  }\n\n  // Dump tail\n\n  tailbits = (max % 4) * 6;\n\n  if (tailbits === 0) {\n    result.push((bits >> 16) & 0xFF);\n    result.push((bits >> 8) & 0xFF);\n    result.push(bits & 0xFF);\n  } else if (tailbits === 18) {\n    result.push((bits >> 10) & 0xFF);\n    result.push((bits >> 2) & 0xFF);\n  } else if (tailbits === 12) {\n    result.push((bits >> 4) & 0xFF);\n  }\n\n  // Wrap into Buffer for NodeJS and leave Array for browser\n  if (NodeBuffer) {\n    return new NodeBuffer(result);\n  }\n\n  return result;\n}\n\nfunction representYamlBinary(object /*, style*/) {\n  var result = '', bits = 0, idx, tail,\n      max = object.length,\n      map = BASE64_MAP;\n\n  // Convert every three bytes to 4 ASCII characters.\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 3 === 0) && idx) {\n      result += map[(bits >> 18) & 0x3F];\n      result += map[(bits >> 12) & 0x3F];\n      result += map[(bits >> 6) & 0x3F];\n      result += map[bits & 0x3F];\n    }\n\n    bits = (bits << 8) + object[idx];\n  }\n\n  // Dump tail\n\n  tail = max % 3;\n\n  if (tail === 0) {\n    result += map[(bits >> 18) & 0x3F];\n    result += map[(bits >> 12) & 0x3F];\n    result += map[(bits >> 6) & 0x3F];\n    result += map[bits & 0x3F];\n  } else if (tail === 2) {\n    result += map[(bits >> 10) & 0x3F];\n    result += map[(bits >> 4) & 0x3F];\n    result += map[(bits << 2) & 0x3F];\n    result += map[64];\n  } else if (tail === 1) {\n    result += map[(bits >> 2) & 0x3F];\n    result += map[(bits << 4) & 0x3F];\n    result += map[64];\n    result += map[64];\n  }\n\n  return result;\n}\n\nfunction isBinary(object) {\n  return NodeBuffer && NodeBuffer.isBuffer(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:binary', {\n  kind: 'scalar',\n  resolve: resolveYamlBinary,\n  construct: constructYamlBinary,\n  predicate: isBinary,\n  represent: representYamlBinary\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlBoolean(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length;\n\n  return (max === 4 && (data === 'true' || data === 'True' || data === 'TRUE')) ||\n         (max === 5 && (data === 'false' || data === 'False' || data === 'FALSE'));\n}\n\nfunction constructYamlBoolean(data) {\n  return data === 'true' ||\n         data === 'True' ||\n         data === 'TRUE';\n}\n\nfunction isBoolean(object) {\n  return '[object Boolean]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:bool', {\n  kind: 'scalar',\n  resolve: resolveYamlBoolean,\n  construct: constructYamlBoolean,\n  predicate: isBoolean,\n  represent: {\n    lowercase: function (object) { return object ? 'true' : 'false'; },\n    uppercase: function (object) { return object ? 'TRUE' : 'FALSE'; },\n    camelcase: function (object) { return object ? 'True' : 'False'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nvar YAML_FLOAT_PATTERN = new RegExp(\n  '^(?:[-+]?(?:[0-9][0-9_]*)\\\\.[0-9_]*(?:[eE][-+][0-9]+)?' +\n  '|\\\\.[0-9_]+(?:[eE][-+][0-9]+)?' +\n  '|[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+\\\\.[0-9_]*' +\n  '|[-+]?\\\\.(?:inf|Inf|INF)' +\n  '|\\\\.(?:nan|NaN|NAN))$');\n\nfunction resolveYamlFloat(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var value, sign, base, digits;\n\n  if (!YAML_FLOAT_PATTERN.test(data)) {\n    return false;\n  }\n  return true;\n}\n\nfunction constructYamlFloat(data) {\n  var value, sign, base, digits;\n\n  value  = data.replace(/_/g, '').toLowerCase();\n  sign   = '-' === value[0] ? -1 : 1;\n  digits = [];\n\n  if (0 <= '+-'.indexOf(value[0])) {\n    value = value.slice(1);\n  }\n\n  if ('.inf' === value) {\n    return (1 === sign) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n  } else if ('.nan' === value) {\n    return NaN;\n\n  } else if (0 <= value.indexOf(':')) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseFloat(v, 10));\n    });\n\n    value = 0.0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += d * base;\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n  return sign * parseFloat(value, 10);\n}\n\nfunction representYamlFloat(object, style) {\n  if (isNaN(object)) {\n    switch (style) {\n    case 'lowercase':\n      return '.nan';\n    case 'uppercase':\n      return '.NAN';\n    case 'camelcase':\n      return '.NaN';\n    }\n  } else if (Number.POSITIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '.inf';\n    case 'uppercase':\n      return '.INF';\n    case 'camelcase':\n      return '.Inf';\n    }\n  } else if (Number.NEGATIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '-.inf';\n    case 'uppercase':\n      return '-.INF';\n    case 'camelcase':\n      return '-.Inf';\n    }\n  } else if (common.isNegativeZero(object)) {\n    return '-0.0';\n  }\n  return object.toString(10);\n}\n\nfunction isFloat(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 !== object % 1 || common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:float', {\n  kind: 'scalar',\n  resolve: resolveYamlFloat,\n  construct: constructYamlFloat,\n  predicate: isFloat,\n  represent: representYamlFloat,\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nfunction isHexCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||\n         ((0x41/* A */ <= c) && (c <= 0x46/* F */)) ||\n         ((0x61/* a */ <= c) && (c <= 0x66/* f */));\n}\n\nfunction isOctCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x37/* 7 */));\n}\n\nfunction isDecCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */));\n}\n\nfunction resolveYamlInteger(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length,\n      index = 0,\n      hasDigits = false,\n      ch;\n\n  if (!max) { return false; }\n\n  ch = data[index];\n\n  // sign\n  if (ch === '-' || ch === '+') {\n    ch = data[++index];\n  }\n\n  if (ch === '0') {\n    // 0\n    if (index + 1 === max) { return true; }\n    ch = data[++index];\n\n    // base 2, base 8, base 16\n\n    if (ch === 'b') {\n      // base 2\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (ch !== '0' && ch !== '1') {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n\n    if (ch === 'x') {\n      // base 16\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (!isHexCode(data.charCodeAt(index))) {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n    // base 8\n    for (; index < max; index++) {\n      ch = data[index];\n      if (ch === '_') { continue; }\n      if (!isOctCode(data.charCodeAt(index))) {\n        return false;\n      }\n      hasDigits = true;\n    }\n    return hasDigits;\n  }\n\n  // base 10 (except 0) or base 60\n\n  for (; index < max; index++) {\n    ch = data[index];\n    if (ch === '_') { continue; }\n    if (ch === ':') { break; }\n    if (!isDecCode(data.charCodeAt(index))) {\n      return false;\n    }\n    hasDigits = true;\n  }\n\n  if (!hasDigits) { return false; }\n\n  // if !base60 - done;\n  if (ch !== ':') { return true; }\n\n  // base60 almost not used, no needs to optimize\n  return /^(:[0-5]?[0-9])+$/.test(data.slice(index));\n}\n\nfunction constructYamlInteger(data) {\n  var value = data, sign = 1, ch, base, digits = [];\n\n  if (value.indexOf('_') !== -1) {\n    value = value.replace(/_/g, '');\n  }\n\n  ch = value[0];\n\n  if (ch === '-' || ch === '+') {\n    if (ch === '-') { sign = -1; }\n    value = value.slice(1);\n    ch = value[0];\n  }\n\n  if ('0' === value) {\n    return 0;\n  }\n\n  if (ch === '0') {\n    if (value[1] === 'b') {\n      return sign * parseInt(value.slice(2), 2);\n    }\n    if (value[1] === 'x') {\n      return sign * parseInt(value, 16);\n    }\n    return sign * parseInt(value, 8);\n\n  }\n\n  if (value.indexOf(':') !== -1) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseInt(v, 10));\n    });\n\n    value = 0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += (d * base);\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n\n  return sign * parseInt(value, 10);\n}\n\nfunction isInteger(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 === object % 1 && !common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:int', {\n  kind: 'scalar',\n  resolve: resolveYamlInteger,\n  construct: constructYamlInteger,\n  predicate: isInteger,\n  represent: {\n    binary:      function (object) { return '0b' + object.toString(2); },\n    octal:       function (object) { return '0'  + object.toString(8); },\n    decimal:     function (object) { return        object.toString(10); },\n    hexadecimal: function (object) { return '0x' + object.toString(16).toUpperCase(); }\n  },\n  defaultStyle: 'decimal',\n  styleAliases: {\n    binary:      [ 2,  'bin' ],\n    octal:       [ 8,  'oct' ],\n    decimal:     [ 10, 'dec' ],\n    hexadecimal: [ 16, 'hex' ]\n  }\n});\n","'use strict';\n\nvar esprima;\n\n// Browserified version does not have esprima\n//\n// 1. For node.js just require module as deps\n// 2. For browser try to require mudule via external AMD system.\n//    If not found - try to fallback to window.esprima. If not\n//    found too - then fail to parse.\n//\ntry {\n  esprima = require('esprima');\n} catch (_) {\n  /*global window */\n  if (typeof window !== 'undefined') { esprima = window.esprima; }\n}\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptFunction(data) {\n  if (null === data) {\n    return false;\n  }\n\n  try {\n    var source = '(' + data + ')',\n        ast    = esprima.parse(source, { range: true }),\n        params = [],\n        body;\n\n    if ('Program'             !== ast.type         ||\n        1                     !== ast.body.length  ||\n        'ExpressionStatement' !== ast.body[0].type ||\n        'FunctionExpression'  !== ast.body[0].expression.type) {\n      return false;\n    }\n\n    return true;\n  } catch (err) {\n    return false;\n  }\n}\n\nfunction constructJavascriptFunction(data) {\n  /*jslint evil:true*/\n\n  var source = '(' + data + ')',\n      ast    = esprima.parse(source, { range: true }),\n      params = [],\n      body;\n\n  if ('Program'             !== ast.type         ||\n      1                     !== ast.body.length  ||\n      'ExpressionStatement' !== ast.body[0].type ||\n      'FunctionExpression'  !== ast.body[0].expression.type) {\n    throw new Error('Failed to resolve function');\n  }\n\n  ast.body[0].expression.params.forEach(function (param) {\n    params.push(param.name);\n  });\n\n  body = ast.body[0].expression.body.range;\n\n  // Esprima's ranges include the first '{' and the last '}' characters on\n  // function expressions. So cut them out.\n  /*eslint-disable no-new-func*/\n  return new Function(params, source.slice(body[0] + 1, body[1] - 1));\n}\n\nfunction representJavascriptFunction(object /*, style*/) {\n  return object.toString();\n}\n\nfunction isFunction(object) {\n  return '[object Function]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/function', {\n  kind: 'scalar',\n  resolve: resolveJavascriptFunction,\n  construct: constructJavascriptFunction,\n  predicate: isFunction,\n  represent: representJavascriptFunction\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptRegExp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  if (0 === data.length) {\n    return false;\n  }\n\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // if regexp starts with '/' it can have modifiers and must be properly closed\n  // `/foo/gim` - modifiers tail can be maximum 3 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n\n    if (modifiers.length > 3) { return false; }\n    // if expression starts with /, is should be properly terminated\n    if (regexp[regexp.length - modifiers.length - 1] !== '/') { return false; }\n\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  try {\n    var dummy = new RegExp(regexp, modifiers);\n    return true;\n  } catch (error) {\n    return false;\n  }\n}\n\nfunction constructJavascriptRegExp(data) {\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // `/foo/gim` - tail can be maximum 4 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  return new RegExp(regexp, modifiers);\n}\n\nfunction representJavascriptRegExp(object /*, style*/) {\n  var result = '/' + object.source + '/';\n\n  if (object.global) {\n    result += 'g';\n  }\n\n  if (object.multiline) {\n    result += 'm';\n  }\n\n  if (object.ignoreCase) {\n    result += 'i';\n  }\n\n  return result;\n}\n\nfunction isRegExp(object) {\n  return '[object RegExp]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/regexp', {\n  kind: 'scalar',\n  resolve: resolveJavascriptRegExp,\n  construct: constructJavascriptRegExp,\n  predicate: isRegExp,\n  represent: representJavascriptRegExp\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptUndefined() {\n  return true;\n}\n\nfunction constructJavascriptUndefined() {\n  /*eslint-disable no-undefined*/\n  return undefined;\n}\n\nfunction representJavascriptUndefined() {\n  return '';\n}\n\nfunction isUndefined(object) {\n  return 'undefined' === typeof object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/undefined', {\n  kind: 'scalar',\n  resolve: resolveJavascriptUndefined,\n  construct: constructJavascriptUndefined,\n  predicate: isUndefined,\n  represent: representJavascriptUndefined\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:map', {\n  kind: 'mapping',\n  construct: function (data) { return null !== data ? data : {}; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlMerge(data) {\n  return '<<' === data || null === data;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:merge', {\n  kind: 'scalar',\n  resolve: resolveYamlMerge\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlNull(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var max = data.length;\n\n  return (max === 1 && data === '~') ||\n         (max === 4 && (data === 'null' || data === 'Null' || data === 'NULL'));\n}\n\nfunction constructYamlNull() {\n  return null;\n}\n\nfunction isNull(object) {\n  return null === object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:null', {\n  kind: 'scalar',\n  resolve: resolveYamlNull,\n  construct: constructYamlNull,\n  predicate: isNull,\n  represent: {\n    canonical: function () { return '~';    },\n    lowercase: function () { return 'null'; },\n    uppercase: function () { return 'NULL'; },\n    camelcase: function () { return 'Null'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\nvar _toString       = Object.prototype.toString;\n\nfunction resolveYamlOmap(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var objectKeys = [], index, length, pair, pairKey, pairHasKey,\n      object = data;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n    pairHasKey = false;\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    for (pairKey in pair) {\n      if (_hasOwnProperty.call(pair, pairKey)) {\n        if (!pairHasKey) {\n          pairHasKey = true;\n        } else {\n          return false;\n        }\n      }\n    }\n\n    if (!pairHasKey) {\n      return false;\n    }\n\n    if (-1 === objectKeys.indexOf(pairKey)) {\n      objectKeys.push(pairKey);\n    } else {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlOmap(data) {\n  return null !== data ? data : [];\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:omap', {\n  kind: 'sequence',\n  resolve: resolveYamlOmap,\n  construct: constructYamlOmap\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _toString = Object.prototype.toString;\n\nfunction resolveYamlPairs(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    keys = Object.keys(pair);\n\n    if (1 !== keys.length) {\n      return false;\n    }\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return true;\n}\n\nfunction constructYamlPairs(data) {\n  if (null === data) {\n    return [];\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    keys = Object.keys(pair);\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return result;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:pairs', {\n  kind: 'sequence',\n  resolve: resolveYamlPairs,\n  construct: constructYamlPairs\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:seq', {\n  kind: 'sequence',\n  construct: function (data) { return null !== data ? data : []; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var key, object = data;\n\n  for (key in object) {\n    if (_hasOwnProperty.call(object, key)) {\n      if (null !== object[key]) {\n        return false;\n      }\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlSet(data) {\n  return null !== data ? data : {};\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:set', {\n  kind: 'mapping',\n  resolve: resolveYamlSet,\n  construct: constructYamlSet\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:str', {\n  kind: 'scalar',\n  construct: function (data) { return null !== data ? data : ''; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar YAML_TIMESTAMP_REGEXP = new RegExp(\n  '^([0-9][0-9][0-9][0-9])'          + // [1] year\n  '-([0-9][0-9]?)'                   + // [2] month\n  '-([0-9][0-9]?)'                   + // [3] day\n  '(?:(?:[Tt]|[ \\\\t]+)'              + // ...\n  '([0-9][0-9]?)'                    + // [4] hour\n  ':([0-9][0-9])'                    + // [5] minute\n  ':([0-9][0-9])'                    + // [6] second\n  '(?:\\\\.([0-9]*))?'                 + // [7] fraction\n  '(?:[ \\\\t]*(Z|([-+])([0-9][0-9]?)' + // [8] tz [9] tz_sign [10] tz_hour\n  '(?::([0-9][0-9]))?))?)?$');         // [11] tz_minute\n\nfunction resolveYamlTimestamp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var match, year, month, day, hour, minute, second, fraction = 0,\n      delta = null, tz_hour, tz_minute, date;\n\n  match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n  if (null === match) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction constructYamlTimestamp(data) {\n  var match, year, month, day, hour, minute, second, fraction = 0,\n      delta = null, tz_hour, tz_minute, date;\n\n  match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n  if (null === match) {\n    throw new Error('Date resolve error');\n  }\n\n  // match: [1] year [2] month [3] day\n\n  year = +(match[1]);\n  month = +(match[2]) - 1; // JS month starts with 0\n  day = +(match[3]);\n\n  if (!match[4]) { // no hour\n    return new Date(Date.UTC(year, month, day));\n  }\n\n  // match: [4] hour [5] minute [6] second [7] fraction\n\n  hour = +(match[4]);\n  minute = +(match[5]);\n  second = +(match[6]);\n\n  if (match[7]) {\n    fraction = match[7].slice(0, 3);\n    while (fraction.length < 3) { // milli-seconds\n      fraction += '0';\n    }\n    fraction = +fraction;\n  }\n\n  // match: [8] tz [9] tz_sign [10] tz_hour [11] tz_minute\n\n  if (match[9]) {\n    tz_hour = +(match[10]);\n    tz_minute = +(match[11] || 0);\n    delta = (tz_hour * 60 + tz_minute) * 60000; // delta in mili-seconds\n    if ('-' === match[9]) {\n      delta = -delta;\n    }\n  }\n\n  date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n  if (delta) {\n    date.setTime(date.getTime() - delta);\n  }\n\n  return date;\n}\n\nfunction representYamlTimestamp(object /*, style*/) {\n  return object.toISOString();\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:timestamp', {\n  kind: 'scalar',\n  resolve: resolveYamlTimestamp,\n  construct: constructYamlTimestamp,\n  instanceOf: Date,\n  represent: representYamlTimestamp\n});\n","/*\n  Copyright (C) 2013 Ariya Hidayat <ariya.hidayat@gmail.com>\n  Copyright (C) 2013 Thaddee Tyl <thaddee.tyl@gmail.com>\n  Copyright (C) 2013 Mathias Bynens <mathias@qiwi.be>\n  Copyright (C) 2012 Ariya Hidayat <ariya.hidayat@gmail.com>\n  Copyright (C) 2012 Mathias Bynens <mathias@qiwi.be>\n  Copyright (C) 2012 Joost-Wim Boekesteijn <joost-wim@boekesteijn.nl>\n  Copyright (C) 2012 Kris Kowal <kris.kowal@cixar.com>\n  Copyright (C) 2012 Yusuke Suzuki <utatane.tea@gmail.com>\n  Copyright (C) 2012 Arpad Borsos <arpad.borsos@googlemail.com>\n  Copyright (C) 2011 Ariya Hidayat <ariya.hidayat@gmail.com>\n\n  Redistribution and use in source and binary forms, with or without\n  modification, are permitted provided that the following conditions are met:\n\n    * Redistributions of source code must retain the above copyright\n      notice, this list of conditions and the following disclaimer.\n    * Redistributions in binary form must reproduce the above copyright\n      notice, this list of conditions and the following disclaimer in the\n      documentation and/or other materials provided with the distribution.\n\n  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n  ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY\n  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND\n  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF\n  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n(function (root, factory) {\n    'use strict';\n\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js,\n    // Rhino, and plain browser loading.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define(['exports'], factory);\n    } else if (typeof exports !== 'undefined') {\n        factory(exports);\n    } else {\n        factory((root.esprima = {}));\n    }\n}(this, function (exports) {\n    'use strict';\n\n    var Token,\n        TokenName,\n        FnExprTokens,\n        Syntax,\n        PlaceHolders,\n        Messages,\n        Regex,\n        source,\n        strict,\n        sourceType,\n        index,\n        lineNumber,\n        lineStart,\n        hasLineTerminator,\n        lastIndex,\n        lastLineNumber,\n        lastLineStart,\n        startIndex,\n        startLineNumber,\n        startLineStart,\n        scanning,\n        length,\n        lookahead,\n        state,\n        extra,\n        isBindingElement,\n        isAssignmentTarget,\n        firstCoverInitializedNameError;\n\n    Token = {\n        BooleanLiteral: 1,\n        EOF: 2,\n        Identifier: 3,\n        Keyword: 4,\n        NullLiteral: 5,\n        NumericLiteral: 6,\n        Punctuator: 7,\n        StringLiteral: 8,\n        RegularExpression: 9,\n        Template: 10\n    };\n\n    TokenName = {};\n    TokenName[Token.BooleanLiteral] = 'Boolean';\n    TokenName[Token.EOF] = '<end>';\n    TokenName[Token.Identifier] = 'Identifier';\n    TokenName[Token.Keyword] = 'Keyword';\n    TokenName[Token.NullLiteral] = 'Null';\n    TokenName[Token.NumericLiteral] = 'Numeric';\n    TokenName[Token.Punctuator] = 'Punctuator';\n    TokenName[Token.StringLiteral] = 'String';\n    TokenName[Token.RegularExpression] = 'RegularExpression';\n    TokenName[Token.Template] = 'Template';\n\n    // A function following one of those tokens is an expression.\n    FnExprTokens = ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new',\n                    'return', 'case', 'delete', 'throw', 'void',\n                    // assignment operators\n                    '=', '+=', '-=', '*=', '/=', '%=', '<<=', '>>=', '>>>=',\n                    '&=', '|=', '^=', ',',\n                    // binary/unary operators\n                    '+', '-', '*', '/', '%', '++', '--', '<<', '>>', '>>>', '&',\n                    '|', '^', '!', '~', '&&', '||', '?', ':', '===', '==', '>=',\n                    '<=', '<', '>', '!=', '!=='];\n\n    Syntax = {\n        AssignmentExpression: 'AssignmentExpression',\n        AssignmentPattern: 'AssignmentPattern',\n        ArrayExpression: 'ArrayExpression',\n        ArrayPattern: 'ArrayPattern',\n        ArrowFunctionExpression: 'ArrowFunctionExpression',\n        BlockStatement: 'BlockStatement',\n        BinaryExpression: 'BinaryExpression',\n        BreakStatement: 'BreakStatement',\n        CallExpression: 'CallExpression',\n        CatchClause: 'CatchClause',\n        ClassBody: 'ClassBody',\n        ClassDeclaration: 'ClassDeclaration',\n        ClassExpression: 'ClassExpression',\n        ConditionalExpression: 'ConditionalExpression',\n        ContinueStatement: 'ContinueStatement',\n        DoWhileStatement: 'DoWhileStatement',\n        DebuggerStatement: 'DebuggerStatement',\n        EmptyStatement: 'EmptyStatement',\n        ExportAllDeclaration: 'ExportAllDeclaration',\n        ExportDefaultDeclaration: 'ExportDefaultDeclaration',\n        ExportNamedDeclaration: 'ExportNamedDeclaration',\n        ExportSpecifier: 'ExportSpecifier',\n        ExpressionStatement: 'ExpressionStatement',\n        ForStatement: 'ForStatement',\n        ForInStatement: 'ForInStatement',\n        FunctionDeclaration: 'FunctionDeclaration',\n        FunctionExpression: 'FunctionExpression',\n        Identifier: 'Identifier',\n        IfStatement: 'IfStatement',\n        ImportDeclaration: 'ImportDeclaration',\n        ImportDefaultSpecifier: 'ImportDefaultSpecifier',\n        ImportNamespaceSpecifier: 'ImportNamespaceSpecifier',\n        ImportSpecifier: 'ImportSpecifier',\n        Literal: 'Literal',\n        LabeledStatement: 'LabeledStatement',\n        LogicalExpression: 'LogicalExpression',\n        MemberExpression: 'MemberExpression',\n        MethodDefinition: 'MethodDefinition',\n        NewExpression: 'NewExpression',\n        ObjectExpression: 'ObjectExpression',\n        ObjectPattern: 'ObjectPattern',\n        Program: 'Program',\n        Property: 'Property',\n        RestElement: 'RestElement',\n        ReturnStatement: 'ReturnStatement',\n        SequenceExpression: 'SequenceExpression',\n        SpreadElement: 'SpreadElement',\n        Super: 'Super',\n        SwitchCase: 'SwitchCase',\n        SwitchStatement: 'SwitchStatement',\n        TaggedTemplateExpression: 'TaggedTemplateExpression',\n        TemplateElement: 'TemplateElement',\n        TemplateLiteral: 'TemplateLiteral',\n        ThisExpression: 'ThisExpression',\n        ThrowStatement: 'ThrowStatement',\n        TryStatement: 'TryStatement',\n        UnaryExpression: 'UnaryExpression',\n        UpdateExpression: 'UpdateExpression',\n        VariableDeclaration: 'VariableDeclaration',\n        VariableDeclarator: 'VariableDeclarator',\n        WhileStatement: 'WhileStatement',\n        WithStatement: 'WithStatement'\n    };\n\n    PlaceHolders = {\n        ArrowParameterPlaceHolder: 'ArrowParameterPlaceHolder'\n    };\n\n    // Error messages should be identical to V8.\n    Messages = {\n        UnexpectedToken: 'Unexpected token %0',\n        UnexpectedNumber: 'Unexpected number',\n        UnexpectedString: 'Unexpected string',\n        UnexpectedIdentifier: 'Unexpected identifier',\n        UnexpectedReserved: 'Unexpected reserved word',\n        UnexpectedTemplate: 'Unexpected quasi %0',\n        UnexpectedEOS: 'Unexpected end of input',\n        NewlineAfterThrow: 'Illegal newline after throw',\n        InvalidRegExp: 'Invalid regular expression',\n        UnterminatedRegExp: 'Invalid regular expression: missing /',\n        InvalidLHSInAssignment: 'Invalid left-hand side in assignment',\n        InvalidLHSInForIn: 'Invalid left-hand side in for-in',\n        MultipleDefaultsInSwitch: 'More than one default clause in switch statement',\n        NoCatchOrFinally: 'Missing catch or finally after try',\n        UnknownLabel: 'Undefined label \\'%0\\'',\n        Redeclaration: '%0 \\'%1\\' has already been declared',\n        IllegalContinue: 'Illegal continue statement',\n        IllegalBreak: 'Illegal break statement',\n        IllegalReturn: 'Illegal return statement',\n        StrictModeWith: 'Strict mode code may not include a with statement',\n        StrictCatchVariable: 'Catch variable may not be eval or arguments in strict mode',\n        StrictVarName: 'Variable name may not be eval or arguments in strict mode',\n        StrictParamName: 'Parameter name eval or arguments is not allowed in strict mode',\n        StrictParamDupe: 'Strict mode function may not have duplicate parameter names',\n        StrictFunctionName: 'Function name may not be eval or arguments in strict mode',\n        StrictOctalLiteral: 'Octal literals are not allowed in strict mode.',\n        StrictDelete: 'Delete of an unqualified identifier in strict mode.',\n        StrictLHSAssignment: 'Assignment to eval or arguments is not allowed in strict mode',\n        StrictLHSPostfix: 'Postfix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictLHSPrefix: 'Prefix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictReservedWord: 'Use of future reserved word in strict mode',\n        TemplateOctalLiteral: 'Octal literals are not allowed in template strings.',\n        ParameterAfterRestParameter: 'Rest parameter must be last formal parameter',\n        DefaultRestParameter: 'Unexpected token =',\n        ObjectPatternAsRestParameter: 'Unexpected token {',\n        DuplicateProtoProperty: 'Duplicate __proto__ fields are not allowed in object literals',\n        ConstructorSpecialMethod: 'Class constructor may not be an accessor',\n        DuplicateConstructor: 'A class may only have one constructor',\n        StaticPrototype: 'Classes may not have static property named prototype',\n        MissingFromClause: 'Unexpected token',\n        NoAsAfterImportNamespace: 'Unexpected token',\n        InvalidModuleSpecifier: 'Unexpected token',\n        IllegalImportDeclaration: 'Unexpected token',\n        IllegalExportDeclaration: 'Unexpected token'\n    };\n\n    // See also tools/generate-unicode-regex.py.\n    Regex = {\n        NonAsciiIdentifierStart: new RegExp('[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0370-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u07F4\\u07F5\\u07FA\\u0800-\\u0815\\u081A\\u0824\\u0828\\u0840-\\u0858\\u08A0-\\u08B2\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0971-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58\\u0C59\\u0C60\\u0C61\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D60\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E46\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17D7\\u17DC\\u1820-\\u1877\\u1880-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19C1-\\u19C7\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1AA7\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C7D\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u1D00-\\u1DBF\\u1E00-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u2071\\u207F\\u2090-\\u209C\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CEE\\u2CF2\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2E2F\\u3005-\\u3007\\u3021-\\u3029\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA61F\\uA62A\\uA62B\\uA640-\\uA66E\\uA67F-\\uA69D\\uA6A0-\\uA6EF\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9CF\\uA9E0-\\uA9E4\\uA9E6-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEA\\uAAF2-\\uAAF4\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF21-\\uFF3A\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]'),\n        NonAsciiIdentifierPart: new RegExp('[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0300-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u0483-\\u0487\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u0591-\\u05BD\\u05BF\\u05C1\\u05C2\\u05C4\\u05C5\\u05C7\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0610-\\u061A\\u0620-\\u0669\\u066E-\\u06D3\\u06D5-\\u06DC\\u06DF-\\u06E8\\u06EA-\\u06FC\\u06FF\\u0710-\\u074A\\u074D-\\u07B1\\u07C0-\\u07F5\\u07FA\\u0800-\\u082D\\u0840-\\u085B\\u08A0-\\u08B2\\u08E4-\\u0963\\u0966-\\u096F\\u0971-\\u0983\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BC-\\u09C4\\u09C7\\u09C8\\u09CB-\\u09CE\\u09D7\\u09DC\\u09DD\\u09DF-\\u09E3\\u09E6-\\u09F1\\u0A01-\\u0A03\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A3C\\u0A3E-\\u0A42\\u0A47\\u0A48\\u0A4B-\\u0A4D\\u0A51\\u0A59-\\u0A5C\\u0A5E\\u0A66-\\u0A75\\u0A81-\\u0A83\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABC-\\u0AC5\\u0AC7-\\u0AC9\\u0ACB-\\u0ACD\\u0AD0\\u0AE0-\\u0AE3\\u0AE6-\\u0AEF\\u0B01-\\u0B03\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3C-\\u0B44\\u0B47\\u0B48\\u0B4B-\\u0B4D\\u0B56\\u0B57\\u0B5C\\u0B5D\\u0B5F-\\u0B63\\u0B66-\\u0B6F\\u0B71\\u0B82\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BBE-\\u0BC2\\u0BC6-\\u0BC8\\u0BCA-\\u0BCD\\u0BD0\\u0BD7\\u0BE6-\\u0BEF\\u0C00-\\u0C03\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D-\\u0C44\\u0C46-\\u0C48\\u0C4A-\\u0C4D\\u0C55\\u0C56\\u0C58\\u0C59\\u0C60-\\u0C63\\u0C66-\\u0C6F\\u0C81-\\u0C83\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBC-\\u0CC4\\u0CC6-\\u0CC8\\u0CCA-\\u0CCD\\u0CD5\\u0CD6\\u0CDE\\u0CE0-\\u0CE3\\u0CE6-\\u0CEF\\u0CF1\\u0CF2\\u0D01-\\u0D03\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D-\\u0D44\\u0D46-\\u0D48\\u0D4A-\\u0D4E\\u0D57\\u0D60-\\u0D63\\u0D66-\\u0D6F\\u0D7A-\\u0D7F\\u0D82\\u0D83\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0DCA\\u0DCF-\\u0DD4\\u0DD6\\u0DD8-\\u0DDF\\u0DE6-\\u0DEF\\u0DF2\\u0DF3\\u0E01-\\u0E3A\\u0E40-\\u0E4E\\u0E50-\\u0E59\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB9\\u0EBB-\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EC8-\\u0ECD\\u0ED0-\\u0ED9\\u0EDC-\\u0EDF\\u0F00\\u0F18\\u0F19\\u0F20-\\u0F29\\u0F35\\u0F37\\u0F39\\u0F3E-\\u0F47\\u0F49-\\u0F6C\\u0F71-\\u0F84\\u0F86-\\u0F97\\u0F99-\\u0FBC\\u0FC6\\u1000-\\u1049\\u1050-\\u109D\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u135D-\\u135F\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1714\\u1720-\\u1734\\u1740-\\u1753\\u1760-\\u176C\\u176E-\\u1770\\u1772\\u1773\\u1780-\\u17D3\\u17D7\\u17DC\\u17DD\\u17E0-\\u17E9\\u180B-\\u180D\\u1810-\\u1819\\u1820-\\u1877\\u1880-\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1920-\\u192B\\u1930-\\u193B\\u1946-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u19D0-\\u19D9\\u1A00-\\u1A1B\\u1A20-\\u1A5E\\u1A60-\\u1A7C\\u1A7F-\\u1A89\\u1A90-\\u1A99\\u1AA7\\u1AB0-\\u1ABD\\u1B00-\\u1B4B\\u1B50-\\u1B59\\u1B6B-\\u1B73\\u1B80-\\u1BF3\\u1C00-\\u1C37\\u1C40-\\u1C49\\u1C4D-\\u1C7D\\u1CD0-\\u1CD2\\u1CD4-\\u1CF6\\u1CF8\\u1CF9\\u1D00-\\u1DF5\\u1DFC-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u200C\\u200D\\u203F\\u2040\\u2054\\u2071\\u207F\\u2090-\\u209C\\u20D0-\\u20DC\\u20E1\\u20E5-\\u20F0\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D7F-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2DE0-\\u2DFF\\u2E2F\\u3005-\\u3007\\u3021-\\u302F\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u3099\\u309A\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA62B\\uA640-\\uA66F\\uA674-\\uA67D\\uA67F-\\uA69D\\uA69F-\\uA6F1\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA827\\uA840-\\uA873\\uA880-\\uA8C4\\uA8D0-\\uA8D9\\uA8E0-\\uA8F7\\uA8FB\\uA900-\\uA92D\\uA930-\\uA953\\uA960-\\uA97C\\uA980-\\uA9C0\\uA9CF-\\uA9D9\\uA9E0-\\uA9FE\\uAA00-\\uAA36\\uAA40-\\uAA4D\\uAA50-\\uAA59\\uAA60-\\uAA76\\uAA7A-\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEF\\uAAF2-\\uAAF6\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABEA\\uABEC\\uABED\\uABF0-\\uABF9\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE00-\\uFE0F\\uFE20-\\uFE2D\\uFE33\\uFE34\\uFE4D-\\uFE4F\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF10-\\uFF19\\uFF21-\\uFF3A\\uFF3F\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]')\n    };\n\n    // Ensure the condition is true, otherwise throw an error.\n    // This is only to have a better contract semantic, i.e. another safety net\n    // to catch a logic error. The condition shall be fulfilled in normal case.\n    // Do NOT use this to enforce a certain condition on any user input.\n\n    function assert(condition, message) {\n        /* istanbul ignore if */\n        if (!condition) {\n            throw new Error('ASSERT: ' + message);\n        }\n    }\n\n    function isDecimalDigit(ch) {\n        return (ch >= 0x30 && ch <= 0x39);   // 0..9\n    }\n\n    function isHexDigit(ch) {\n        return '0123456789abcdefABCDEF'.indexOf(ch) >= 0;\n    }\n\n    function isOctalDigit(ch) {\n        return '01234567'.indexOf(ch) >= 0;\n    }\n\n    function octalToDecimal(ch) {\n        // \\0 is not octal escape sequence\n        var octal = (ch !== '0'), code = '01234567'.indexOf(ch);\n\n        if (index < length && isOctalDigit(source[index])) {\n            octal = true;\n            code = code * 8 + '01234567'.indexOf(source[index++]);\n\n            // 3 digits are only allowed when string starts\n            // with 0, 1, 2, 3\n            if ('0123'.indexOf(ch) >= 0 &&\n                    index < length &&\n                    isOctalDigit(source[index])) {\n                code = code * 8 + '01234567'.indexOf(source[index++]);\n            }\n        }\n\n        return {\n            code: code,\n            octal: octal\n        };\n    }\n\n    // 7.2 White Space\n\n    function isWhiteSpace(ch) {\n        return (ch === 0x20) || (ch === 0x09) || (ch === 0x0B) || (ch === 0x0C) || (ch === 0xA0) ||\n            (ch >= 0x1680 && [0x1680, 0x180E, 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, 0x202F, 0x205F, 0x3000, 0xFEFF].indexOf(ch) >= 0);\n    }\n\n    // 7.3 Line Terminators\n\n    function isLineTerminator(ch) {\n        return (ch === 0x0A) || (ch === 0x0D) || (ch === 0x2028) || (ch === 0x2029);\n    }\n\n    // 7.6 Identifier Names and Identifiers\n\n    function isIdentifierStart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierStart.test(String.fromCharCode(ch)));\n    }\n\n    function isIdentifierPart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch >= 0x30 && ch <= 0x39) ||         // 0..9\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierPart.test(String.fromCharCode(ch)));\n    }\n\n    // 7.6.1.2 Future Reserved Words\n\n    function isFutureReservedWord(id) {\n        switch (id) {\n        case 'enum':\n        case 'export':\n        case 'import':\n        case 'super':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    // 11.6.2.2 Future Reserved Words\n\n    function isStrictModeReservedWord(id) {\n        switch (id) {\n        case 'implements':\n        case 'interface':\n        case 'package':\n        case 'private':\n        case 'protected':\n        case 'public':\n        case 'static':\n        case 'yield':\n        case 'let':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    function isRestrictedWord(id) {\n        return id === 'eval' || id === 'arguments';\n    }\n\n    // 7.6.1.1 Keywords\n\n    function isKeyword(id) {\n\n        // 'const' is specialized as Keyword in V8.\n        // 'yield' and 'let' are for compatibility with SpiderMonkey and ES.next.\n        // Some others are from future reserved words.\n\n        switch (id.length) {\n        case 2:\n            return (id === 'if') || (id === 'in') || (id === 'do');\n        case 3:\n            return (id === 'var') || (id === 'for') || (id === 'new') ||\n                (id === 'try') || (id === 'let');\n        case 4:\n            return (id === 'this') || (id === 'else') || (id === 'case') ||\n                (id === 'void') || (id === 'with') || (id === 'enum');\n        case 5:\n            return (id === 'while') || (id === 'break') || (id === 'catch') ||\n                (id === 'throw') || (id === 'const') || (id === 'yield') ||\n                (id === 'class') || (id === 'super');\n        case 6:\n            return (id === 'return') || (id === 'typeof') || (id === 'delete') ||\n                (id === 'switch') || (id === 'export') || (id === 'import');\n        case 7:\n            return (id === 'default') || (id === 'finally') || (id === 'extends');\n        case 8:\n            return (id === 'function') || (id === 'continue') || (id === 'debugger');\n        case 10:\n            return (id === 'instanceof');\n        default:\n            return false;\n        }\n    }\n\n    // 7.4 Comments\n\n    function addComment(type, value, start, end, loc) {\n        var comment;\n\n        assert(typeof start === 'number', 'Comment must have valid position');\n\n        state.lastCommentStart = start;\n\n        comment = {\n            type: type,\n            value: value\n        };\n        if (extra.range) {\n            comment.range = [start, end];\n        }\n        if (extra.loc) {\n            comment.loc = loc;\n        }\n        extra.comments.push(comment);\n        if (extra.attachComment) {\n            extra.leadingComments.push(comment);\n            extra.trailingComments.push(comment);\n        }\n    }\n\n    function skipSingleLineComment(offset) {\n        var start, loc, ch, comment;\n\n        start = index - offset;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart - offset\n            }\n        };\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            ++index;\n            if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                if (extra.comments) {\n                    comment = source.slice(start + offset, index - 1);\n                    loc.end = {\n                        line: lineNumber,\n                        column: index - lineStart - 1\n                    };\n                    addComment('Line', comment, start, index - 1, loc);\n                }\n                if (ch === 13 && source.charCodeAt(index) === 10) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                return;\n            }\n        }\n\n        if (extra.comments) {\n            comment = source.slice(start + offset, index);\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            addComment('Line', comment, start, index, loc);\n        }\n    }\n\n    function skipMultiLineComment() {\n        var start, loc, ch, comment;\n\n        if (extra.comments) {\n            start = index - 2;\n            loc = {\n                start: {\n                    line: lineNumber,\n                    column: index - lineStart - 2\n                }\n            };\n        }\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (isLineTerminator(ch)) {\n                if (ch === 0x0D && source.charCodeAt(index + 1) === 0x0A) {\n                    ++index;\n                }\n                hasLineTerminator = true;\n                ++lineNumber;\n                ++index;\n                lineStart = index;\n            } else if (ch === 0x2A) {\n                // Block comment ends with '*/'.\n                if (source.charCodeAt(index + 1) === 0x2F) {\n                    ++index;\n                    ++index;\n                    if (extra.comments) {\n                        comment = source.slice(start + 2, index - 2);\n                        loc.end = {\n                            line: lineNumber,\n                            column: index - lineStart\n                        };\n                        addComment('Block', comment, start, index, loc);\n                    }\n                    return;\n                }\n                ++index;\n            } else {\n                ++index;\n            }\n        }\n\n        // Ran off the end of the file - the whole thing is a comment\n        if (extra.comments) {\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            comment = source.slice(start + 2, index);\n            addComment('Block', comment, start, index, loc);\n        }\n        tolerateUnexpectedToken();\n    }\n\n    function skipComment() {\n        var ch, start;\n        hasLineTerminator = false;\n\n        start = (index === 0);\n        while (index < length) {\n            ch = source.charCodeAt(index);\n\n            if (isWhiteSpace(ch)) {\n                ++index;\n            } else if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                ++index;\n                if (ch === 0x0D && source.charCodeAt(index) === 0x0A) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                start = true;\n            } else if (ch === 0x2F) { // U+002F is '/'\n                ch = source.charCodeAt(index + 1);\n                if (ch === 0x2F) {\n                    ++index;\n                    ++index;\n                    skipSingleLineComment(2);\n                    start = true;\n                } else if (ch === 0x2A) {  // U+002A is '*'\n                    ++index;\n                    ++index;\n                    skipMultiLineComment();\n                } else {\n                    break;\n                }\n            } else if (start && ch === 0x2D) { // U+002D is '-'\n                // U+003E is '>'\n                if ((source.charCodeAt(index + 1) === 0x2D) && (source.charCodeAt(index + 2) === 0x3E)) {\n                    // '-->' is a single-line comment\n                    index += 3;\n                    skipSingleLineComment(3);\n                } else {\n                    break;\n                }\n            } else if (ch === 0x3C) { // U+003C is '<'\n                if (source.slice(index + 1, index + 4) === '!--') {\n                    ++index; // `<`\n                    ++index; // `!`\n                    ++index; // `-`\n                    ++index; // `-`\n                    skipSingleLineComment(4);\n                } else {\n                    break;\n                }\n            } else {\n                break;\n            }\n        }\n    }\n\n    function scanHexEscape(prefix) {\n        var i, len, ch, code = 0;\n\n        len = (prefix === 'u') ? 4 : 2;\n        for (i = 0; i < len; ++i) {\n            if (index < length && isHexDigit(source[index])) {\n                ch = source[index++];\n                code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n            } else {\n                return '';\n            }\n        }\n        return String.fromCharCode(code);\n    }\n\n    function scanUnicodeCodePointEscape() {\n        var ch, code, cu1, cu2;\n\n        ch = source[index];\n        code = 0;\n\n        // At least, one hex digit is required.\n        if (ch === '}') {\n            throwUnexpectedToken();\n        }\n\n        while (index < length) {\n            ch = source[index++];\n            if (!isHexDigit(ch)) {\n                break;\n            }\n            code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n        }\n\n        if (code > 0x10FFFF || ch !== '}') {\n            throwUnexpectedToken();\n        }\n\n        // UTF-16 Encoding\n        if (code <= 0xFFFF) {\n            return String.fromCharCode(code);\n        }\n        cu1 = ((code - 0x10000) >> 10) + 0xD800;\n        cu2 = ((code - 0x10000) & 1023) + 0xDC00;\n        return String.fromCharCode(cu1, cu2);\n    }\n\n    function getEscapedIdentifier() {\n        var ch, id;\n\n        ch = source.charCodeAt(index++);\n        id = String.fromCharCode(ch);\n\n        // '\\u' (U+005C, U+0075) denotes an escaped character.\n        if (ch === 0x5C) {\n            if (source.charCodeAt(index) !== 0x75) {\n                throwUnexpectedToken();\n            }\n            ++index;\n            ch = scanHexEscape('u');\n            if (!ch || ch === '\\\\' || !isIdentifierStart(ch.charCodeAt(0))) {\n                throwUnexpectedToken();\n            }\n            id = ch;\n        }\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (!isIdentifierPart(ch)) {\n                break;\n            }\n            ++index;\n            id += String.fromCharCode(ch);\n\n            // '\\u' (U+005C, U+0075) denotes an escaped character.\n            if (ch === 0x5C) {\n                id = id.substr(0, id.length - 1);\n                if (source.charCodeAt(index) !== 0x75) {\n                    throwUnexpectedToken();\n                }\n                ++index;\n                ch = scanHexEscape('u');\n                if (!ch || ch === '\\\\' || !isIdentifierPart(ch.charCodeAt(0))) {\n                    throwUnexpectedToken();\n                }\n                id += ch;\n            }\n        }\n\n        return id;\n    }\n\n    function getIdentifier() {\n        var start, ch;\n\n        start = index++;\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (ch === 0x5C) {\n                // Blackslash (U+005C) marks Unicode escape sequence.\n                index = start;\n                return getEscapedIdentifier();\n            }\n            if (isIdentifierPart(ch)) {\n                ++index;\n            } else {\n                break;\n            }\n        }\n\n        return source.slice(start, index);\n    }\n\n    function scanIdentifier() {\n        var start, id, type;\n\n        start = index;\n\n        // Backslash (U+005C) starts an escaped character.\n        id = (source.charCodeAt(index) === 0x5C) ? getEscapedIdentifier() : getIdentifier();\n\n        // There is no keyword or literal with only one character.\n        // Thus, it must be an identifier.\n        if (id.length === 1) {\n            type = Token.Identifier;\n        } else if (isKeyword(id)) {\n            type = Token.Keyword;\n        } else if (id === 'null') {\n            type = Token.NullLiteral;\n        } else if (id === 'true' || id === 'false') {\n            type = Token.BooleanLiteral;\n        } else {\n            type = Token.Identifier;\n        }\n\n        return {\n            type: type,\n            value: id,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n\n    // 7.7 Punctuators\n\n    function scanPunctuator() {\n        var token, str;\n\n        token = {\n            type: Token.Punctuator,\n            value: '',\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: index,\n            end: index\n        };\n\n        // Check for most common single-character punctuators.\n        str = source[index];\n        switch (str) {\n\n        case '(':\n            if (extra.tokenize) {\n                extra.openParenToken = extra.tokens.length;\n            }\n            ++index;\n            break;\n\n        case '{':\n            if (extra.tokenize) {\n                extra.openCurlyToken = extra.tokens.length;\n            }\n            state.curlyStack.push('{');\n            ++index;\n            break;\n\n        case '.':\n            ++index;\n            if (source[index] === '.' && source[index + 1] === '.') {\n                // Spread operator: ...\n                index += 2;\n                str = '...';\n            }\n            break;\n\n        case '}':\n            ++index;\n            state.curlyStack.pop();\n            break;\n        case ')':\n        case ';':\n        case ',':\n        case '[':\n        case ']':\n        case ':':\n        case '?':\n        case '~':\n            ++index;\n            break;\n\n        default:\n            // 4-character punctuator.\n            str = source.substr(index, 4);\n            if (str === '>>>=') {\n                index += 4;\n            } else {\n\n                // 3-character punctuators.\n                str = str.substr(0, 3);\n                if (str === '===' || str === '!==' || str === '>>>' ||\n                    str === '<<=' || str === '>>=') {\n                    index += 3;\n                } else {\n\n                    // 2-character punctuators.\n                    str = str.substr(0, 2);\n                    if (str === '&&' || str === '||' || str === '==' || str === '!=' ||\n                        str === '+=' || str === '-=' || str === '*=' || str === '/=' ||\n                        str === '++' || str === '--' || str === '<<' || str === '>>' ||\n                        str === '&=' || str === '|=' || str === '^=' || str === '%=' ||\n                        str === '<=' || str === '>=' || str === '=>') {\n                        index += 2;\n                    } else {\n\n                        // 1-character punctuators.\n                        str = source[index];\n                        if ('<>=!+-*%&|^/'.indexOf(str) >= 0) {\n                            ++index;\n                        }\n                    }\n                }\n            }\n        }\n\n        if (index === token.start) {\n            throwUnexpectedToken();\n        }\n\n        token.end = index;\n        token.value = str;\n        return token;\n    }\n\n    // 7.8.3 Numeric Literals\n\n    function scanHexLiteral(start) {\n        var number = '';\n\n        while (index < length) {\n            if (!isHexDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt('0x' + number, 16),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanBinaryLiteral(start) {\n        var ch, number;\n\n        number = '';\n\n        while (index < length) {\n            ch = source[index];\n            if (ch !== '0' && ch !== '1') {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            // only 0b or 0B\n            throwUnexpectedToken();\n        }\n\n        if (index < length) {\n            ch = source.charCodeAt(index);\n            /* istanbul ignore else */\n            if (isIdentifierStart(ch) || isDecimalDigit(ch)) {\n                throwUnexpectedToken();\n            }\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 2),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanOctalLiteral(prefix, start) {\n        var number, octal;\n\n        if (isOctalDigit(prefix)) {\n            octal = true;\n            number = '0' + source[index++];\n        } else {\n            octal = false;\n            ++index;\n            number = '';\n        }\n\n        while (index < length) {\n            if (!isOctalDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (!octal && number.length === 0) {\n            // only 0o or 0O\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index)) || isDecimalDigit(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 8),\n            octal: octal,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function isImplicitOctalLiteral() {\n        var i, ch;\n\n        // Implicit octal, unless there is a non-octal digit.\n        // (Annex B.1.1 on Numeric Literals)\n        for (i = index + 1; i < length; ++i) {\n            ch = source[i];\n            if (ch === '8' || ch === '9') {\n                return false;\n            }\n            if (!isOctalDigit(ch)) {\n                return true;\n            }\n        }\n\n        return true;\n    }\n\n    function scanNumericLiteral() {\n        var number, start, ch;\n\n        ch = source[index];\n        assert(isDecimalDigit(ch.charCodeAt(0)) || (ch === '.'),\n            'Numeric literal must start with a decimal digit or a decimal point');\n\n        start = index;\n        number = '';\n        if (ch !== '.') {\n            number = source[index++];\n            ch = source[index];\n\n            // Hex number starts with '0x'.\n            // Octal number starts with '0'.\n            // Octal number in ES6 starts with '0o'.\n            // Binary number in ES6 starts with '0b'.\n            if (number === '0') {\n                if (ch === 'x' || ch === 'X') {\n                    ++index;\n                    return scanHexLiteral(start);\n                }\n                if (ch === 'b' || ch === 'B') {\n                    ++index;\n                    return scanBinaryLiteral(start);\n                }\n                if (ch === 'o' || ch === 'O') {\n                    return scanOctalLiteral(ch, start);\n                }\n\n                if (isOctalDigit(ch)) {\n                    if (isImplicitOctalLiteral()) {\n                        return scanOctalLiteral(ch, start);\n                    }\n                }\n            }\n\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === '.') {\n            number += source[index++];\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === 'e' || ch === 'E') {\n            number += source[index++];\n\n            ch = source[index];\n            if (ch === '+' || ch === '-') {\n                number += source[index++];\n            }\n            if (isDecimalDigit(source.charCodeAt(index))) {\n                while (isDecimalDigit(source.charCodeAt(index))) {\n                    number += source[index++];\n                }\n            } else {\n                throwUnexpectedToken();\n            }\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseFloat(number),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    // 7.8.4 String Literals\n\n    function scanStringLiteral() {\n        var str = '', quote, start, ch, unescaped, octToDec, octal = false;\n\n        quote = source[index];\n        assert((quote === '\\'' || quote === '\"'),\n            'String literal must starts with a quote');\n\n        start = index;\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n\n            if (ch === quote) {\n                quote = '';\n                break;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!ch || !isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            str += scanUnicodeCodePointEscape();\n                        } else {\n                            unescaped = scanHexEscape(ch);\n                            if (!unescaped) {\n                                throw throwUnexpectedToken();\n                            }\n                            str += unescaped;\n                        }\n                        break;\n                    case 'n':\n                        str += '\\n';\n                        break;\n                    case 'r':\n                        str += '\\r';\n                        break;\n                    case 't':\n                        str += '\\t';\n                        break;\n                    case 'b':\n                        str += '\\b';\n                        break;\n                    case 'f':\n                        str += '\\f';\n                        break;\n                    case 'v':\n                        str += '\\x0B';\n                        break;\n                    case '8':\n                    case '9':\n                        throw throwUnexpectedToken();\n\n                    default:\n                        if (isOctalDigit(ch)) {\n                            octToDec = octalToDecimal(ch);\n\n                            octal = octToDec.octal || octal;\n                            str += String.fromCharCode(octToDec.code);\n                        } else {\n                            str += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                break;\n            } else {\n                str += ch;\n            }\n        }\n\n        if (quote !== '') {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.StringLiteral,\n            value: str,\n            octal: octal,\n            lineNumber: startLineNumber,\n            lineStart: startLineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanTemplate() {\n        var cooked = '', ch, start, rawOffset, terminated, head, tail, restore, unescaped;\n\n        terminated = false;\n        tail = false;\n        start = index;\n        head = (source[index] === '`');\n        rawOffset = 2;\n\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n            if (ch === '`') {\n                rawOffset = 1;\n                tail = true;\n                terminated = true;\n                break;\n            } else if (ch === '$') {\n                if (source[index] === '{') {\n                    state.curlyStack.push('${');\n                    ++index;\n                    terminated = true;\n                    break;\n                }\n                cooked += ch;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'n':\n                        cooked += '\\n';\n                        break;\n                    case 'r':\n                        cooked += '\\r';\n                        break;\n                    case 't':\n                        cooked += '\\t';\n                        break;\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            cooked += scanUnicodeCodePointEscape();\n                        } else {\n                            restore = index;\n                            unescaped = scanHexEscape(ch);\n                            if (unescaped) {\n                                cooked += unescaped;\n                            } else {\n                                index = restore;\n                                cooked += ch;\n                            }\n                        }\n                        break;\n                    case 'b':\n                        cooked += '\\b';\n                        break;\n                    case 'f':\n                        cooked += '\\f';\n                        break;\n                    case 'v':\n                        cooked += '\\v';\n                        break;\n\n                    default:\n                        if (ch === '0') {\n                            if (isDecimalDigit(source.charCodeAt(index))) {\n                                // Illegal: \\01 \\02 and so on\n                                throwError(Messages.TemplateOctalLiteral);\n                            }\n                            cooked += '\\0';\n                        } else if (isOctalDigit(ch)) {\n                            // Illegal: \\1 \\2\n                            throwError(Messages.TemplateOctalLiteral);\n                        } else {\n                            cooked += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                ++lineNumber;\n                if (ch === '\\r' && source[index] === '\\n') {\n                    ++index;\n                }\n                lineStart = index;\n                cooked += '\\n';\n            } else {\n                cooked += ch;\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken();\n        }\n\n        if (!head) {\n            state.curlyStack.pop();\n        }\n\n        return {\n            type: Token.Template,\n            value: {\n                cooked: cooked,\n                raw: source.slice(start + 1, index - rawOffset)\n            },\n            head: head,\n            tail: tail,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function testRegExp(pattern, flags) {\n        var tmp = pattern;\n\n        if (flags.indexOf('u') >= 0) {\n            // Replace each astral symbol and every Unicode escape sequence\n            // that possibly represents an astral symbol or a paired surrogate\n            // with a single ASCII symbol to avoid throwing on regular\n            // expressions that are only valid in combination with the `/u`\n            // flag.\n            // Note: replacing with the ASCII symbol `x` might cause false\n            // negatives in unlikely scenarios. For example, `[\\u{61}-b]` is a\n            // perfectly valid pattern that is equivalent to `[a-b]`, but it\n            // would be replaced by `[x-b]` which throws an error.\n            tmp = tmp\n                .replace(/\\\\u\\{([0-9a-fA-F]+)\\}/g, function ($0, $1) {\n                    if (parseInt($1, 16) <= 0x10FFFF) {\n                        return 'x';\n                    }\n                    throwUnexpectedToken(null, Messages.InvalidRegExp);\n                })\n                .replace(\n                    /\\\\u([a-fA-F0-9]{4})|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g,\n                    'x'\n                );\n        }\n\n        // First, detect invalid regular expressions.\n        try {\n            RegExp(tmp);\n        } catch (e) {\n            throwUnexpectedToken(null, Messages.InvalidRegExp);\n        }\n\n        // Return a regular expression object for this pattern-flag pair, or\n        // `null` in case the current environment doesn't support the flags it\n        // uses.\n        try {\n            return new RegExp(pattern, flags);\n        } catch (exception) {\n            return null;\n        }\n    }\n\n    function scanRegExpBody() {\n        var ch, str, classMarker, terminated, body;\n\n        ch = source[index];\n        assert(ch === '/', 'Regular expression literal must start with a slash');\n        str = source[index++];\n\n        classMarker = false;\n        terminated = false;\n        while (index < length) {\n            ch = source[index++];\n            str += ch;\n            if (ch === '\\\\') {\n                ch = source[index++];\n                // ECMA-262 7.8.5\n                if (isLineTerminator(ch.charCodeAt(0))) {\n                    throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n                }\n                str += ch;\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n            } else if (classMarker) {\n                if (ch === ']') {\n                    classMarker = false;\n                }\n            } else {\n                if (ch === '/') {\n                    terminated = true;\n                    break;\n                } else if (ch === '[') {\n                    classMarker = true;\n                }\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n        }\n\n        // Exclude leading and trailing slash.\n        body = str.substr(1, str.length - 2);\n        return {\n            value: body,\n            literal: str\n        };\n    }\n\n    function scanRegExpFlags() {\n        var ch, str, flags, restore;\n\n        str = '';\n        flags = '';\n        while (index < length) {\n            ch = source[index];\n            if (!isIdentifierPart(ch.charCodeAt(0))) {\n                break;\n            }\n\n            ++index;\n            if (ch === '\\\\' && index < length) {\n                ch = source[index];\n                if (ch === 'u') {\n                    ++index;\n                    restore = index;\n                    ch = scanHexEscape('u');\n                    if (ch) {\n                        flags += ch;\n                        for (str += '\\\\u'; restore < index; ++restore) {\n                            str += source[restore];\n                        }\n                    } else {\n                        index = restore;\n                        flags += 'u';\n                        str += '\\\\u';\n                    }\n                    tolerateUnexpectedToken();\n                } else {\n                    str += '\\\\';\n                    tolerateUnexpectedToken();\n                }\n            } else {\n                flags += ch;\n                str += ch;\n            }\n        }\n\n        return {\n            value: flags,\n            literal: str\n        };\n    }\n\n    function scanRegExp() {\n        scanning = true;\n        var start, body, flags, value;\n\n        lookahead = null;\n        skipComment();\n        start = index;\n\n        body = scanRegExpBody();\n        flags = scanRegExpFlags();\n        value = testRegExp(body.value, flags.value);\n        scanning = false;\n        if (extra.tokenize) {\n            return {\n                type: Token.RegularExpression,\n                value: value,\n                regex: {\n                    pattern: body.value,\n                    flags: flags.value\n                },\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: start,\n                end: index\n            };\n        }\n\n        return {\n            literal: body.literal + flags.literal,\n            value: value,\n            regex: {\n                pattern: body.value,\n                flags: flags.value\n            },\n            start: start,\n            end: index\n        };\n    }\n\n    function collectRegex() {\n        var pos, loc, regex, token;\n\n        skipComment();\n\n        pos = index;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        regex = scanRegExp();\n\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        /* istanbul ignore next */\n        if (!extra.tokenize) {\n            // Pop the previous token, which is likely '/' or '/='\n            if (extra.tokens.length > 0) {\n                token = extra.tokens[extra.tokens.length - 1];\n                if (token.range[0] === pos && token.type === 'Punctuator') {\n                    if (token.value === '/' || token.value === '/=') {\n                        extra.tokens.pop();\n                    }\n                }\n            }\n\n            extra.tokens.push({\n                type: 'RegularExpression',\n                value: regex.literal,\n                regex: regex.regex,\n                range: [pos, index],\n                loc: loc\n            });\n        }\n\n        return regex;\n    }\n\n    function isIdentifierName(token) {\n        return token.type === Token.Identifier ||\n            token.type === Token.Keyword ||\n            token.type === Token.BooleanLiteral ||\n            token.type === Token.NullLiteral;\n    }\n\n    function advanceSlash() {\n        var prevToken,\n            checkToken;\n        // Using the following algorithm:\n        // https://github.com/mozilla/sweet.js/wiki/design\n        prevToken = extra.tokens[extra.tokens.length - 1];\n        if (!prevToken) {\n            // Nothing before that: it cannot be a division.\n            return collectRegex();\n        }\n        if (prevToken.type === 'Punctuator') {\n            if (prevToken.value === ']') {\n                return scanPunctuator();\n            }\n            if (prevToken.value === ')') {\n                checkToken = extra.tokens[extra.openParenToken - 1];\n                if (checkToken &&\n                        checkToken.type === 'Keyword' &&\n                        (checkToken.value === 'if' ||\n                         checkToken.value === 'while' ||\n                         checkToken.value === 'for' ||\n                         checkToken.value === 'with')) {\n                    return collectRegex();\n                }\n                return scanPunctuator();\n            }\n            if (prevToken.value === '}') {\n                // Dividing a function by anything makes little sense,\n                // but we have to check for that.\n                if (extra.tokens[extra.openCurlyToken - 3] &&\n                        extra.tokens[extra.openCurlyToken - 3].type === 'Keyword') {\n                    // Anonymous function.\n                    checkToken = extra.tokens[extra.openCurlyToken - 4];\n                    if (!checkToken) {\n                        return scanPunctuator();\n                    }\n                } else if (extra.tokens[extra.openCurlyToken - 4] &&\n                        extra.tokens[extra.openCurlyToken - 4].type === 'Keyword') {\n                    // Named function.\n                    checkToken = extra.tokens[extra.openCurlyToken - 5];\n                    if (!checkToken) {\n                        return collectRegex();\n                    }\n                } else {\n                    return scanPunctuator();\n                }\n                // checkToken determines whether the function is\n                // a declaration or an expression.\n                if (FnExprTokens.indexOf(checkToken.value) >= 0) {\n                    // It is an expression.\n                    return scanPunctuator();\n                }\n                // It is a declaration.\n                return collectRegex();\n            }\n            return collectRegex();\n        }\n        if (prevToken.type === 'Keyword' && prevToken.value !== 'this') {\n            return collectRegex();\n        }\n        return scanPunctuator();\n    }\n\n    function advance() {\n        var ch, token;\n\n        if (index >= length) {\n            return {\n                type: Token.EOF,\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: index,\n                end: index\n            };\n        }\n\n        ch = source.charCodeAt(index);\n\n        if (isIdentifierStart(ch)) {\n            token = scanIdentifier();\n            if (strict && isStrictModeReservedWord(token.value)) {\n                token.type = Token.Keyword;\n            }\n            return token;\n        }\n\n        // Very common: ( and ) and ;\n        if (ch === 0x28 || ch === 0x29 || ch === 0x3B) {\n            return scanPunctuator();\n        }\n\n        // String literal starts with single quote (U+0027) or double quote (U+0022).\n        if (ch === 0x27 || ch === 0x22) {\n            return scanStringLiteral();\n        }\n\n        // Dot (.) U+002E can also start a floating-point number, hence the need\n        // to check the next character.\n        if (ch === 0x2E) {\n            if (isDecimalDigit(source.charCodeAt(index + 1))) {\n                return scanNumericLiteral();\n            }\n            return scanPunctuator();\n        }\n\n        if (isDecimalDigit(ch)) {\n            return scanNumericLiteral();\n        }\n\n        // Slash (/) U+002F can also start a regex.\n        if (extra.tokenize && ch === 0x2F) {\n            return advanceSlash();\n        }\n\n        // Template literals start with ` (U+0060) for template head\n        // or } (U+007D) for template middle or template tail.\n        if (ch === 0x60 || (ch === 0x7D && state.curlyStack[state.curlyStack.length - 1] === '${')) {\n            return scanTemplate();\n        }\n\n        return scanPunctuator();\n    }\n\n    function collectToken() {\n        var loc, token, value, entry;\n\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        token = advance();\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        if (token.type !== Token.EOF) {\n            value = source.slice(token.start, token.end);\n            entry = {\n                type: TokenName[token.type],\n                value: value,\n                range: [token.start, token.end],\n                loc: loc\n            };\n            if (token.regex) {\n                entry.regex = {\n                    pattern: token.regex.pattern,\n                    flags: token.regex.flags\n                };\n            }\n            extra.tokens.push(entry);\n        }\n\n        return token;\n    }\n\n    function lex() {\n        var token;\n        scanning = true;\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        skipComment();\n\n        token = lookahead;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n        return token;\n    }\n\n    function peek() {\n        scanning = true;\n\n        skipComment();\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n    }\n\n    function Position() {\n        this.line = startLineNumber;\n        this.column = startIndex - startLineStart;\n    }\n\n    function SourceLocation() {\n        this.start = new Position();\n        this.end = null;\n    }\n\n    function WrappingSourceLocation(startToken) {\n        this.start = {\n            line: startToken.lineNumber,\n            column: startToken.start - startToken.lineStart\n        };\n        this.end = null;\n    }\n\n    function Node() {\n        if (extra.range) {\n            this.range = [startIndex, 0];\n        }\n        if (extra.loc) {\n            this.loc = new SourceLocation();\n        }\n    }\n\n    function WrappingNode(startToken) {\n        if (extra.range) {\n            this.range = [startToken.start, 0];\n        }\n        if (extra.loc) {\n            this.loc = new WrappingSourceLocation(startToken);\n        }\n    }\n\n    WrappingNode.prototype = Node.prototype = {\n\n        processComment: function () {\n            var lastChild,\n                leadingComments,\n                trailingComments,\n                bottomRight = extra.bottomRightStack,\n                i,\n                comment,\n                last = bottomRight[bottomRight.length - 1];\n\n            if (this.type === Syntax.Program) {\n                if (this.body.length > 0) {\n                    return;\n                }\n            }\n\n            if (extra.trailingComments.length > 0) {\n                trailingComments = [];\n                for (i = extra.trailingComments.length - 1; i >= 0; --i) {\n                    comment = extra.trailingComments[i];\n                    if (comment.range[0] >= this.range[1]) {\n                        trailingComments.unshift(comment);\n                        extra.trailingComments.splice(i, 1);\n                    }\n                }\n                extra.trailingComments = [];\n            } else {\n                if (last && last.trailingComments && last.trailingComments[0].range[0] >= this.range[1]) {\n                    trailingComments = last.trailingComments;\n                    delete last.trailingComments;\n                }\n            }\n\n            // Eating the stack.\n            if (last) {\n                while (last && last.range[0] >= this.range[0]) {\n                    lastChild = last;\n                    last = bottomRight.pop();\n                }\n            }\n\n            if (lastChild) {\n                if (lastChild.leadingComments && lastChild.leadingComments[lastChild.leadingComments.length - 1].range[1] <= this.range[0]) {\n                    this.leadingComments = lastChild.leadingComments;\n                    lastChild.leadingComments = undefined;\n                }\n            } else if (extra.leadingComments.length > 0) {\n                leadingComments = [];\n                for (i = extra.leadingComments.length - 1; i >= 0; --i) {\n                    comment = extra.leadingComments[i];\n                    if (comment.range[1] <= this.range[0]) {\n                        leadingComments.unshift(comment);\n                        extra.leadingComments.splice(i, 1);\n                    }\n                }\n            }\n\n\n            if (leadingComments && leadingComments.length > 0) {\n                this.leadingComments = leadingComments;\n            }\n            if (trailingComments && trailingComments.length > 0) {\n                this.trailingComments = trailingComments;\n            }\n\n            bottomRight.push(this);\n        },\n\n        finish: function () {\n            if (extra.range) {\n                this.range[1] = lastIndex;\n            }\n            if (extra.loc) {\n                this.loc.end = {\n                    line: lastLineNumber,\n                    column: lastIndex - lastLineStart\n                };\n                if (extra.source) {\n                    this.loc.source = extra.source;\n                }\n            }\n\n            if (extra.attachComment) {\n                this.processComment();\n            }\n        },\n\n        finishArrayExpression: function (elements) {\n            this.type = Syntax.ArrayExpression;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrayPattern: function (elements) {\n            this.type = Syntax.ArrayPattern;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrowFunctionExpression: function (params, defaults, body, expression) {\n            this.type = Syntax.ArrowFunctionExpression;\n            this.id = null;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentExpression: function (operator, left, right) {\n            this.type = Syntax.AssignmentExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentPattern: function (left, right) {\n            this.type = Syntax.AssignmentPattern;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBinaryExpression: function (operator, left, right) {\n            this.type = (operator === '||' || operator === '&&') ? Syntax.LogicalExpression : Syntax.BinaryExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBlockStatement: function (body) {\n            this.type = Syntax.BlockStatement;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishBreakStatement: function (label) {\n            this.type = Syntax.BreakStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishCallExpression: function (callee, args) {\n            this.type = Syntax.CallExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishCatchClause: function (param, body) {\n            this.type = Syntax.CatchClause;\n            this.param = param;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassBody: function (body) {\n            this.type = Syntax.ClassBody;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassDeclaration: function (id, superClass, body) {\n            this.type = Syntax.ClassDeclaration;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassExpression: function (id, superClass, body) {\n            this.type = Syntax.ClassExpression;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishConditionalExpression: function (test, consequent, alternate) {\n            this.type = Syntax.ConditionalExpression;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishContinueStatement: function (label) {\n            this.type = Syntax.ContinueStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishDebuggerStatement: function () {\n            this.type = Syntax.DebuggerStatement;\n            this.finish();\n            return this;\n        },\n\n        finishDoWhileStatement: function (body, test) {\n            this.type = Syntax.DoWhileStatement;\n            this.body = body;\n            this.test = test;\n            this.finish();\n            return this;\n        },\n\n        finishEmptyStatement: function () {\n            this.type = Syntax.EmptyStatement;\n            this.finish();\n            return this;\n        },\n\n        finishExpressionStatement: function (expression) {\n            this.type = Syntax.ExpressionStatement;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishForStatement: function (init, test, update, body) {\n            this.type = Syntax.ForStatement;\n            this.init = init;\n            this.test = test;\n            this.update = update;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishForInStatement: function (left, right, body) {\n            this.type = Syntax.ForInStatement;\n            this.left = left;\n            this.right = right;\n            this.body = body;\n            this.each = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionDeclaration: function (id, params, defaults, body) {\n            this.type = Syntax.FunctionDeclaration;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionExpression: function (id, params, defaults, body) {\n            this.type = Syntax.FunctionExpression;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishIdentifier: function (name) {\n            this.type = Syntax.Identifier;\n            this.name = name;\n            this.finish();\n            return this;\n        },\n\n        finishIfStatement: function (test, consequent, alternate) {\n            this.type = Syntax.IfStatement;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishLabeledStatement: function (label, body) {\n            this.type = Syntax.LabeledStatement;\n            this.label = label;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishLiteral: function (token) {\n            this.type = Syntax.Literal;\n            this.value = token.value;\n            this.raw = source.slice(token.start, token.end);\n            if (token.regex) {\n                this.regex = token.regex;\n            }\n            this.finish();\n            return this;\n        },\n\n        finishMemberExpression: function (accessor, object, property) {\n            this.type = Syntax.MemberExpression;\n            this.computed = accessor === '[';\n            this.object = object;\n            this.property = property;\n            this.finish();\n            return this;\n        },\n\n        finishNewExpression: function (callee, args) {\n            this.type = Syntax.NewExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishObjectExpression: function (properties) {\n            this.type = Syntax.ObjectExpression;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishObjectPattern: function (properties) {\n            this.type = Syntax.ObjectPattern;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishPostfixExpression: function (operator, argument) {\n            this.type = Syntax.UpdateExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = false;\n            this.finish();\n            return this;\n        },\n\n        finishProgram: function (body) {\n            this.type = Syntax.Program;\n            this.body = body;\n            if (sourceType === 'module') {\n                // very restrictive for now\n                this.sourceType = sourceType;\n            }\n            this.finish();\n            return this;\n        },\n\n        finishProperty: function (kind, key, computed, value, method, shorthand) {\n            this.type = Syntax.Property;\n            this.key = key;\n            this.computed = computed;\n            this.value = value;\n            this.kind = kind;\n            this.method = method;\n            this.shorthand = shorthand;\n            this.finish();\n            return this;\n        },\n\n        finishRestElement: function (argument) {\n            this.type = Syntax.RestElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishReturnStatement: function (argument) {\n            this.type = Syntax.ReturnStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSequenceExpression: function (expressions) {\n            this.type = Syntax.SequenceExpression;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishSpreadElement: function (argument) {\n            this.type = Syntax.SpreadElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchCase: function (test, consequent) {\n            this.type = Syntax.SwitchCase;\n            this.test = test;\n            this.consequent = consequent;\n            this.finish();\n            return this;\n        },\n\n        finishSuper: function () {\n            this.type = Syntax.Super;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchStatement: function (discriminant, cases) {\n            this.type = Syntax.SwitchStatement;\n            this.discriminant = discriminant;\n            this.cases = cases;\n            this.finish();\n            return this;\n        },\n\n        finishTaggedTemplateExpression: function (tag, quasi) {\n            this.type = Syntax.TaggedTemplateExpression;\n            this.tag = tag;\n            this.quasi = quasi;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateElement: function (value, tail) {\n            this.type = Syntax.TemplateElement;\n            this.value = value;\n            this.tail = tail;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateLiteral: function (quasis, expressions) {\n            this.type = Syntax.TemplateLiteral;\n            this.quasis = quasis;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishThisExpression: function () {\n            this.type = Syntax.ThisExpression;\n            this.finish();\n            return this;\n        },\n\n        finishThrowStatement: function (argument) {\n            this.type = Syntax.ThrowStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishTryStatement: function (block, handler, finalizer) {\n            this.type = Syntax.TryStatement;\n            this.block = block;\n            this.guardedHandlers = [];\n            this.handlers = handler ? [ handler ] : [];\n            this.handler = handler;\n            this.finalizer = finalizer;\n            this.finish();\n            return this;\n        },\n\n        finishUnaryExpression: function (operator, argument) {\n            this.type = (operator === '++' || operator === '--') ? Syntax.UpdateExpression : Syntax.UnaryExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = true;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclaration: function (declarations) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = 'var';\n            this.finish();\n            return this;\n        },\n\n        finishLexicalDeclaration: function (declarations, kind) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = kind;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclarator: function (id, init) {\n            this.type = Syntax.VariableDeclarator;\n            this.id = id;\n            this.init = init;\n            this.finish();\n            return this;\n        },\n\n        finishWhileStatement: function (test, body) {\n            this.type = Syntax.WhileStatement;\n            this.test = test;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishWithStatement: function (object, body) {\n            this.type = Syntax.WithStatement;\n            this.object = object;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishExportSpecifier: function (local, exported) {\n            this.type = Syntax.ExportSpecifier;\n            this.exported = exported || local;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportDefaultSpecifier: function (local) {\n            this.type = Syntax.ImportDefaultSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportNamespaceSpecifier: function (local) {\n            this.type = Syntax.ImportNamespaceSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishExportNamedDeclaration: function (declaration, specifiers, src) {\n            this.type = Syntax.ExportNamedDeclaration;\n            this.declaration = declaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishExportDefaultDeclaration: function (declaration) {\n            this.type = Syntax.ExportDefaultDeclaration;\n            this.declaration = declaration;\n            this.finish();\n            return this;\n        },\n\n        finishExportAllDeclaration: function (src) {\n            this.type = Syntax.ExportAllDeclaration;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishImportSpecifier: function (local, imported) {\n            this.type = Syntax.ImportSpecifier;\n            this.local = local || imported;\n            this.imported = imported;\n            this.finish();\n            return this;\n        },\n\n        finishImportDeclaration: function (specifiers, src) {\n            this.type = Syntax.ImportDeclaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        }\n    };\n\n\n    function recordError(error) {\n        var e, existing;\n\n        for (e = 0; e < extra.errors.length; e++) {\n            existing = extra.errors[e];\n            // Prevent duplicated error.\n            /* istanbul ignore next */\n            if (existing.index === error.index && existing.message === error.message) {\n                return;\n            }\n        }\n\n        extra.errors.push(error);\n    }\n\n    function createError(line, pos, description) {\n        var error = new Error('Line ' + line + ': ' + description);\n        error.index = pos;\n        error.lineNumber = line;\n        error.column = pos - (scanning ? lineStart : lastLineStart) + 1;\n        error.description = description;\n        return error;\n    }\n\n    // Throw an exception\n\n    function throwError(messageFormat) {\n        var args, msg;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        throw createError(lastLineNumber, lastIndex, msg);\n    }\n\n    function tolerateError(messageFormat) {\n        var args, msg, error;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        /* istanbul ignore next */\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        error = createError(lineNumber, lastIndex, msg);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Throw an exception because of the token.\n\n    function unexpectedTokenError(token, message) {\n        var value, msg = message || Messages.UnexpectedToken;\n\n        if (token) {\n            if (!message) {\n                msg = (token.type === Token.EOF) ? Messages.UnexpectedEOS :\n                    (token.type === Token.Identifier) ? Messages.UnexpectedIdentifier :\n                    (token.type === Token.NumericLiteral) ? Messages.UnexpectedNumber :\n                    (token.type === Token.StringLiteral) ? Messages.UnexpectedString :\n                    (token.type === Token.Template) ? Messages.UnexpectedTemplate :\n                    Messages.UnexpectedToken;\n\n                if (token.type === Token.Keyword) {\n                    if (isFutureReservedWord(token.value)) {\n                        msg = Messages.UnexpectedReserved;\n                    } else if (strict && isStrictModeReservedWord(token.value)) {\n                        msg = Messages.StrictReservedWord;\n                    }\n                }\n            }\n\n            value = (token.type === Token.Template) ? token.value.raw : token.value;\n        } else {\n            value = 'ILLEGAL';\n        }\n\n        msg = msg.replace('%0', value);\n\n        return (token && typeof token.lineNumber === 'number') ?\n            createError(token.lineNumber, token.start, msg) :\n            createError(scanning ? lineNumber : lastLineNumber, scanning ? index : lastIndex, msg);\n    }\n\n    function throwUnexpectedToken(token, message) {\n        throw unexpectedTokenError(token, message);\n    }\n\n    function tolerateUnexpectedToken(token, message) {\n        var error = unexpectedTokenError(token, message);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Expect the next token to match the specified punctuator.\n    // If not, an exception will be thrown.\n\n    function expect(value) {\n        var token = lex();\n        if (token.type !== Token.Punctuator || token.value !== value) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    /**\n     * @name expectCommaSeparator\n     * @description Quietly expect a comma when in tolerant mode, otherwise delegates\n     * to <code>expect(value)</code>\n     * @since 2.0\n     */\n    function expectCommaSeparator() {\n        var token;\n\n        if (extra.errors) {\n            token = lookahead;\n            if (token.type === Token.Punctuator && token.value === ',') {\n                lex();\n            } else if (token.type === Token.Punctuator && token.value === ';') {\n                lex();\n                tolerateUnexpectedToken(token);\n            } else {\n                tolerateUnexpectedToken(token, Messages.UnexpectedToken);\n            }\n        } else {\n            expect(',');\n        }\n    }\n\n    // Expect the next token to match the specified keyword.\n    // If not, an exception will be thrown.\n\n    function expectKeyword(keyword) {\n        var token = lex();\n        if (token.type !== Token.Keyword || token.value !== keyword) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    // Return true if the next token matches the specified punctuator.\n\n    function match(value) {\n        return lookahead.type === Token.Punctuator && lookahead.value === value;\n    }\n\n    // Return true if the next token matches the specified keyword\n\n    function matchKeyword(keyword) {\n        return lookahead.type === Token.Keyword && lookahead.value === keyword;\n    }\n\n    // Return true if the next token matches the specified contextual keyword\n    // (where an identifier is sometimes a keyword depending on the context)\n\n    function matchContextualKeyword(keyword) {\n        return lookahead.type === Token.Identifier && lookahead.value === keyword;\n    }\n\n    // Return true if the next token is an assignment operator\n\n    function matchAssign() {\n        var op;\n\n        if (lookahead.type !== Token.Punctuator) {\n            return false;\n        }\n        op = lookahead.value;\n        return op === '=' ||\n            op === '*=' ||\n            op === '/=' ||\n            op === '%=' ||\n            op === '+=' ||\n            op === '-=' ||\n            op === '<<=' ||\n            op === '>>=' ||\n            op === '>>>=' ||\n            op === '&=' ||\n            op === '^=' ||\n            op === '|=';\n    }\n\n    function consumeSemicolon() {\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(startIndex) === 0x3B || match(';')) {\n            lex();\n            return;\n        }\n\n        if (hasLineTerminator) {\n            return;\n        }\n\n        // FIXME(ikarienator): this is seemingly an issue in the previous location info convention.\n        lastIndex = startIndex;\n        lastLineNumber = startLineNumber;\n        lastLineStart = startLineStart;\n\n        if (lookahead.type !== Token.EOF && !match('}')) {\n            throwUnexpectedToken(lookahead);\n        }\n    }\n\n    // Cover grammar support.\n    //\n    // When an assignment expression position starts with an left parenthesis, the determination of the type\n    // of the syntax is to be deferred arbitrarily long until the end of the parentheses pair (plus a lookahead)\n    // or the first comma. This situation also defers the determination of all the expressions nested in the pair.\n    //\n    // There are three productions that can be parsed in a parentheses pair that needs to be determined\n    // after the outermost pair is closed. They are:\n    //\n    //   1. AssignmentExpression\n    //   2. BindingElements\n    //   3. AssignmentTargets\n    //\n    // In order to avoid exponential backtracking, we use two flags to denote if the production can be\n    // binding element or assignment target.\n    //\n    // The three productions have the relationship:\n    //\n    //   BindingElements ⊆ AssignmentTargets ⊆ AssignmentExpression\n    //\n    // with a single exception that CoverInitializedName when used directly in an Expression, generates\n    // an early error. Therefore, we need the third state, firstCoverInitializedNameError, to track the\n    // first usage of CoverInitializedName and report it when we reached the end of the parentheses pair.\n    //\n    // isolateCoverGrammar function runs the given parser function with a new cover grammar context, and it does not\n    // effect the current flags. This means the production the parser parses is only used as an expression. Therefore\n    // the CoverInitializedName check is conducted.\n    //\n    // inheritCoverGrammar function runs the given parse function with a new cover grammar context, and it propagates\n    // the flags outside of the parser. This means the production the parser parses is used as a part of a potential\n    // pattern. The CoverInitializedName check is deferred.\n    function isolateCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        if (firstCoverInitializedNameError !== null) {\n            throwUnexpectedToken(firstCoverInitializedNameError);\n        }\n        isBindingElement = oldIsBindingElement;\n        isAssignmentTarget = oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError;\n        return result;\n    }\n\n    function inheritCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        isBindingElement = isBindingElement && oldIsBindingElement;\n        isAssignmentTarget = isAssignmentTarget && oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError || firstCoverInitializedNameError;\n        return result;\n    }\n\n    function parseArrayPattern() {\n        var node = new Node(), elements = [], rest, restNode;\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else {\n                if (match('...')) {\n                    restNode = new Node();\n                    lex();\n                    rest = parseVariableIdentifier();\n                    elements.push(restNode.finishRestElement(rest));\n                    break;\n                } else {\n                    elements.push(parsePatternWithDefault());\n                }\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n\n        }\n\n        expect(']');\n\n        return node.finishArrayPattern(elements);\n    }\n\n    function parsePropertyPattern() {\n        var node = new Node(), key, computed = match('['), init;\n        if (lookahead.type === Token.Identifier) {\n            key = parseVariableIdentifier();\n            if (match('=')) {\n                lex();\n                init = parseAssignmentExpression();\n                return node.finishProperty(\n                    'init', key, false,\n                    new WrappingNode(key).finishAssignmentPattern(key, init), false, false);\n            } else if (!match(':')) {\n                return node.finishProperty('init', key, false, key, false, true);\n            }\n        } else {\n            key = parseObjectPropertyKey();\n        }\n        expect(':');\n        init = parsePatternWithDefault();\n        return node.finishProperty('init', key, computed, init, false, false);\n    }\n\n    function parseObjectPattern() {\n        var node = new Node(), properties = [];\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parsePropertyPattern());\n            if (!match('}')) {\n                expect(',');\n            }\n        }\n\n        lex();\n\n        return node.finishObjectPattern(properties);\n    }\n\n    function parsePattern() {\n        if (lookahead.type === Token.Identifier) {\n            return parseVariableIdentifier();\n        } else if (match('[')) {\n            return parseArrayPattern();\n        } else if (match('{')) {\n            return parseObjectPattern();\n        }\n        throwUnexpectedToken(lookahead);\n    }\n\n    function parsePatternWithDefault() {\n        var startToken = lookahead, pattern, right;\n        pattern = parsePattern();\n        if (match('=')) {\n            lex();\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            pattern = new WrappingNode(startToken).finishAssignmentPattern(pattern, right);\n        }\n        return pattern;\n    }\n\n    // 11.1.4 Array Initialiser\n\n    function parseArrayInitialiser() {\n        var elements = [], node = new Node(), restSpread;\n\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else if (match('...')) {\n                restSpread = new Node();\n                lex();\n                restSpread.finishSpreadElement(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    isAssignmentTarget = isBindingElement = false;\n                    expect(',');\n                }\n                elements.push(restSpread);\n            } else {\n                elements.push(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n        }\n\n        lex();\n\n        return node.finishArrayExpression(elements);\n    }\n\n    // 11.1.5 Object Initialiser\n\n    function parsePropertyFunction(node, paramInfo) {\n        var previousStrict, body;\n\n        isAssignmentTarget = isBindingElement = false;\n\n        previousStrict = strict;\n        body = isolateCoverGrammar(parseFunctionSourceElements);\n\n        if (strict && paramInfo.firstRestricted) {\n            tolerateUnexpectedToken(paramInfo.firstRestricted, paramInfo.message);\n        }\n        if (strict && paramInfo.stricted) {\n            tolerateUnexpectedToken(paramInfo.stricted, paramInfo.message);\n        }\n\n        strict = previousStrict;\n        return node.finishFunctionExpression(null, paramInfo.params, paramInfo.defaults, body);\n    }\n\n    function parsePropertyMethodFunction() {\n        var params, method, node = new Node();\n\n        params = parseParams();\n        method = parsePropertyFunction(node, params);\n\n        return method;\n    }\n\n    function parseObjectPropertyKey() {\n        var token, node = new Node(), expr;\n\n        token = lex();\n\n        // Note: This function is called only from parseObjectProperty(), where\n        // EOF and Punctuator tokens are already filtered out.\n\n        switch (token.type) {\n        case Token.StringLiteral:\n        case Token.NumericLiteral:\n            if (strict && token.octal) {\n                tolerateUnexpectedToken(token, Messages.StrictOctalLiteral);\n            }\n            return node.finishLiteral(token);\n        case Token.Identifier:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.Keyword:\n            return node.finishIdentifier(token.value);\n        case Token.Punctuator:\n            if (token.value === '[') {\n                expr = isolateCoverGrammar(parseAssignmentExpression);\n                expect(']');\n                return expr;\n            }\n            break;\n        }\n        throwUnexpectedToken(token);\n    }\n\n    function lookaheadPropertyName() {\n        switch (lookahead.type) {\n        case Token.Identifier:\n        case Token.StringLiteral:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.NumericLiteral:\n        case Token.Keyword:\n            return true;\n        case Token.Punctuator:\n            return lookahead.value === '[';\n        }\n        return false;\n    }\n\n    // This function is to try to parse a MethodDefinition as defined in 14.3. But in the case of object literals,\n    // it might be called at a position where there is in fact a short hand identifier pattern or a data property.\n    // This can only be determined after we consumed up to the left parentheses.\n    //\n    // In order to avoid back tracking, it returns `null` if the position is not a MethodDefinition and the caller\n    // is responsible to visit other options.\n    function tryParseMethodDefinition(token, key, computed, node) {\n        var value, options, methodNode;\n\n        if (token.type === Token.Identifier) {\n            // check for `get` and `set`;\n\n            if (token.value === 'get' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n                expect(')');\n                value = parsePropertyFunction(methodNode, {\n                    params: [],\n                    defaults: [],\n                    stricted: null,\n                    firstRestricted: null,\n                    message: null\n                });\n                return node.finishProperty('get', key, computed, value, false, false);\n            } else if (token.value === 'set' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n\n                options = {\n                    params: [],\n                    defaultCount: 0,\n                    defaults: [],\n                    firstRestricted: null,\n                    paramSet: {}\n                };\n                if (match(')')) {\n                    tolerateUnexpectedToken(lookahead);\n                } else {\n                    parseParam(options);\n                    if (options.defaultCount === 0) {\n                        options.defaults = [];\n                    }\n                }\n                expect(')');\n\n                value = parsePropertyFunction(methodNode, options);\n                return node.finishProperty('set', key, computed, value, false, false);\n            }\n        }\n\n        if (match('(')) {\n            value = parsePropertyMethodFunction();\n            return node.finishProperty('init', key, computed, value, true, false);\n        }\n\n        // Not a MethodDefinition.\n        return null;\n    }\n\n    function checkProto(key, computed, hasProto) {\n        if (computed === false && (key.type === Syntax.Identifier && key.name === '__proto__' ||\n            key.type === Syntax.Literal && key.value === '__proto__')) {\n            if (hasProto.value) {\n                tolerateError(Messages.DuplicateProtoProperty);\n            } else {\n                hasProto.value = true;\n            }\n        }\n    }\n\n    function parseObjectProperty(hasProto) {\n        var token = lookahead, node = new Node(), computed, key, maybeMethod, value;\n\n        computed = match('[');\n        key = parseObjectPropertyKey();\n        maybeMethod = tryParseMethodDefinition(token, key, computed, node);\n\n        if (maybeMethod) {\n            checkProto(maybeMethod.key, maybeMethod.computed, hasProto);\n            // finished\n            return maybeMethod;\n        }\n\n        // init property or short hand property.\n        checkProto(key, computed, hasProto);\n\n        if (match(':')) {\n            lex();\n            value = inheritCoverGrammar(parseAssignmentExpression);\n            return node.finishProperty('init', key, computed, value, false, false);\n        }\n\n        if (token.type === Token.Identifier) {\n            if (match('=')) {\n                firstCoverInitializedNameError = lookahead;\n                lex();\n                value = isolateCoverGrammar(parseAssignmentExpression);\n                return node.finishProperty('init', key, computed,\n                    new WrappingNode(token).finishAssignmentPattern(key, value), false, true);\n            }\n            return node.finishProperty('init', key, computed, key, false, true);\n        }\n\n        throwUnexpectedToken(lookahead);\n    }\n\n    function parseObjectInitialiser() {\n        var properties = [], hasProto = {value: false}, node = new Node();\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parseObjectProperty(hasProto));\n\n            if (!match('}')) {\n                expectCommaSeparator();\n            }\n        }\n\n        expect('}');\n\n        return node.finishObjectExpression(properties);\n    }\n\n    function reinterpretExpressionAsPattern(expr) {\n        var i;\n        switch (expr.type) {\n        case Syntax.Identifier:\n        case Syntax.MemberExpression:\n        case Syntax.RestElement:\n        case Syntax.AssignmentPattern:\n            break;\n        case Syntax.SpreadElement:\n            expr.type = Syntax.RestElement;\n            reinterpretExpressionAsPattern(expr.argument);\n            break;\n        case Syntax.ArrayExpression:\n            expr.type = Syntax.ArrayPattern;\n            for (i = 0; i < expr.elements.length; i++) {\n                if (expr.elements[i] !== null) {\n                    reinterpretExpressionAsPattern(expr.elements[i]);\n                }\n            }\n            break;\n        case Syntax.ObjectExpression:\n            expr.type = Syntax.ObjectPattern;\n            for (i = 0; i < expr.properties.length; i++) {\n                reinterpretExpressionAsPattern(expr.properties[i].value);\n            }\n            break;\n        case Syntax.AssignmentExpression:\n            expr.type = Syntax.AssignmentPattern;\n            reinterpretExpressionAsPattern(expr.left);\n            break;\n        default:\n            // Allow other node type for tolerant parsing.\n            break;\n        }\n    }\n\n    function parseTemplateElement(option) {\n        var node, token;\n\n        if (lookahead.type !== Token.Template || (option.head && !lookahead.head)) {\n            throwUnexpectedToken();\n        }\n\n        node = new Node();\n        token = lex();\n\n        return node.finishTemplateElement({ raw: token.value.raw, cooked: token.value.cooked }, token.tail);\n    }\n\n    function parseTemplateLiteral() {\n        var quasi, quasis, expressions, node = new Node();\n\n        quasi = parseTemplateElement({ head: true });\n        quasis = [ quasi ];\n        expressions = [];\n\n        while (!quasi.tail) {\n            expressions.push(parseExpression());\n            quasi = parseTemplateElement({ head: false });\n            quasis.push(quasi);\n        }\n\n        return node.finishTemplateLiteral(quasis, expressions);\n    }\n\n    // 11.1.6 The Grouping Operator\n\n    function parseGroupExpression() {\n        var expr, expressions, startToken, i;\n\n        expect('(');\n\n        if (match(')')) {\n            lex();\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: []\n            };\n        }\n\n        startToken = lookahead;\n        if (match('...')) {\n            expr = parseRestElement();\n            expect(')');\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: [expr]\n            };\n        }\n\n        isBindingElement = true;\n        expr = inheritCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            isAssignmentTarget = false;\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n\n                if (match('...')) {\n                    if (!isBindingElement) {\n                        throwUnexpectedToken(lookahead);\n                    }\n                    expressions.push(parseRestElement());\n                    expect(')');\n                    if (!match('=>')) {\n                        expect('=>');\n                    }\n                    isBindingElement = false;\n                    for (i = 0; i < expressions.length; i++) {\n                        reinterpretExpressionAsPattern(expressions[i]);\n                    }\n                    return {\n                        type: PlaceHolders.ArrowParameterPlaceHolder,\n                        params: expressions\n                    };\n                }\n\n                expressions.push(inheritCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n\n        expect(')');\n\n        if (match('=>')) {\n            if (!isBindingElement) {\n                throwUnexpectedToken(lookahead);\n            }\n\n            if (expr.type === Syntax.SequenceExpression) {\n                for (i = 0; i < expr.expressions.length; i++) {\n                    reinterpretExpressionAsPattern(expr.expressions[i]);\n                }\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            expr = {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: expr.type === Syntax.SequenceExpression ? expr.expressions : [expr]\n            };\n        }\n        isBindingElement = false;\n        return expr;\n    }\n\n\n    // 11.1 Primary Expressions\n\n    function parsePrimaryExpression() {\n        var type, token, expr, node;\n\n        if (match('(')) {\n            isBindingElement = false;\n            return inheritCoverGrammar(parseGroupExpression);\n        }\n\n        if (match('[')) {\n            return inheritCoverGrammar(parseArrayInitialiser);\n        }\n\n        if (match('{')) {\n            return inheritCoverGrammar(parseObjectInitialiser);\n        }\n\n        type = lookahead.type;\n        node = new Node();\n\n        if (type === Token.Identifier) {\n            expr = node.finishIdentifier(lex().value);\n        } else if (type === Token.StringLiteral || type === Token.NumericLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            if (strict && lookahead.octal) {\n                tolerateUnexpectedToken(lookahead, Messages.StrictOctalLiteral);\n            }\n            expr = node.finishLiteral(lex());\n        } else if (type === Token.Keyword) {\n            isAssignmentTarget = isBindingElement = false;\n            if (matchKeyword('function')) {\n                return parseFunctionExpression();\n            }\n            if (matchKeyword('this')) {\n                lex();\n                return node.finishThisExpression();\n            }\n            if (matchKeyword('class')) {\n                return parseClassExpression();\n            }\n            throwUnexpectedToken(lex());\n        } else if (type === Token.BooleanLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = (token.value === 'true');\n            expr = node.finishLiteral(token);\n        } else if (type === Token.NullLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = null;\n            expr = node.finishLiteral(token);\n        } else if (match('/') || match('/=')) {\n            isAssignmentTarget = isBindingElement = false;\n            index = startIndex;\n\n            if (typeof extra.tokens !== 'undefined') {\n                token = collectRegex();\n            } else {\n                token = scanRegExp();\n            }\n            lex();\n            expr = node.finishLiteral(token);\n        } else if (type === Token.Template) {\n            expr = parseTemplateLiteral();\n        } else {\n            throwUnexpectedToken(lex());\n        }\n\n        return expr;\n    }\n\n    // 11.2 Left-Hand-Side Expressions\n\n    function parseArguments() {\n        var args = [];\n\n        expect('(');\n\n        if (!match(')')) {\n            while (startIndex < length) {\n                args.push(isolateCoverGrammar(parseAssignmentExpression));\n                if (match(')')) {\n                    break;\n                }\n                expectCommaSeparator();\n            }\n        }\n\n        expect(')');\n\n        return args;\n    }\n\n    function parseNonComputedProperty() {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (!isIdentifierName(token)) {\n            throwUnexpectedToken(token);\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseNonComputedMember() {\n        expect('.');\n\n        return parseNonComputedProperty();\n    }\n\n    function parseComputedMember() {\n        var expr;\n\n        expect('[');\n\n        expr = isolateCoverGrammar(parseExpression);\n\n        expect(']');\n\n        return expr;\n    }\n\n    function parseNewExpression() {\n        var callee, args, node = new Node();\n\n        expectKeyword('new');\n        callee = isolateCoverGrammar(parseLeftHandSideExpression);\n        args = match('(') ? parseArguments() : [];\n\n        isAssignmentTarget = isBindingElement = false;\n\n        return node.finishNewExpression(callee, args);\n    }\n\n    function parseLeftHandSideExpressionAllowCall() {\n        var quasi, expr, args, property, startToken, previousAllowIn = state.allowIn;\n\n        startToken = lookahead;\n        state.allowIn = true;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('(') && !match('.') && !match('[')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (match('(')) {\n                isBindingElement = false;\n                isAssignmentTarget = false;\n                args = parseArguments();\n                expr = new WrappingNode(startToken).finishCallExpression(expr, args);\n            } else if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        state.allowIn = previousAllowIn;\n\n        return expr;\n    }\n\n    function parseLeftHandSideExpression() {\n        var quasi, expr, property, startToken;\n        assert(state.allowIn, 'callee of new expression always allow in keyword.');\n\n        startToken = lookahead;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('[') && !match('.')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        return expr;\n    }\n\n    // 11.3 Postfix Expressions\n\n    function parsePostfixExpression() {\n        var expr, token, startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseLeftHandSideExpressionAllowCall);\n\n        if (!hasLineTerminator && lookahead.type === Token.Punctuator) {\n            if (match('++') || match('--')) {\n                // 11.3.1, 11.3.2\n                if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                    tolerateError(Messages.StrictLHSPostfix);\n                }\n\n                if (!isAssignmentTarget) {\n                    tolerateError(Messages.InvalidLHSInAssignment);\n                }\n\n                isAssignmentTarget = isBindingElement = false;\n\n                token = lex();\n                expr = new WrappingNode(startToken).finishPostfixExpression(token.value, expr);\n            }\n        }\n\n        return expr;\n    }\n\n    // 11.4 Unary Operators\n\n    function parseUnaryExpression() {\n        var token, expr, startToken;\n\n        if (lookahead.type !== Token.Punctuator && lookahead.type !== Token.Keyword) {\n            expr = parsePostfixExpression();\n        } else if (match('++') || match('--')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            // 11.4.4, 11.4.5\n            if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                tolerateError(Messages.StrictLHSPrefix);\n            }\n\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (match('+') || match('-') || match('~') || match('!')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (matchKeyword('delete') || matchKeyword('void') || matchKeyword('typeof')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            if (strict && expr.operator === 'delete' && expr.argument.type === Syntax.Identifier) {\n                tolerateError(Messages.StrictDelete);\n            }\n            isAssignmentTarget = isBindingElement = false;\n        } else {\n            expr = parsePostfixExpression();\n        }\n\n        return expr;\n    }\n\n    function binaryPrecedence(token, allowIn) {\n        var prec = 0;\n\n        if (token.type !== Token.Punctuator && token.type !== Token.Keyword) {\n            return 0;\n        }\n\n        switch (token.value) {\n        case '||':\n            prec = 1;\n            break;\n\n        case '&&':\n            prec = 2;\n            break;\n\n        case '|':\n            prec = 3;\n            break;\n\n        case '^':\n            prec = 4;\n            break;\n\n        case '&':\n            prec = 5;\n            break;\n\n        case '==':\n        case '!=':\n        case '===':\n        case '!==':\n            prec = 6;\n            break;\n\n        case '<':\n        case '>':\n        case '<=':\n        case '>=':\n        case 'instanceof':\n            prec = 7;\n            break;\n\n        case 'in':\n            prec = allowIn ? 7 : 0;\n            break;\n\n        case '<<':\n        case '>>':\n        case '>>>':\n            prec = 8;\n            break;\n\n        case '+':\n        case '-':\n            prec = 9;\n            break;\n\n        case '*':\n        case '/':\n        case '%':\n            prec = 11;\n            break;\n\n        default:\n            break;\n        }\n\n        return prec;\n    }\n\n    // 11.5 Multiplicative Operators\n    // 11.6 Additive Operators\n    // 11.7 Bitwise Shift Operators\n    // 11.8 Relational Operators\n    // 11.9 Equality Operators\n    // 11.10 Binary Bitwise Operators\n    // 11.11 Binary Logical Operators\n\n    function parseBinaryExpression() {\n        var marker, markers, expr, token, prec, stack, right, operator, left, i;\n\n        marker = lookahead;\n        left = inheritCoverGrammar(parseUnaryExpression);\n\n        token = lookahead;\n        prec = binaryPrecedence(token, state.allowIn);\n        if (prec === 0) {\n            return left;\n        }\n        isAssignmentTarget = isBindingElement = false;\n        token.prec = prec;\n        lex();\n\n        markers = [marker, lookahead];\n        right = isolateCoverGrammar(parseUnaryExpression);\n\n        stack = [left, token, right];\n\n        while ((prec = binaryPrecedence(lookahead, state.allowIn)) > 0) {\n\n            // Reduce: make a binary expression from the three topmost entries.\n            while ((stack.length > 2) && (prec <= stack[stack.length - 2].prec)) {\n                right = stack.pop();\n                operator = stack.pop().value;\n                left = stack.pop();\n                markers.pop();\n                expr = new WrappingNode(markers[markers.length - 1]).finishBinaryExpression(operator, left, right);\n                stack.push(expr);\n            }\n\n            // Shift.\n            token = lex();\n            token.prec = prec;\n            stack.push(token);\n            markers.push(lookahead);\n            expr = isolateCoverGrammar(parseUnaryExpression);\n            stack.push(expr);\n        }\n\n        // Final reduce to clean-up the stack.\n        i = stack.length - 1;\n        expr = stack[i];\n        markers.pop();\n        while (i > 1) {\n            expr = new WrappingNode(markers.pop()).finishBinaryExpression(stack[i - 1].value, stack[i - 2], expr);\n            i -= 2;\n        }\n\n        return expr;\n    }\n\n\n    // 11.12 Conditional Operator\n\n    function parseConditionalExpression() {\n        var expr, previousAllowIn, consequent, alternate, startToken;\n\n        startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseBinaryExpression);\n        if (match('?')) {\n            lex();\n            previousAllowIn = state.allowIn;\n            state.allowIn = true;\n            consequent = isolateCoverGrammar(parseAssignmentExpression);\n            state.allowIn = previousAllowIn;\n            expect(':');\n            alternate = isolateCoverGrammar(parseAssignmentExpression);\n\n            expr = new WrappingNode(startToken).finishConditionalExpression(expr, consequent, alternate);\n            isAssignmentTarget = isBindingElement = false;\n        }\n\n        return expr;\n    }\n\n    // [ES6] 14.2 Arrow Function\n\n    function parseConciseBody() {\n        if (match('{')) {\n            return parseFunctionSourceElements();\n        }\n        return isolateCoverGrammar(parseAssignmentExpression);\n    }\n\n    function checkPatternParam(options, param) {\n        var i;\n        switch (param.type) {\n        case Syntax.Identifier:\n            validateParam(options, param, param.name);\n            break;\n        case Syntax.RestElement:\n            checkPatternParam(options, param.argument);\n            break;\n        case Syntax.AssignmentPattern:\n            checkPatternParam(options, param.left);\n            break;\n        case Syntax.ArrayPattern:\n            for (i = 0; i < param.elements.length; i++) {\n                if (param.elements[i] !== null) {\n                    checkPatternParam(options, param.elements[i]);\n                }\n            }\n            break;\n        default:\n            assert(param.type === Syntax.ObjectPattern, 'Invalid type');\n            for (i = 0; i < param.properties.length; i++) {\n                checkPatternParam(options, param.properties[i].value);\n            }\n            break;\n        }\n    }\n    function reinterpretAsCoverFormalsList(expr) {\n        var i, len, param, params, defaults, defaultCount, options, token;\n\n        defaults = [];\n        defaultCount = 0;\n        params = [expr];\n\n        switch (expr.type) {\n        case Syntax.Identifier:\n            break;\n        case PlaceHolders.ArrowParameterPlaceHolder:\n            params = expr.params;\n            break;\n        default:\n            return null;\n        }\n\n        options = {\n            paramSet: {}\n        };\n\n        for (i = 0, len = params.length; i < len; i += 1) {\n            param = params[i];\n            switch (param.type) {\n            case Syntax.AssignmentPattern:\n                params[i] = param.left;\n                defaults.push(param.right);\n                ++defaultCount;\n                checkPatternParam(options, param.left);\n                break;\n            default:\n                checkPatternParam(options, param);\n                params[i] = param;\n                defaults.push(null);\n                break;\n            }\n        }\n\n        if (options.message === Messages.StrictParamDupe) {\n            token = strict ? options.stricted : options.firstRestricted;\n            throwUnexpectedToken(token, options.message);\n        }\n\n        if (defaultCount === 0) {\n            defaults = [];\n        }\n\n        return {\n            params: params,\n            defaults: defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseArrowFunctionExpression(options, node) {\n        var previousStrict, body;\n\n        if (hasLineTerminator) {\n            tolerateUnexpectedToken(lookahead);\n        }\n        expect('=>');\n        previousStrict = strict;\n\n        body = parseConciseBody();\n\n        if (strict && options.firstRestricted) {\n            throwUnexpectedToken(options.firstRestricted, options.message);\n        }\n        if (strict && options.stricted) {\n            tolerateUnexpectedToken(options.stricted, options.message);\n        }\n\n        strict = previousStrict;\n\n        return node.finishArrowFunctionExpression(options.params, options.defaults, body, body.type !== Syntax.BlockStatement);\n    }\n\n    // 11.13 Assignment Operators\n\n    function parseAssignmentExpression() {\n        var token, expr, right, list, startToken;\n\n        startToken = lookahead;\n        token = lookahead;\n\n        expr = parseConditionalExpression();\n\n        if (expr.type === PlaceHolders.ArrowParameterPlaceHolder || match('=>')) {\n            isAssignmentTarget = isBindingElement = false;\n            list = reinterpretAsCoverFormalsList(expr);\n\n            if (list) {\n                firstCoverInitializedNameError = null;\n                return parseArrowFunctionExpression(list, new WrappingNode(startToken));\n            }\n\n            return expr;\n        }\n\n        if (matchAssign()) {\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n\n            // 11.13.1\n            if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                tolerateUnexpectedToken(token, Messages.StrictLHSAssignment);\n            }\n\n            if (!match('=')) {\n                isAssignmentTarget = isBindingElement = false;\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            token = lex();\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            expr = new WrappingNode(startToken).finishAssignmentExpression(token.value, expr, right);\n            firstCoverInitializedNameError = null;\n        }\n\n        return expr;\n    }\n\n    // 11.14 Comma Operator\n\n    function parseExpression() {\n        var expr, startToken = lookahead, expressions;\n\n        expr = isolateCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n                expressions.push(isolateCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n        return expr;\n    }\n\n    // 12.1 Block\n\n    function parseStatementListItem() {\n        if (lookahead.type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'export':\n                if (sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalExportDeclaration);\n                }\n                return parseExportDeclaration();\n            case 'import':\n                if (sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalImportDeclaration);\n                }\n                return parseImportDeclaration();\n            case 'const':\n            case 'let':\n                return parseLexicalDeclaration({inFor: false});\n            case 'function':\n                return parseFunctionDeclaration(new Node());\n            case 'class':\n                return parseClassDeclaration();\n            }\n        }\n\n        return parseStatement();\n    }\n\n    function parseStatementList() {\n        var list = [];\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            list.push(parseStatementListItem());\n        }\n\n        return list;\n    }\n\n    function parseBlock() {\n        var block, node = new Node();\n\n        expect('{');\n\n        block = parseStatementList();\n\n        expect('}');\n\n        return node.finishBlockStatement(block);\n    }\n\n    // 12.2 Variable Statement\n\n    function parseVariableIdentifier() {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (token.type !== Token.Identifier) {\n            if (strict && token.type === Token.Keyword && isStrictModeReservedWord(token.value)) {\n                tolerateUnexpectedToken(token, Messages.StrictReservedWord);\n            } else {\n                throwUnexpectedToken(token);\n            }\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseVariableDeclaration() {\n        var init = null, id, node = new Node();\n\n        id = parsePattern();\n\n        // 12.2.1\n        if (strict && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (match('=')) {\n            lex();\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        } else if (id.type !== Syntax.Identifier) {\n            expect('=');\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseVariableDeclarationList() {\n        var list = [];\n\n        do {\n            list.push(parseVariableDeclaration());\n            if (!match(',')) {\n                break;\n            }\n            lex();\n        } while (startIndex < length);\n\n        return list;\n    }\n\n    function parseVariableStatement(node) {\n        var declarations;\n\n        expectKeyword('var');\n\n        declarations = parseVariableDeclarationList();\n\n        consumeSemicolon();\n\n        return node.finishVariableDeclaration(declarations);\n    }\n\n    function parseLexicalBinding(kind, options) {\n        var init = null, id, node = new Node();\n\n        id = parsePattern();\n\n        // 12.2.1\n        if (strict && id.type === Syntax.Identifier && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (kind === 'const') {\n            if (!matchKeyword('in')) {\n                expect('=');\n                init = isolateCoverGrammar(parseAssignmentExpression);\n            }\n        } else if ((!options.inFor && id.type !== Syntax.Identifier) || match('=')) {\n            expect('=');\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseBindingList(kind, options) {\n        var list = [];\n\n        do {\n            list.push(parseLexicalBinding(kind, options));\n            if (!match(',')) {\n                break;\n            }\n            lex();\n        } while (startIndex < length);\n\n        return list;\n    }\n\n    function parseLexicalDeclaration(options) {\n        var kind, declarations, node = new Node();\n\n        kind = lex().value;\n        assert(kind === 'let' || kind === 'const', 'Lexical declaration must be either let or const');\n\n        declarations = parseBindingList(kind, options);\n\n        consumeSemicolon();\n\n        return node.finishLexicalDeclaration(declarations, kind);\n    }\n\n    function parseRestElement() {\n        var param, node = new Node();\n\n        lex();\n\n        if (match('{')) {\n            throwError(Messages.ObjectPatternAsRestParameter);\n        }\n\n        param = parseVariableIdentifier();\n\n        if (match('=')) {\n            throwError(Messages.DefaultRestParameter);\n        }\n\n        if (!match(')')) {\n            throwError(Messages.ParameterAfterRestParameter);\n        }\n\n        return node.finishRestElement(param);\n    }\n\n    // 12.3 Empty Statement\n\n    function parseEmptyStatement(node) {\n        expect(';');\n        return node.finishEmptyStatement();\n    }\n\n    // 12.4 Expression Statement\n\n    function parseExpressionStatement(node) {\n        var expr = parseExpression();\n        consumeSemicolon();\n        return node.finishExpressionStatement(expr);\n    }\n\n    // 12.5 If statement\n\n    function parseIfStatement(node) {\n        var test, consequent, alternate;\n\n        expectKeyword('if');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        consequent = parseStatement();\n\n        if (matchKeyword('else')) {\n            lex();\n            alternate = parseStatement();\n        } else {\n            alternate = null;\n        }\n\n        return node.finishIfStatement(test, consequent, alternate);\n    }\n\n    // 12.6 Iteration Statements\n\n    function parseDoWhileStatement(node) {\n        var body, test, oldInIteration;\n\n        expectKeyword('do');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        if (match(';')) {\n            lex();\n        }\n\n        return node.finishDoWhileStatement(body, test);\n    }\n\n    function parseWhileStatement(node) {\n        var test, body, oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        return node.finishWhileStatement(test, body);\n    }\n\n    function parseForStatement(node) {\n        var init, initSeq, initStartToken, test, update, left, right, kind, declarations,\n            body, oldInIteration, previousAllowIn = state.allowIn;\n\n        init = test = update = null;\n\n        expectKeyword('for');\n\n        expect('(');\n\n        if (match(';')) {\n            lex();\n        } else {\n            if (matchKeyword('var')) {\n                init = new Node();\n                lex();\n\n                state.allowIn = false;\n                init = init.finishVariableDeclaration(parseVariableDeclarationList());\n                state.allowIn = previousAllowIn;\n\n                if (init.declarations.length === 1 && matchKeyword('in')) {\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    expect(';');\n                }\n            } else if (matchKeyword('const') || matchKeyword('let')) {\n                init = new Node();\n                kind = lex().value;\n\n                state.allowIn = false;\n                declarations = parseBindingList(kind, {inFor: true});\n                state.allowIn = previousAllowIn;\n\n                if (declarations.length === 1 && declarations[0].init === null && matchKeyword('in')) {\n                    init = init.finishLexicalDeclaration(declarations, kind);\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    consumeSemicolon();\n                    init = init.finishLexicalDeclaration(declarations, kind);\n                }\n            } else {\n                initStartToken = lookahead;\n                state.allowIn = false;\n                init = inheritCoverGrammar(parseAssignmentExpression);\n                state.allowIn = previousAllowIn;\n\n                if (matchKeyword('in')) {\n                    if (!isAssignmentTarget) {\n                        tolerateError(Messages.InvalidLHSInForIn);\n                    }\n\n                    lex();\n                    reinterpretExpressionAsPattern(init);\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    if (match(',')) {\n                        initSeq = [init];\n                        while (match(',')) {\n                            lex();\n                            initSeq.push(isolateCoverGrammar(parseAssignmentExpression));\n                        }\n                        init = new WrappingNode(initStartToken).finishSequenceExpression(initSeq);\n                    }\n                    expect(';');\n                }\n            }\n        }\n\n        if (typeof left === 'undefined') {\n\n            if (!match(';')) {\n                test = parseExpression();\n            }\n            expect(';');\n\n            if (!match(')')) {\n                update = parseExpression();\n            }\n        }\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = isolateCoverGrammar(parseStatement);\n\n        state.inIteration = oldInIteration;\n\n        return (typeof left === 'undefined') ?\n                node.finishForStatement(init, test, update, body) :\n                node.finishForInStatement(left, right, body);\n    }\n\n    // 12.7 The continue statement\n\n    function parseContinueStatement(node) {\n        var label = null, key;\n\n        expectKeyword('continue');\n\n        // Optimize the most common form: 'continue;'.\n        if (source.charCodeAt(startIndex) === 0x3B) {\n            lex();\n\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !state.inIteration) {\n            throwError(Messages.IllegalContinue);\n        }\n\n        return node.finishContinueStatement(label);\n    }\n\n    // 12.8 The break statement\n\n    function parseBreakStatement(node) {\n        var label = null, key;\n\n        expectKeyword('break');\n\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(lastIndex) === 0x3B) {\n            lex();\n\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n\n            return node.finishBreakStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n\n            return node.finishBreakStatement(null);\n        }\n\n        if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !(state.inIteration || state.inSwitch)) {\n            throwError(Messages.IllegalBreak);\n        }\n\n        return node.finishBreakStatement(label);\n    }\n\n    // 12.9 The return statement\n\n    function parseReturnStatement(node) {\n        var argument = null;\n\n        expectKeyword('return');\n\n        if (!state.inFunctionBody) {\n            tolerateError(Messages.IllegalReturn);\n        }\n\n        // 'return' followed by a space and an identifier is very common.\n        if (source.charCodeAt(lastIndex) === 0x20) {\n            if (isIdentifierStart(source.charCodeAt(lastIndex + 1))) {\n                argument = parseExpression();\n                consumeSemicolon();\n                return node.finishReturnStatement(argument);\n            }\n        }\n\n        if (hasLineTerminator) {\n            // HACK\n            return node.finishReturnStatement(null);\n        }\n\n        if (!match(';')) {\n            if (!match('}') && lookahead.type !== Token.EOF) {\n                argument = parseExpression();\n            }\n        }\n\n        consumeSemicolon();\n\n        return node.finishReturnStatement(argument);\n    }\n\n    // 12.10 The with statement\n\n    function parseWithStatement(node) {\n        var object, body;\n\n        if (strict) {\n            tolerateError(Messages.StrictModeWith);\n        }\n\n        expectKeyword('with');\n\n        expect('(');\n\n        object = parseExpression();\n\n        expect(')');\n\n        body = parseStatement();\n\n        return node.finishWithStatement(object, body);\n    }\n\n    // 12.10 The swith statement\n\n    function parseSwitchCase() {\n        var test, consequent = [], statement, node = new Node();\n\n        if (matchKeyword('default')) {\n            lex();\n            test = null;\n        } else {\n            expectKeyword('case');\n            test = parseExpression();\n        }\n        expect(':');\n\n        while (startIndex < length) {\n            if (match('}') || matchKeyword('default') || matchKeyword('case')) {\n                break;\n            }\n            statement = parseStatementListItem();\n            consequent.push(statement);\n        }\n\n        return node.finishSwitchCase(test, consequent);\n    }\n\n    function parseSwitchStatement(node) {\n        var discriminant, cases, clause, oldInSwitch, defaultFound;\n\n        expectKeyword('switch');\n\n        expect('(');\n\n        discriminant = parseExpression();\n\n        expect(')');\n\n        expect('{');\n\n        cases = [];\n\n        if (match('}')) {\n            lex();\n            return node.finishSwitchStatement(discriminant, cases);\n        }\n\n        oldInSwitch = state.inSwitch;\n        state.inSwitch = true;\n        defaultFound = false;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            clause = parseSwitchCase();\n            if (clause.test === null) {\n                if (defaultFound) {\n                    throwError(Messages.MultipleDefaultsInSwitch);\n                }\n                defaultFound = true;\n            }\n            cases.push(clause);\n        }\n\n        state.inSwitch = oldInSwitch;\n\n        expect('}');\n\n        return node.finishSwitchStatement(discriminant, cases);\n    }\n\n    // 12.13 The throw statement\n\n    function parseThrowStatement(node) {\n        var argument;\n\n        expectKeyword('throw');\n\n        if (hasLineTerminator) {\n            throwError(Messages.NewlineAfterThrow);\n        }\n\n        argument = parseExpression();\n\n        consumeSemicolon();\n\n        return node.finishThrowStatement(argument);\n    }\n\n    // 12.14 The try statement\n\n    function parseCatchClause() {\n        var param, body, node = new Node();\n\n        expectKeyword('catch');\n\n        expect('(');\n        if (match(')')) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        param = parsePattern();\n\n        // 12.14.1\n        if (strict && isRestrictedWord(param.name)) {\n            tolerateError(Messages.StrictCatchVariable);\n        }\n\n        expect(')');\n        body = parseBlock();\n        return node.finishCatchClause(param, body);\n    }\n\n    function parseTryStatement(node) {\n        var block, handler = null, finalizer = null;\n\n        expectKeyword('try');\n\n        block = parseBlock();\n\n        if (matchKeyword('catch')) {\n            handler = parseCatchClause();\n        }\n\n        if (matchKeyword('finally')) {\n            lex();\n            finalizer = parseBlock();\n        }\n\n        if (!handler && !finalizer) {\n            throwError(Messages.NoCatchOrFinally);\n        }\n\n        return node.finishTryStatement(block, handler, finalizer);\n    }\n\n    // 12.15 The debugger statement\n\n    function parseDebuggerStatement(node) {\n        expectKeyword('debugger');\n\n        consumeSemicolon();\n\n        return node.finishDebuggerStatement();\n    }\n\n    // 12 Statements\n\n    function parseStatement() {\n        var type = lookahead.type,\n            expr,\n            labeledBody,\n            key,\n            node;\n\n        if (type === Token.EOF) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        if (type === Token.Punctuator && lookahead.value === '{') {\n            return parseBlock();\n        }\n        isAssignmentTarget = isBindingElement = true;\n        node = new Node();\n\n        if (type === Token.Punctuator) {\n            switch (lookahead.value) {\n            case ';':\n                return parseEmptyStatement(node);\n            case '(':\n                return parseExpressionStatement(node);\n            default:\n                break;\n            }\n        } else if (type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'break':\n                return parseBreakStatement(node);\n            case 'continue':\n                return parseContinueStatement(node);\n            case 'debugger':\n                return parseDebuggerStatement(node);\n            case 'do':\n                return parseDoWhileStatement(node);\n            case 'for':\n                return parseForStatement(node);\n            case 'function':\n                return parseFunctionDeclaration(node);\n            case 'if':\n                return parseIfStatement(node);\n            case 'return':\n                return parseReturnStatement(node);\n            case 'switch':\n                return parseSwitchStatement(node);\n            case 'throw':\n                return parseThrowStatement(node);\n            case 'try':\n                return parseTryStatement(node);\n            case 'var':\n                return parseVariableStatement(node);\n            case 'while':\n                return parseWhileStatement(node);\n            case 'with':\n                return parseWithStatement(node);\n            default:\n                break;\n            }\n        }\n\n        expr = parseExpression();\n\n        // 12.12 Labelled Statements\n        if ((expr.type === Syntax.Identifier) && match(':')) {\n            lex();\n\n            key = '$' + expr.name;\n            if (Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.Redeclaration, 'Label', expr.name);\n            }\n\n            state.labelSet[key] = true;\n            labeledBody = parseStatement();\n            delete state.labelSet[key];\n            return node.finishLabeledStatement(expr, labeledBody);\n        }\n\n        consumeSemicolon();\n\n        return node.finishExpressionStatement(expr);\n    }\n\n    // 13 Function Definition\n\n    function parseFunctionSourceElements() {\n        var statement, body = [], token, directive, firstRestricted,\n            oldLabelSet, oldInIteration, oldInSwitch, oldInFunctionBody, oldParenthesisCount,\n            node = new Node();\n\n        expect('{');\n\n        while (startIndex < length) {\n            if (lookahead.type !== Token.StringLiteral) {\n                break;\n            }\n            token = lookahead;\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        oldLabelSet = state.labelSet;\n        oldInIteration = state.inIteration;\n        oldInSwitch = state.inSwitch;\n        oldInFunctionBody = state.inFunctionBody;\n        oldParenthesisCount = state.parenthesizedCount;\n\n        state.labelSet = {};\n        state.inIteration = false;\n        state.inSwitch = false;\n        state.inFunctionBody = true;\n        state.parenthesizedCount = 0;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            body.push(parseStatementListItem());\n        }\n\n        expect('}');\n\n        state.labelSet = oldLabelSet;\n        state.inIteration = oldInIteration;\n        state.inSwitch = oldInSwitch;\n        state.inFunctionBody = oldInFunctionBody;\n        state.parenthesizedCount = oldParenthesisCount;\n\n        return node.finishBlockStatement(body);\n    }\n\n    function validateParam(options, param, name) {\n        var key = '$' + name;\n        if (strict) {\n            if (isRestrictedWord(name)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamName;\n            }\n            if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        } else if (!options.firstRestricted) {\n            if (isRestrictedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictParamName;\n            } else if (isStrictModeReservedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictReservedWord;\n            } else if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        }\n        options.paramSet[key] = true;\n    }\n\n    function parseParam(options) {\n        var token, param, def;\n\n        token = lookahead;\n        if (token.value === '...') {\n            param = parseRestElement();\n            validateParam(options, param.argument, param.argument.name);\n            options.params.push(param);\n            options.defaults.push(null);\n            return false;\n        }\n\n        param = parsePatternWithDefault();\n        validateParam(options, token, token.value);\n\n        if (param.type === Syntax.AssignmentPattern) {\n            def = param.right;\n            param = param.left;\n            ++options.defaultCount;\n        }\n\n        options.params.push(param);\n        options.defaults.push(def);\n\n        return !match(')');\n    }\n\n    function parseParams(firstRestricted) {\n        var options;\n\n        options = {\n            params: [],\n            defaultCount: 0,\n            defaults: [],\n            firstRestricted: firstRestricted\n        };\n\n        expect('(');\n\n        if (!match(')')) {\n            options.paramSet = {};\n            while (startIndex < length) {\n                if (!parseParam(options)) {\n                    break;\n                }\n                expect(',');\n            }\n        }\n\n        expect(')');\n\n        if (options.defaultCount === 0) {\n            options.defaults = [];\n        }\n\n        return {\n            params: options.params,\n            defaults: options.defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseFunctionDeclaration(node, identifierIsOptional) {\n        var id = null, params = [], defaults = [], body, token, stricted, tmp, firstRestricted, message, previousStrict;\n\n        expectKeyword('function');\n        if (!identifierIsOptional || !match('(')) {\n            token = lookahead;\n            id = parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n        strict = previousStrict;\n\n        return node.finishFunctionDeclaration(id, params, defaults, body);\n    }\n\n    function parseFunctionExpression() {\n        var token, id = null, stricted, firstRestricted, message, tmp,\n            params = [], defaults = [], body, previousStrict, node = new Node();\n\n        expectKeyword('function');\n\n        if (!match('(')) {\n            token = lookahead;\n            id = parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n        strict = previousStrict;\n\n        return node.finishFunctionExpression(id, params, defaults, body);\n    }\n\n\n    function parseClassBody() {\n        var classBody, token, isStatic, hasConstructor = false, body, method, computed, key;\n\n        classBody = new Node();\n\n        expect('{');\n        body = [];\n        while (!match('}')) {\n            if (match(';')) {\n                lex();\n            } else {\n                method = new Node();\n                token = lookahead;\n                isStatic = false;\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                if (key.name === 'static' && lookaheadPropertyName()) {\n                    token = lookahead;\n                    isStatic = true;\n                    computed = match('[');\n                    key = parseObjectPropertyKey();\n                }\n                method = tryParseMethodDefinition(token, key, computed, method);\n                if (method) {\n                    method['static'] = isStatic;\n                    if (method.kind === 'init') {\n                        method.kind = 'method';\n                    }\n                    if (!isStatic) {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'constructor') {\n                            if (method.kind !== 'method' || !method.method || method.value.generator) {\n                                throwUnexpectedToken(token, Messages.ConstructorSpecialMethod);\n                            }\n                            if (hasConstructor) {\n                                throwUnexpectedToken(token, Messages.DuplicateConstructor);\n                            } else {\n                                hasConstructor = true;\n                            }\n                            method.kind = 'constructor';\n                        }\n                    } else {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'prototype') {\n                            throwUnexpectedToken(token, Messages.StaticPrototype);\n                        }\n                    }\n                    method.type = Syntax.MethodDefinition;\n                    delete method.method;\n                    delete method.shorthand;\n                    body.push(method);\n                } else {\n                    throwUnexpectedToken(lookahead);\n                }\n            }\n        }\n        lex();\n        return classBody.finishClassBody(body);\n    }\n\n    function parseClassDeclaration(identifierIsOptional) {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (!identifierIsOptional || lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassDeclaration(id, superClass, classBody);\n    }\n\n    function parseClassExpression() {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassExpression(id, superClass, classBody);\n    }\n\n    // Modules grammar from:\n    // people.mozilla.org/~jorendorff/es6-draft.html\n\n    function parseModuleSpecifier() {\n        var node = new Node();\n\n        if (lookahead.type !== Token.StringLiteral) {\n            throwError(Messages.InvalidModuleSpecifier);\n        }\n        return node.finishLiteral(lex());\n    }\n\n    function parseExportSpecifier() {\n        var exported, local, node = new Node(), def;\n        if (matchKeyword('default')) {\n            // export {default} from 'something';\n            def = new Node();\n            lex();\n            local = def.finishIdentifier('default');\n        } else {\n            local = parseVariableIdentifier();\n        }\n        if (matchContextualKeyword('as')) {\n            lex();\n            exported = parseNonComputedProperty();\n        }\n        return node.finishExportSpecifier(local, exported);\n    }\n\n    function parseExportNamedDeclaration(node) {\n        var declaration = null,\n            isExportFromIdentifier,\n            src = null, specifiers = [];\n\n        // non-default export\n        if (lookahead.type === Token.Keyword) {\n            // covers:\n            // export var f = 1;\n            switch (lookahead.value) {\n                case 'let':\n                case 'const':\n                case 'var':\n                case 'class':\n                case 'function':\n                    declaration = parseStatementListItem();\n                    return node.finishExportNamedDeclaration(declaration, specifiers, null);\n            }\n        }\n\n        expect('{');\n        if (!match('}')) {\n            do {\n                isExportFromIdentifier = isExportFromIdentifier || matchKeyword('default');\n                specifiers.push(parseExportSpecifier());\n            } while (match(',') && lex());\n        }\n        expect('}');\n\n        if (matchContextualKeyword('from')) {\n            // covering:\n            // export {default} from 'foo';\n            // export {foo} from 'foo';\n            lex();\n            src = parseModuleSpecifier();\n            consumeSemicolon();\n        } else if (isExportFromIdentifier) {\n            // covering:\n            // export {default}; // missing fromClause\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        } else {\n            // cover\n            // export {foo};\n            consumeSemicolon();\n        }\n        return node.finishExportNamedDeclaration(declaration, specifiers, src);\n    }\n\n    function parseExportDefaultDeclaration(node) {\n        var declaration = null,\n            expression = null;\n\n        // covers:\n        // export default ...\n        expectKeyword('default');\n\n        if (matchKeyword('function')) {\n            // covers:\n            // export default function foo () {}\n            // export default function () {}\n            declaration = parseFunctionDeclaration(new Node(), true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n        if (matchKeyword('class')) {\n            declaration = parseClassDeclaration(true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n\n        if (matchContextualKeyword('from')) {\n            throwError(Messages.UnexpectedToken, lookahead.value);\n        }\n\n        // covers:\n        // export default {};\n        // export default [];\n        // export default (1 + 2);\n        if (match('{')) {\n            expression = parseObjectInitialiser();\n        } else if (match('[')) {\n            expression = parseArrayInitialiser();\n        } else {\n            expression = parseAssignmentExpression();\n        }\n        consumeSemicolon();\n        return node.finishExportDefaultDeclaration(expression);\n    }\n\n    function parseExportAllDeclaration(node) {\n        var src;\n\n        // covers:\n        // export * from 'foo';\n        expect('*');\n        if (!matchContextualKeyword('from')) {\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        }\n        lex();\n        src = parseModuleSpecifier();\n        consumeSemicolon();\n\n        return node.finishExportAllDeclaration(src);\n    }\n\n    function parseExportDeclaration() {\n        var node = new Node();\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalExportDeclaration);\n        }\n\n        expectKeyword('export');\n\n        if (matchKeyword('default')) {\n            return parseExportDefaultDeclaration(node);\n        }\n        if (match('*')) {\n            return parseExportAllDeclaration(node);\n        }\n        return parseExportNamedDeclaration(node);\n    }\n\n    function parseImportSpecifier() {\n        // import {<foo as bar>} ...;\n        var local, imported, node = new Node();\n\n        imported = parseNonComputedProperty();\n        if (matchContextualKeyword('as')) {\n            lex();\n            local = parseVariableIdentifier();\n        }\n\n        return node.finishImportSpecifier(local, imported);\n    }\n\n    function parseNamedImports() {\n        var specifiers = [];\n        // {foo, bar as bas}\n        expect('{');\n        if (!match('}')) {\n            do {\n                specifiers.push(parseImportSpecifier());\n            } while (match(',') && lex());\n        }\n        expect('}');\n        return specifiers;\n    }\n\n    function parseImportDefaultSpecifier() {\n        // import <foo> ...;\n        var local, node = new Node();\n\n        local = parseNonComputedProperty();\n\n        return node.finishImportDefaultSpecifier(local);\n    }\n\n    function parseImportNamespaceSpecifier() {\n        // import <* as foo> ...;\n        var local, node = new Node();\n\n        expect('*');\n        if (!matchContextualKeyword('as')) {\n            throwError(Messages.NoAsAfterImportNamespace);\n        }\n        lex();\n        local = parseNonComputedProperty();\n\n        return node.finishImportNamespaceSpecifier(local);\n    }\n\n    function parseImportDeclaration() {\n        var specifiers, src, node = new Node();\n\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalImportDeclaration);\n        }\n\n        expectKeyword('import');\n        specifiers = [];\n\n        if (lookahead.type === Token.StringLiteral) {\n            // covers:\n            // import 'foo';\n            src = parseModuleSpecifier();\n            consumeSemicolon();\n            return node.finishImportDeclaration(specifiers, src);\n        }\n\n        if (!matchKeyword('default') && isIdentifierName(lookahead)) {\n            // covers:\n            // import foo\n            // import foo, ...\n            specifiers.push(parseImportDefaultSpecifier());\n            if (match(',')) {\n                lex();\n            }\n        }\n        if (match('*')) {\n            // covers:\n            // import foo, * as foo\n            // import * as foo\n            specifiers.push(parseImportNamespaceSpecifier());\n        } else if (match('{')) {\n            // covers:\n            // import foo, {bar}\n            // import {bar}\n            specifiers = specifiers.concat(parseNamedImports());\n        }\n\n        if (!matchContextualKeyword('from')) {\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        }\n        lex();\n        src = parseModuleSpecifier();\n        consumeSemicolon();\n\n        return node.finishImportDeclaration(specifiers, src);\n    }\n\n    // 14 Program\n\n    function parseScriptBody() {\n        var statement, body = [], token, directive, firstRestricted;\n\n        while (startIndex < length) {\n            token = lookahead;\n            if (token.type !== Token.StringLiteral) {\n                break;\n            }\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        while (startIndex < length) {\n            statement = parseStatementListItem();\n            /* istanbul ignore if */\n            if (typeof statement === 'undefined') {\n                break;\n            }\n            body.push(statement);\n        }\n        return body;\n    }\n\n    function parseProgram() {\n        var body, node;\n\n        peek();\n        node = new Node();\n\n        body = parseScriptBody();\n        return node.finishProgram(body);\n    }\n\n    function filterTokenLocation() {\n        var i, entry, token, tokens = [];\n\n        for (i = 0; i < extra.tokens.length; ++i) {\n            entry = extra.tokens[i];\n            token = {\n                type: entry.type,\n                value: entry.value\n            };\n            if (entry.regex) {\n                token.regex = {\n                    pattern: entry.regex.pattern,\n                    flags: entry.regex.flags\n                };\n            }\n            if (extra.range) {\n                token.range = entry.range;\n            }\n            if (extra.loc) {\n                token.loc = entry.loc;\n            }\n            tokens.push(token);\n        }\n\n        extra.tokens = tokens;\n    }\n\n    function tokenize(code, options) {\n        var toString,\n            tokens;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: []\n        };\n\n        extra = {};\n\n        // Options matching.\n        options = options || {};\n\n        // Of course we collect tokens here.\n        options.tokens = true;\n        extra.tokens = [];\n        extra.tokenize = true;\n        // The following two fields are necessary to compute the Regex tokens.\n        extra.openParenToken = -1;\n        extra.openCurlyToken = -1;\n\n        extra.range = (typeof options.range === 'boolean') && options.range;\n        extra.loc = (typeof options.loc === 'boolean') && options.loc;\n\n        if (typeof options.comment === 'boolean' && options.comment) {\n            extra.comments = [];\n        }\n        if (typeof options.tolerant === 'boolean' && options.tolerant) {\n            extra.errors = [];\n        }\n\n        try {\n            peek();\n            if (lookahead.type === Token.EOF) {\n                return extra.tokens;\n            }\n\n            lex();\n            while (lookahead.type !== Token.EOF) {\n                try {\n                    lex();\n                } catch (lexError) {\n                    if (extra.errors) {\n                        recordError(lexError);\n                        // We have to break on the first error\n                        // to avoid infinite loops.\n                        break;\n                    } else {\n                        throw lexError;\n                    }\n                }\n            }\n\n            filterTokenLocation();\n            tokens = extra.tokens;\n            if (typeof extra.comments !== 'undefined') {\n                tokens.comments = extra.comments;\n            }\n            if (typeof extra.errors !== 'undefined') {\n                tokens.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n        return tokens;\n    }\n\n    function parse(code, options) {\n        var program, toString;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: []\n        };\n        sourceType = 'script';\n        strict = false;\n\n        extra = {};\n        if (typeof options !== 'undefined') {\n            extra.range = (typeof options.range === 'boolean') && options.range;\n            extra.loc = (typeof options.loc === 'boolean') && options.loc;\n            extra.attachComment = (typeof options.attachComment === 'boolean') && options.attachComment;\n\n            if (extra.loc && options.source !== null && options.source !== undefined) {\n                extra.source = toString(options.source);\n            }\n\n            if (typeof options.tokens === 'boolean' && options.tokens) {\n                extra.tokens = [];\n            }\n            if (typeof options.comment === 'boolean' && options.comment) {\n                extra.comments = [];\n            }\n            if (typeof options.tolerant === 'boolean' && options.tolerant) {\n                extra.errors = [];\n            }\n            if (extra.attachComment) {\n                extra.range = true;\n                extra.comments = [];\n                extra.bottomRightStack = [];\n                extra.trailingComments = [];\n                extra.leadingComments = [];\n            }\n            if (options.sourceType === 'module') {\n                // very restrictive condition for now\n                sourceType = options.sourceType;\n                strict = true;\n            }\n        }\n\n        try {\n            program = parseProgram();\n            if (typeof extra.comments !== 'undefined') {\n                program.comments = extra.comments;\n            }\n            if (typeof extra.tokens !== 'undefined') {\n                filterTokenLocation();\n                program.tokens = extra.tokens;\n            }\n            if (typeof extra.errors !== 'undefined') {\n                program.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n\n        return program;\n    }\n\n    // Sync with *.json manifests.\n    exports.version = '2.2.0';\n\n    exports.tokenize = tokenize;\n\n    exports.parse = parse;\n\n    // Deep copy.\n    /* istanbul ignore next */\n    exports.Syntax = (function () {\n        var name, types = {};\n\n        if (typeof Object.create === 'function') {\n            types = Object.create(null);\n        }\n\n        for (name in Syntax) {\n            if (Syntax.hasOwnProperty(name)) {\n                types[name] = Syntax[name];\n            }\n        }\n\n        if (typeof Object.freeze === 'function') {\n            Object.freeze(types);\n        }\n\n        return types;\n    }());\n\n}));\n/* vim: set sw=4 ts=4 et tw=80 : */\n","/*\r\n* loglevel - https://github.com/pimterry/loglevel\r\n*\r\n* Copyright (c) 2013 Tim Perry\r\n* Licensed under the MIT license.\r\n*/\r\n(function (root, definition) {\r\n    if (typeof module === 'object' && module.exports && typeof require === 'function') {\r\n        module.exports = definition();\r\n    } else if (typeof define === 'function' && typeof define.amd === 'object') {\r\n        define(definition);\r\n    } else {\r\n        root.log = definition();\r\n    }\r\n}(this, function () {\r\n    var self = {};\r\n    var noop = function() {};\r\n    var undefinedType = \"undefined\";\r\n\r\n    function realMethod(methodName) {\r\n        if (typeof console === undefinedType) {\r\n            return false; // We can't build a real method without a console to log to\r\n        } else if (console[methodName] !== undefined) {\r\n            return bindMethod(console, methodName);\r\n        } else if (console.log !== undefined) {\r\n            return bindMethod(console, 'log');\r\n        } else {\r\n            return noop;\r\n        }\r\n    }\r\n\r\n    function bindMethod(obj, methodName) {\r\n        var method = obj[methodName];\r\n        if (typeof method.bind === 'function') {\r\n            return method.bind(obj);\r\n        } else {\r\n            try {\r\n                return Function.prototype.bind.call(method, obj);\r\n            } catch (e) {\r\n                // Missing bind shim or IE8 + Modernizr, fallback to wrapping\r\n                return function() {\r\n                    return Function.prototype.apply.apply(method, [obj, arguments]);\r\n                };\r\n            }\r\n        }\r\n    }\r\n\r\n    function enableLoggingWhenConsoleArrives(methodName, level) {\r\n        return function () {\r\n            if (typeof console !== undefinedType) {\r\n                replaceLoggingMethods(level);\r\n                self[methodName].apply(self, arguments);\r\n            }\r\n        };\r\n    }\r\n\r\n    var logMethods = [\r\n        \"trace\",\r\n        \"debug\",\r\n        \"info\",\r\n        \"warn\",\r\n        \"error\"\r\n    ];\r\n\r\n    function replaceLoggingMethods(level) {\r\n        for (var i = 0; i < logMethods.length; i++) {\r\n            var methodName = logMethods[i];\r\n            self[methodName] = (i < level) ? noop : self.methodFactory(methodName, level);\r\n        }\r\n    }\r\n\r\n    function persistLevelIfPossible(levelNum) {\r\n        var levelName = (logMethods[levelNum] || 'silent').toUpperCase();\r\n\r\n        // Use localStorage if available\r\n        try {\r\n            window.localStorage['loglevel'] = levelName;\r\n            return;\r\n        } catch (ignore) {}\r\n\r\n        // Use session cookie as fallback\r\n        try {\r\n            window.document.cookie = \"loglevel=\" + levelName + \";\";\r\n        } catch (ignore) {}\r\n    }\r\n\r\n    function loadPersistedLevel() {\r\n        var storedLevel;\r\n\r\n        try {\r\n            storedLevel = window.localStorage['loglevel'];\r\n        } catch (ignore) {}\r\n\r\n        if (typeof storedLevel === undefinedType) {\r\n            try {\r\n                storedLevel = /loglevel=([^;]+)/.exec(window.document.cookie)[1];\r\n            } catch (ignore) {}\r\n        }\r\n        \r\n        if (self.levels[storedLevel] === undefined) {\r\n            storedLevel = \"WARN\";\r\n        }\r\n\r\n        self.setLevel(self.levels[storedLevel]);\r\n    }\r\n\r\n    /*\r\n     *\r\n     * Public API\r\n     *\r\n     */\r\n\r\n    self.levels = { \"TRACE\": 0, \"DEBUG\": 1, \"INFO\": 2, \"WARN\": 3,\r\n        \"ERROR\": 4, \"SILENT\": 5};\r\n\r\n    self.methodFactory = function (methodName, level) {\r\n        return realMethod(methodName) ||\r\n               enableLoggingWhenConsoleArrives(methodName, level);\r\n    };\r\n\r\n    self.setLevel = function (level) {\r\n        if (typeof level === \"string\" && self.levels[level.toUpperCase()] !== undefined) {\r\n            level = self.levels[level.toUpperCase()];\r\n        }\r\n        if (typeof level === \"number\" && level >= 0 && level <= self.levels.SILENT) {\r\n            persistLevelIfPossible(level);\r\n            replaceLoggingMethods(level);\r\n            if (typeof console === undefinedType && level < self.levels.SILENT) {\r\n                return \"No console available for logging\";\r\n            }\r\n        } else {\r\n            throw \"log.setLevel() called with invalid level: \" + level;\r\n        }\r\n    };\r\n\r\n    self.enableAll = function() {\r\n        self.setLevel(self.levels.TRACE);\r\n    };\r\n\r\n    self.disableAll = function() {\r\n        self.setLevel(self.levels.SILENT);\r\n    };\r\n\r\n    // Grab the current global log variable in case of overwrite\r\n    var _log = (typeof window !== undefinedType) ? window.log : undefined;\r\n    self.noConflict = function() {\r\n        if (typeof window !== undefinedType &&\r\n               window.log === self) {\r\n            window.log = _log;\r\n        }\r\n\r\n        return self;\r\n    };\r\n\r\n    loadPersistedLevel();\r\n    return self;\r\n}));\r\n","'use strict';\n\nvar whiteList = ['not', 'any', 'all', 'none'];\n\n\nfunction notNull(x)  { return x != null; }\nfunction toString(x) { return x.toString(); }\nfunction wrap(x)     { return '(' + x + ')';}\n\nfunction maybeQuote(value) {\n    if (typeof value === 'string') {\n        return '\"' + value + '\"';\n    }\n    return value;\n}\n\nfunction lookUp(key) {\n    if (key.lastIndexOf('$') === 0) {\n        return 'context.' + key.substring(1);\n    }\n    return 'context.feature.properties.' + key;\n}\n\nfunction nullValue(key, value) {\n    return {\n        type: 'nullValue',\n        key: key,\n        toString: function () {\n            return ' true ';\n        }\n    };\n}\n\nfunction propertyEqual(key, value) {\n    return {\n        type: 'propertyEqual',\n        opt: '===' ,\n        key: key,\n        value: value,\n        toString: function () {\n            return wrap(maybeQuote(this.value) + ' ' + this.opt + ' ' + lookUp(key));\n        }\n    };\n}\n\nfunction propertyOr(key, values) {\n    return {\n        type: 'propertyOr',\n        key: key,\n        values: values.map(function (x) { return propertyEqual(key, x); }),\n        toString: function () {\n            return wrap(this.values.map(toString).join(' || '));\n        }\n    };\n}\n\nfunction not(key, value) {\n    return {\n        type: 'notProperty',\n        key: key,\n        value: parseFilter(value),\n        toString: function () {\n            return '!' + wrap(this.value.toString());\n        }\n    };\n}\n\nfunction none(key, values) {\n    return {\n        type: 'none',\n        values: any(null, values),\n        toString: function () {\n            return '!' + wrap(this.values.toString());\n        }\n    };\n}\n\nfunction printNested(values, joiner) {\n    return wrap(values.filter(notNull).map(function (x) {\n        return wrap(x.join(' && '));\n    }).join(' ' + joiner + ' '));\n}\n\nfunction any(_, values) {\n    return {\n        type: 'any',\n        values: values.map(parseFilter),\n        toString: function () {\n            return printNested(this.values, '||');\n        }\n    };\n}\n\nfunction all(_, values) {\n    return {\n        type: 'all',\n        values: values.filter(notNull).map(parseFilter),\n        toString: function () {\n            return printNested(this.values, '&&');\n        }\n    };\n}\n\nfunction propertyMatchesBoolean(key, value) {\n    return {\n        type: 'propertyMatchesBoolean',\n        key: key,\n        value: value,\n        toString: function () {\n            return wrap(lookUp(this.key) + (this.value ? ' != ' : ' == ')  + 'null');\n        }\n    };\n}\n\nfunction rangeMatch(key, values) {\n    return {\n        type: 'rangeMatch',\n        key: key,\n        values: values,\n        toString: function () {\n            var expressions = [];\n\n            if (this.values.max) {\n                expressions.push('' + lookUp(key) + ' < ' + this.values.max);\n            }\n\n            if (this.values.min) {\n                expressions.push('' + lookUp(key) + ' >= ' + this.values.min);\n            }\n\n            return wrap(expressions.join(' && '));\n        }\n    };\n}\n\nfunction parseFilter(filter) {\n    var filterAST = [];\n\n    // Function filter\n    if (typeof filter === 'function') {\n        filterAST.push(wrap(filter.toString() + '(context)'));\n        return filterAST;\n    }\n\n    // Object filter\n    var keys = Object.keys(filter);\n    keys.forEach(function (key, idx) {\n\n        var value = filter[key],\n            type  = typeof value;\n        if (type === 'string' || type === 'number') {\n            filterAST.push(propertyEqual(key, value));\n        } else if (type === 'boolean') {\n            filterAST.push(propertyMatchesBoolean(key, value));\n        } else if (value == null) {\n            filterAST.push(nullValue(key, value));\n        } else if (whiteList.indexOf(key) >= 0) {\n            switch (key) {\n            case 'not':\n                filterAST.push(not(key, value));\n                break;\n            case 'any':\n                filterAST.push(any(key, value));\n                break;\n            case 'all':\n                filterAST.push(all(key, value));\n                break;\n            case 'none':\n                filterAST.push(none(key, value));\n                break;\n            default:\n                throw new Error('Unhandled WhiteListed property: ' + key);\n            }\n        } else if (Array.isArray(value)) {\n            filterAST.push(propertyOr(key, value));\n        } else if (type === 'object' && value != null) {\n            if (value.max || value.min) {\n                filterAST.push(rangeMatch(key, value));\n            }\n        } else {\n            throw new Error('Unknown Query sytnax: ' + value);\n        }\n    });\n\n    return keys.length === 0 ? ['true'] : filterAST;\n}\n\nfunction filterToString(filterAST) {\n    return wrap(filterAST.join(' && '));\n}\n\nfunction match(filter) {\n    if (filter == null) { return function () { return true; }; }\n    // jshint evil: true\n    return new Function('context', 'return ' + filterToString(parseFilter(filter)) + ';');\n}\n\nmodule.exports = {\n    match: match,\n    filterToString: filterToString,\n    parseFilter: parseFilter\n};\n","'use strict';\n\n// lightweight Buffer shim for pbf browser build\n// based on code from github.com/feross/buffer (MIT-licensed)\n\nmodule.exports = Buffer;\n\nvar ieee754 = require('ieee754');\n\nvar BufferMethods;\n\nfunction Buffer(length) {\n    var arr;\n    if (length && length.length) {\n        arr = length;\n        length = arr.length;\n    }\n    var buf = new Uint8Array(length || 0);\n    if (arr) buf.set(arr);\n\n    buf.readUInt32LE = BufferMethods.readUInt32LE;\n    buf.writeUInt32LE = BufferMethods.writeUInt32LE;\n    buf.readInt32LE = BufferMethods.readInt32LE;\n    buf.writeInt32LE = BufferMethods.writeInt32LE;\n    buf.readFloatLE = BufferMethods.readFloatLE;\n    buf.writeFloatLE = BufferMethods.writeFloatLE;\n    buf.readDoubleLE = BufferMethods.readDoubleLE;\n    buf.writeDoubleLE = BufferMethods.writeDoubleLE;\n    buf.toString = BufferMethods.toString;\n    buf.write = BufferMethods.write;\n    buf.slice = BufferMethods.slice;\n    buf.copy = BufferMethods.copy;\n\n    buf._isBuffer = true;\n    return buf;\n}\n\nvar lastStr, lastStrEncoded;\n\nBufferMethods = {\n    readUInt32LE: function(pos) {\n        return ((this[pos]) |\n            (this[pos + 1] << 8) |\n            (this[pos + 2] << 16)) +\n            (this[pos + 3] * 0x1000000);\n    },\n\n    writeUInt32LE: function(val, pos) {\n        this[pos] = val;\n        this[pos + 1] = (val >>> 8);\n        this[pos + 2] = (val >>> 16);\n        this[pos + 3] = (val >>> 24);\n    },\n\n    readInt32LE: function(pos) {\n        return ((this[pos]) |\n            (this[pos + 1] << 8) |\n            (this[pos + 2] << 16)) +\n            (this[pos + 3] << 24);\n    },\n\n    readFloatLE:  function(pos) { return ieee754.read(this, pos, true, 23, 4); },\n    readDoubleLE: function(pos) { return ieee754.read(this, pos, true, 52, 8); },\n\n    writeFloatLE:  function(val, pos) { return ieee754.write(this, val, pos, true, 23, 4); },\n    writeDoubleLE: function(val, pos) { return ieee754.write(this, val, pos, true, 52, 8); },\n\n    toString: function(encoding, start, end) {\n        var str = '',\n            tmp = '';\n\n        start = start || 0;\n        end = Math.min(this.length, end || this.length);\n\n        for (var i = start; i < end; i++) {\n            var ch = this[i];\n            if (ch <= 0x7F) {\n                str += decodeURIComponent(tmp) + String.fromCharCode(ch);\n                tmp = '';\n            } else {\n                tmp += '%' + ch.toString(16);\n            }\n        }\n\n        str += decodeURIComponent(tmp);\n\n        return str;\n    },\n\n    write: function(str, pos) {\n        var bytes = str === lastStr ? lastStrEncoded : encodeString(str);\n        for (var i = 0; i < bytes.length; i++) {\n            this[pos + i] = bytes[i];\n        }\n    },\n\n    slice: function(start, end) {\n        return this.subarray(start, end);\n    },\n\n    copy: function(buf, pos) {\n        pos = pos || 0;\n        for (var i = 0; i < this.length; i++) {\n            buf[pos + i] = this[i];\n        }\n    }\n};\n\nBufferMethods.writeInt32LE = BufferMethods.writeUInt32LE;\n\nBuffer.byteLength = function(str) {\n    lastStr = str;\n    lastStrEncoded = encodeString(str);\n    return lastStrEncoded.length;\n};\n\nBuffer.isBuffer = function(buf) {\n    return !!(buf && buf._isBuffer);\n};\n\nfunction encodeString(str) {\n    var length = str.length,\n        bytes = [];\n\n    for (var i = 0, c, lead; i < length; i++) {\n        c = str.charCodeAt(i); // code point\n\n        if (c > 0xD7FF && c < 0xE000) {\n\n            if (lead) {\n                if (c < 0xDC00) {\n                    bytes.push(0xEF, 0xBF, 0xBD);\n                    lead = c;\n                    continue;\n\n                } else {\n                    c = lead - 0xD800 << 10 | c - 0xDC00 | 0x10000;\n                    lead = null;\n                }\n\n            } else {\n                if (c > 0xDBFF || (i + 1 === length)) bytes.push(0xEF, 0xBF, 0xBD);\n                else lead = c;\n\n                continue;\n            }\n\n        } else if (lead) {\n            bytes.push(0xEF, 0xBF, 0xBD);\n            lead = null;\n        }\n\n        if (c < 0x80) bytes.push(c);\n        else if (c < 0x800) bytes.push(c >> 0x6 | 0xC0, c & 0x3F | 0x80);\n        else if (c < 0x10000) bytes.push(c >> 0xC | 0xE0, c >> 0x6 & 0x3F | 0x80, c & 0x3F | 0x80);\n        else bytes.push(c >> 0x12 | 0xF0, c >> 0xC & 0x3F | 0x80, c >> 0x6 & 0x3F | 0x80, c & 0x3F | 0x80);\n    }\n    return bytes;\n}\n","(function (global){\n'use strict';\n\nmodule.exports = Pbf;\n\nvar Buffer = global.Buffer || require('./buffer');\n\nfunction Pbf(buf) {\n    this.buf = !Buffer.isBuffer(buf) ? new Buffer(buf || 0) : buf;\n    this.pos = 0;\n    this.length = this.buf.length;\n}\n\nPbf.Varint  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n    SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32,\n    POW_2_63 = Math.pow(2, 63);\n\nPbf.prototype = {\n\n    destroy: function() {\n        this.buf = null;\n    },\n\n    // === READING =================================================================\n\n    readFields: function(readField, result, end) {\n        end = end || this.length;\n\n        while (this.pos < end) {\n            var val = this.readVarint(),\n                tag = val >> 3,\n                startPos = this.pos;\n\n            readField(tag, result, this);\n\n            if (this.pos === startPos) this.skip(val);\n        }\n        return result;\n    },\n\n    readMessage: function(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    },\n\n    readFixed32: function() {\n        var val = this.buf.readUInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readSFixed32: function() {\n        var val = this.buf.readInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n    readFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readUInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readSFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readFloat: function() {\n        var val = this.buf.readFloatLE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readDouble: function() {\n        var val = this.buf.readDoubleLE(this.pos);\n        this.pos += 8;\n        return val;\n    },\n\n    readVarint: function() {\n        var buf = this.buf,\n            val, b, b0, b1, b2, b3;\n\n        b0 = buf[this.pos++]; if (b0 < 0x80) return b0;                 b0 = b0 & 0x7f;\n        b1 = buf[this.pos++]; if (b1 < 0x80) return b0 | b1 << 7;       b1 = (b1 & 0x7f) << 7;\n        b2 = buf[this.pos++]; if (b2 < 0x80) return b0 | b1 | b2 << 14; b2 = (b2 & 0x7f) << 14;\n        b3 = buf[this.pos++]; if (b3 < 0x80) return b0 | b1 | b2 | b3 << 21;\n\n        val = b0 | b1 | b2 | (b3 & 0x7f) << 21;\n\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x10000000;         if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x800000000;        if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x40000000000;      if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x2000000000000;    if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x100000000000000;  if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x8000000000000000; if (b < 0x80) return val;\n\n        throw new Error('Expected varint not more than 10 bytes');\n    },\n\n    readVarint64: function() {\n        var startPos = this.pos,\n            val = this.readVarint();\n\n        if (val < POW_2_63) return val;\n\n        var pos = this.pos - 2;\n        while (this.buf[pos] === 0xff) pos--;\n        if (pos < startPos) pos = startPos;\n\n        val = 0;\n        for (var i = 0; i < pos - startPos + 1; i++) {\n            var b = ~this.buf[startPos + i] & 0x7f;\n            val += i < 4 ? b << i * 7 : b * Math.pow(2, i * 7);\n        }\n\n        return -val - 1;\n    },\n\n    readSVarint: function() {\n        var num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    },\n\n    readBoolean: function() {\n        return Boolean(this.readVarint());\n    },\n\n    readString: function() {\n        var end = this.readVarint() + this.pos,\n            str = this.buf.toString('utf8', this.pos, end);\n        this.pos = end;\n        return str;\n    },\n\n    readBytes: function() {\n        var end = this.readVarint() + this.pos,\n            buffer = this.buf.slice(this.pos, end);\n        this.pos = end;\n        return buffer;\n    },\n\n    // verbose for performance reasons; doesn't affect gzipped size\n\n    readPackedVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readVarint());\n        return arr;\n    },\n    readPackedSVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    },\n    readPackedBoolean: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    },\n    readPackedFloat: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    },\n    readPackedDouble: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    },\n    readPackedFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    },\n    readPackedSFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    },\n    readPackedFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    },\n    readPackedSFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    },\n\n    skip: function(val) {\n        var type = val & 0x7;\n        if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}\n        else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;\n        else if (type === Pbf.Fixed32) this.pos += 4;\n        else if (type === Pbf.Fixed64) this.pos += 8;\n        else throw new Error('Unimplemented type: ' + type);\n    },\n\n    // === WRITING =================================================================\n\n    writeTag: function(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    },\n\n    realloc: function(min) {\n        var length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            var buf = new Buffer(length);\n            this.buf.copy(buf);\n            this.buf = buf;\n            this.length = length;\n        }\n    },\n\n    finish: function() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.slice(0, this.length);\n    },\n\n    writeFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeUInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeSFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeUInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeSFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeVarint: function(val) {\n        val = +val;\n\n        if (val <= 0x7f) {\n            this.realloc(1);\n            this.buf[this.pos++] = val;\n\n        } else if (val <= 0x3fff) {\n            this.realloc(2);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f);\n\n        } else if (val <= 0x1fffff) {\n            this.realloc(3);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f);\n\n        } else if (val <= 0xfffffff) {\n            this.realloc(4);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 21) & 0x7f);\n\n        } else {\n            var pos = this.pos;\n            while (val >= 0x80) {\n                this.realloc(1);\n                this.buf[this.pos++] = (val & 0xff) | 0x80;\n                val /= 0x80;\n            }\n            this.realloc(1);\n            this.buf[this.pos++] = val | 0;\n            if (this.pos - pos > 10) throw new Error('Given varint doesn\\'t fit into 10 bytes');\n        }\n    },\n\n    writeSVarint: function(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    },\n\n    writeBoolean: function(val) {\n        this.writeVarint(Boolean(val));\n    },\n\n    writeString: function(str) {\n        str = String(str);\n        var bytes = Buffer.byteLength(str);\n        this.writeVarint(bytes);\n        this.realloc(bytes);\n        this.buf.write(str, this.pos);\n        this.pos += bytes;\n    },\n\n    writeFloat: function(val) {\n        this.realloc(4);\n        this.buf.writeFloatLE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeDouble: function(val) {\n        this.realloc(8);\n        this.buf.writeDoubleLE(val, this.pos);\n        this.pos += 8;\n    },\n\n    writeBytes: function(buffer) {\n        var len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    },\n\n    writeMessage: function(tag, fn, obj) {\n        this.writeTag(tag, Pbf.Bytes);\n\n        this.pos++; // reserve 1 byte for short message length\n\n        // write the message directly to the buffer and see how much was written\n        var startPos = this.pos;\n        fn(obj, this);\n        var len = this.pos - startPos;\n\n        var varintLen =\n            len <= 0x7f ? 1 :\n            len <= 0x3fff ? 2 :\n            len <= 0x1fffff ? 3 :\n            len <= 0xfffffff ? 4 : Math.ceil(Math.log(len) / (Math.LN2 * 7));\n\n        // if 1 byte isn't enough for encoding message length, shift the data to the right\n        if (varintLen > 1) {\n            this.realloc(varintLen - 1);\n            for (var i = this.pos - 1; i >= startPos; i--) this.buf[i + varintLen - 1] = this.buf[i];\n        }\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    },\n\n    writePackedVarint:   function(tag, arr) { this.writeMessage(tag, writePackedVarint, arr);   },\n    writePackedSVarint:  function(tag, arr) { this.writeMessage(tag, writePackedSVarint, arr);  },\n    writePackedBoolean:  function(tag, arr) { this.writeMessage(tag, writePackedBoolean, arr);  },\n    writePackedFloat:    function(tag, arr) { this.writeMessage(tag, writePackedFloat, arr);    },\n    writePackedDouble:   function(tag, arr) { this.writeMessage(tag, writePackedDouble, arr);   },\n    writePackedFixed32:  function(tag, arr) { this.writeMessage(tag, writePackedFixed32, arr);  },\n    writePackedSFixed32: function(tag, arr) { this.writeMessage(tag, writePackedSFixed32, arr); },\n    writePackedFixed64:  function(tag, arr) { this.writeMessage(tag, writePackedFixed64, arr);  },\n    writePackedSFixed64: function(tag, arr) { this.writeMessage(tag, writePackedSFixed64, arr); },\n\n    writeBytesField: function(tag, buffer) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeBytes(buffer);\n    },\n    writeFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFixed32(val);\n    },\n    writeSFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeSFixed32(val);\n    },\n    writeFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeFixed64(val);\n    },\n    writeSFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeSFixed64(val);\n    },\n    writeVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeVarint(val);\n    },\n    writeSVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeSVarint(val);\n    },\n    writeStringField: function(tag, str) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeString(str);\n    },\n    writeFloatField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFloat(val);\n    },\n    writeDoubleField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeDouble(val);\n    },\n    writeBooleanField: function(tag, val) {\n        this.writeVarintField(tag, Boolean(val));\n    }\n};\n\nfunction writePackedVarint(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);   }\nfunction writePackedSVarint(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);  }\nfunction writePackedFloat(arr, pbf)    { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);    }\nfunction writePackedDouble(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);   }\nfunction writePackedBoolean(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);  }\nfunction writePackedFixed32(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);  }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);  }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/pbf/index.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["'use strict';\n\nmodule.exports = Pbf;\n\nvar Buffer = global.Buffer || require('./buffer');\n\nfunction Pbf(buf) {\n    this.buf = !Buffer.isBuffer(buf) ? new Buffer(buf || 0) : buf;\n    this.pos = 0;\n    this.length = this.buf.length;\n}\n\nPbf.Varint  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n    SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32,\n    POW_2_63 = Math.pow(2, 63);\n\nPbf.prototype = {\n\n    destroy: function() {\n        this.buf = null;\n    },\n\n    // === READING =================================================================\n\n    readFields: function(readField, result, end) {\n        end = end || this.length;\n\n        while (this.pos < end) {\n            var val = this.readVarint(),\n                tag = val >> 3,\n                startPos = this.pos;\n\n            readField(tag, result, this);\n\n            if (this.pos === startPos) this.skip(val);\n        }\n        return result;\n    },\n\n    readMessage: function(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    },\n\n    readFixed32: function() {\n        var val = this.buf.readUInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readSFixed32: function() {\n        var val = this.buf.readInt32LE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n    readFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readUInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readSFixed64: function() {\n        var val = this.buf.readUInt32LE(this.pos) + this.buf.readInt32LE(this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readFloat: function() {\n        var val = this.buf.readFloatLE(this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readDouble: function() {\n        var val = this.buf.readDoubleLE(this.pos);\n        this.pos += 8;\n        return val;\n    },\n\n    readVarint: function() {\n        var buf = this.buf,\n            val, b, b0, b1, b2, b3;\n\n        b0 = buf[this.pos++]; if (b0 < 0x80) return b0;                 b0 = b0 & 0x7f;\n        b1 = buf[this.pos++]; if (b1 < 0x80) return b0 | b1 << 7;       b1 = (b1 & 0x7f) << 7;\n        b2 = buf[this.pos++]; if (b2 < 0x80) return b0 | b1 | b2 << 14; b2 = (b2 & 0x7f) << 14;\n        b3 = buf[this.pos++]; if (b3 < 0x80) return b0 | b1 | b2 | b3 << 21;\n\n        val = b0 | b1 | b2 | (b3 & 0x7f) << 21;\n\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x10000000;         if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x800000000;        if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x40000000000;      if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x2000000000000;    if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x100000000000000;  if (b < 0x80) return val;\n        b = buf[this.pos++]; val += (b & 0x7f) * 0x8000000000000000; if (b < 0x80) return val;\n\n        throw new Error('Expected varint not more than 10 bytes');\n    },\n\n    readVarint64: function() {\n        var startPos = this.pos,\n            val = this.readVarint();\n\n        if (val < POW_2_63) return val;\n\n        var pos = this.pos - 2;\n        while (this.buf[pos] === 0xff) pos--;\n        if (pos < startPos) pos = startPos;\n\n        val = 0;\n        for (var i = 0; i < pos - startPos + 1; i++) {\n            var b = ~this.buf[startPos + i] & 0x7f;\n            val += i < 4 ? b << i * 7 : b * Math.pow(2, i * 7);\n        }\n\n        return -val - 1;\n    },\n\n    readSVarint: function() {\n        var num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    },\n\n    readBoolean: function() {\n        return Boolean(this.readVarint());\n    },\n\n    readString: function() {\n        var end = this.readVarint() + this.pos,\n            str = this.buf.toString('utf8', this.pos, end);\n        this.pos = end;\n        return str;\n    },\n\n    readBytes: function() {\n        var end = this.readVarint() + this.pos,\n            buffer = this.buf.slice(this.pos, end);\n        this.pos = end;\n        return buffer;\n    },\n\n    // verbose for performance reasons; doesn't affect gzipped size\n\n    readPackedVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readVarint());\n        return arr;\n    },\n    readPackedSVarint: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    },\n    readPackedBoolean: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    },\n    readPackedFloat: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    },\n    readPackedDouble: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    },\n    readPackedFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    },\n    readPackedSFixed32: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    },\n    readPackedFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    },\n    readPackedSFixed64: function() {\n        var end = this.readVarint() + this.pos, arr = [];\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    },\n\n    skip: function(val) {\n        var type = val & 0x7;\n        if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}\n        else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;\n        else if (type === Pbf.Fixed32) this.pos += 4;\n        else if (type === Pbf.Fixed64) this.pos += 8;\n        else throw new Error('Unimplemented type: ' + type);\n    },\n\n    // === WRITING =================================================================\n\n    writeTag: function(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    },\n\n    realloc: function(min) {\n        var length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            var buf = new Buffer(length);\n            this.buf.copy(buf);\n            this.buf = buf;\n            this.length = length;\n        }\n    },\n\n    finish: function() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.slice(0, this.length);\n    },\n\n    writeFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeUInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeSFixed32: function(val) {\n        this.realloc(4);\n        this.buf.writeInt32LE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeUInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeSFixed64: function(val) {\n        this.realloc(8);\n        this.buf.writeInt32LE(val & -1, this.pos);\n        this.buf.writeInt32LE(Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeVarint: function(val) {\n        val = +val;\n\n        if (val <= 0x7f) {\n            this.realloc(1);\n            this.buf[this.pos++] = val;\n\n        } else if (val <= 0x3fff) {\n            this.realloc(2);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f);\n\n        } else if (val <= 0x1fffff) {\n            this.realloc(3);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f);\n\n        } else if (val <= 0xfffffff) {\n            this.realloc(4);\n            this.buf[this.pos++] = ((val >>> 0) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 7) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 14) & 0x7f) | 0x80;\n            this.buf[this.pos++] = ((val >>> 21) & 0x7f);\n\n        } else {\n            var pos = this.pos;\n            while (val >= 0x80) {\n                this.realloc(1);\n                this.buf[this.pos++] = (val & 0xff) | 0x80;\n                val /= 0x80;\n            }\n            this.realloc(1);\n            this.buf[this.pos++] = val | 0;\n            if (this.pos - pos > 10) throw new Error('Given varint doesn\\'t fit into 10 bytes');\n        }\n    },\n\n    writeSVarint: function(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    },\n\n    writeBoolean: function(val) {\n        this.writeVarint(Boolean(val));\n    },\n\n    writeString: function(str) {\n        str = String(str);\n        var bytes = Buffer.byteLength(str);\n        this.writeVarint(bytes);\n        this.realloc(bytes);\n        this.buf.write(str, this.pos);\n        this.pos += bytes;\n    },\n\n    writeFloat: function(val) {\n        this.realloc(4);\n        this.buf.writeFloatLE(val, this.pos);\n        this.pos += 4;\n    },\n\n    writeDouble: function(val) {\n        this.realloc(8);\n        this.buf.writeDoubleLE(val, this.pos);\n        this.pos += 8;\n    },\n\n    writeBytes: function(buffer) {\n        var len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    },\n\n    writeMessage: function(tag, fn, obj) {\n        this.writeTag(tag, Pbf.Bytes);\n\n        this.pos++; // reserve 1 byte for short message length\n\n        // write the message directly to the buffer and see how much was written\n        var startPos = this.pos;\n        fn(obj, this);\n        var len = this.pos - startPos;\n\n        var varintLen =\n            len <= 0x7f ? 1 :\n            len <= 0x3fff ? 2 :\n            len <= 0x1fffff ? 3 :\n            len <= 0xfffffff ? 4 : Math.ceil(Math.log(len) / (Math.LN2 * 7));\n\n        // if 1 byte isn't enough for encoding message length, shift the data to the right\n        if (varintLen > 1) {\n            this.realloc(varintLen - 1);\n            for (var i = this.pos - 1; i >= startPos; i--) this.buf[i + varintLen - 1] = this.buf[i];\n        }\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    },\n\n    writePackedVarint:   function(tag, arr) { this.writeMessage(tag, writePackedVarint, arr);   },\n    writePackedSVarint:  function(tag, arr) { this.writeMessage(tag, writePackedSVarint, arr);  },\n    writePackedBoolean:  function(tag, arr) { this.writeMessage(tag, writePackedBoolean, arr);  },\n    writePackedFloat:    function(tag, arr) { this.writeMessage(tag, writePackedFloat, arr);    },\n    writePackedDouble:   function(tag, arr) { this.writeMessage(tag, writePackedDouble, arr);   },\n    writePackedFixed32:  function(tag, arr) { this.writeMessage(tag, writePackedFixed32, arr);  },\n    writePackedSFixed32: function(tag, arr) { this.writeMessage(tag, writePackedSFixed32, arr); },\n    writePackedFixed64:  function(tag, arr) { this.writeMessage(tag, writePackedFixed64, arr);  },\n    writePackedSFixed64: function(tag, arr) { this.writeMessage(tag, writePackedSFixed64, arr); },\n\n    writeBytesField: function(tag, buffer) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeBytes(buffer);\n    },\n    writeFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFixed32(val);\n    },\n    writeSFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeSFixed32(val);\n    },\n    writeFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeFixed64(val);\n    },\n    writeSFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeSFixed64(val);\n    },\n    writeVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeVarint(val);\n    },\n    writeSVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeSVarint(val);\n    },\n    writeStringField: function(tag, str) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeString(str);\n    },\n    writeFloatField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFloat(val);\n    },\n    writeDoubleField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeDouble(val);\n    },\n    writeBooleanField: function(tag, val) {\n        this.writeVarintField(tag, Boolean(val));\n    }\n};\n\nfunction writePackedVarint(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);   }\nfunction writePackedSVarint(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);  }\nfunction writePackedFloat(arr, pbf)    { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);    }\nfunction writePackedDouble(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);   }\nfunction writePackedBoolean(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);  }\nfunction writePackedFixed32(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);  }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);  }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n"]}","/*!\n * strip-comments <https://github.com/jonschlinkert/strip-comments>\n *\n * Copyright (c) 2014 Jon Schlinkert, contributors.\n * Licensed under the MIT license.\n */\n\n'use stric';\n\nvar reBlock = '\\\\/\\\\*';\nvar reBlockIgnore = '\\\\/\\\\*(?!\\\\*?\\\\!)';\nvar reBlockEnd = '(.|[\\\\r\\\\n]|\\\\n)*?\\\\*\\\\/\\\\n?\\\\n?';\nvar reLine = /(^|[^\\S\\n])(?:\\/\\/)([\\s\\S]+?)$/gm;\nvar reLineIgnore = /(^|[^\\S\\n])(?:\\/\\/[^!])([\\s\\S]+?)$/gm;\n\n\n/**\n * Strip all comments\n *\n * {%= docs(\"strip\") %}\n *\n * @param   {String} `str`  file contents or string to strip.\n * @param   {Object} `opts`  options are passed to `.block`, and `.line`\n * @return  {String} String without comments.\n * @api public\n */\n\nvar strip = module.exports = function(str, opts) {\n  return str ? strip.block(strip.line(str, opts), opts) : '';\n};\n\n\n/**\n * Strip only block comments, optionally leaving protected comments\n * (e.g. `/*!`) intact.\n *\n * {%= docs(\"block\") %}\n *\n * @param   {String} `str`  file content or string to strip to\n * @param   {Object} `opts`  if `safe:true`, strip only comments that do not start with `/*!` or `/**!`\n * @return  {String} String without block comments.\n * @api public\n */\n\nstrip.block = function(str, opts) {\n  opts = opts || {};\n  var re = new RegExp(reBlock + reBlockEnd, 'gm');\n  if(opts.safe) {\n    re = new RegExp(reBlockIgnore + reBlockEnd, 'gm');\n  }\n  return str ? str.replace(re, '') : '';\n};\n\n\n/**\n * Strip only line comments\n *\n * {%= docs(\"line\") %}\n *\n * @param   {String} `str`  file content or string to strip to\n * @param   {Object} `opts`  if `safe:true`, strip all that not starts with `//!`\n * @return  {String} String without line comments.\n * @api public\n */\n\nstrip.line = function(str, opts) {\n  opts = opts || {};\n  var re = reLine;\n  if(opts.safe) {\n    re = reLineIgnore;\n  }\n  return str ? str.replace(re, '') : '';\n};\n","!function() {\n  var topojson = {\n    version: \"1.6.19\",\n    mesh: function(topology) { return object(topology, meshArcs.apply(this, arguments)); },\n    meshArcs: meshArcs,\n    merge: function(topology) { return object(topology, mergeArcs.apply(this, arguments)); },\n    mergeArcs: mergeArcs,\n    feature: featureOrCollection,\n    neighbors: neighbors,\n    presimplify: presimplify\n  };\n\n  function stitchArcs(topology, arcs) {\n    var stitchedArcs = {},\n        fragmentByStart = {},\n        fragmentByEnd = {},\n        fragments = [],\n        emptyIndex = -1;\n\n    // Stitch empty arcs first, since they may be subsumed by other arcs.\n    arcs.forEach(function(i, j) {\n      var arc = topology.arcs[i < 0 ? ~i : i], t;\n      if (arc.length < 3 && !arc[1][0] && !arc[1][1]) {\n        t = arcs[++emptyIndex], arcs[emptyIndex] = i, arcs[j] = t;\n      }\n    });\n\n    arcs.forEach(function(i) {\n      var e = ends(i),\n          start = e[0],\n          end = e[1],\n          f, g;\n\n      if (f = fragmentByEnd[start]) {\n        delete fragmentByEnd[f.end];\n        f.push(i);\n        f.end = end;\n        if (g = fragmentByStart[end]) {\n          delete fragmentByStart[g.start];\n          var fg = g === f ? f : f.concat(g);\n          fragmentByStart[fg.start = f.start] = fragmentByEnd[fg.end = g.end] = fg;\n        } else {\n          fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n        }\n      } else if (f = fragmentByStart[end]) {\n        delete fragmentByStart[f.start];\n        f.unshift(i);\n        f.start = start;\n        if (g = fragmentByEnd[start]) {\n          delete fragmentByEnd[g.end];\n          var gf = g === f ? f : g.concat(f);\n          fragmentByStart[gf.start = g.start] = fragmentByEnd[gf.end = f.end] = gf;\n        } else {\n          fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n        }\n      } else {\n        f = [i];\n        fragmentByStart[f.start = start] = fragmentByEnd[f.end = end] = f;\n      }\n    });\n\n    function ends(i) {\n      var arc = topology.arcs[i < 0 ? ~i : i], p0 = arc[0], p1;\n      if (topology.transform) p1 = [0, 0], arc.forEach(function(dp) { p1[0] += dp[0], p1[1] += dp[1]; });\n      else p1 = arc[arc.length - 1];\n      return i < 0 ? [p1, p0] : [p0, p1];\n    }\n\n    function flush(fragmentByEnd, fragmentByStart) {\n      for (var k in fragmentByEnd) {\n        var f = fragmentByEnd[k];\n        delete fragmentByStart[f.start];\n        delete f.start;\n        delete f.end;\n        f.forEach(function(i) { stitchedArcs[i < 0 ? ~i : i] = 1; });\n        fragments.push(f);\n      }\n    }\n\n    flush(fragmentByEnd, fragmentByStart);\n    flush(fragmentByStart, fragmentByEnd);\n    arcs.forEach(function(i) { if (!stitchedArcs[i < 0 ? ~i : i]) fragments.push([i]); });\n\n    return fragments;\n  }\n\n  function meshArcs(topology, o, filter) {\n    var arcs = [];\n\n    if (arguments.length > 1) {\n      var geomsByArc = [],\n          geom;\n\n      function arc(i) {\n        var j = i < 0 ? ~i : i;\n        (geomsByArc[j] || (geomsByArc[j] = [])).push({i: i, g: geom});\n      }\n\n      function line(arcs) {\n        arcs.forEach(arc);\n      }\n\n      function polygon(arcs) {\n        arcs.forEach(line);\n      }\n\n      function geometry(o) {\n        if (o.type === \"GeometryCollection\") o.geometries.forEach(geometry);\n        else if (o.type in geometryType) geom = o, geometryType[o.type](o.arcs);\n      }\n\n      var geometryType = {\n        LineString: line,\n        MultiLineString: polygon,\n        Polygon: polygon,\n        MultiPolygon: function(arcs) { arcs.forEach(polygon); }\n      };\n\n      geometry(o);\n\n      geomsByArc.forEach(arguments.length < 3\n          ? function(geoms) { arcs.push(geoms[0].i); }\n          : function(geoms) { if (filter(geoms[0].g, geoms[geoms.length - 1].g)) arcs.push(geoms[0].i); });\n    } else {\n      for (var i = 0, n = topology.arcs.length; i < n; ++i) arcs.push(i);\n    }\n\n    return {type: \"MultiLineString\", arcs: stitchArcs(topology, arcs)};\n  }\n\n  function mergeArcs(topology, objects) {\n    var polygonsByArc = {},\n        polygons = [],\n        components = [];\n\n    objects.forEach(function(o) {\n      if (o.type === \"Polygon\") register(o.arcs);\n      else if (o.type === \"MultiPolygon\") o.arcs.forEach(register);\n    });\n\n    function register(polygon) {\n      polygon.forEach(function(ring) {\n        ring.forEach(function(arc) {\n          (polygonsByArc[arc = arc < 0 ? ~arc : arc] || (polygonsByArc[arc] = [])).push(polygon);\n        });\n      });\n      polygons.push(polygon);\n    }\n\n    function exterior(ring) {\n      return cartesianRingArea(object(topology, {type: \"Polygon\", arcs: [ring]}).coordinates[0]) > 0; // TODO allow spherical?\n    }\n\n    polygons.forEach(function(polygon) {\n      if (!polygon._) {\n        var component = [],\n            neighbors = [polygon];\n        polygon._ = 1;\n        components.push(component);\n        while (polygon = neighbors.pop()) {\n          component.push(polygon);\n          polygon.forEach(function(ring) {\n            ring.forEach(function(arc) {\n              polygonsByArc[arc < 0 ? ~arc : arc].forEach(function(polygon) {\n                if (!polygon._) {\n                  polygon._ = 1;\n                  neighbors.push(polygon);\n                }\n              });\n            });\n          });\n        }\n      }\n    });\n\n    polygons.forEach(function(polygon) {\n      delete polygon._;\n    });\n\n    return {\n      type: \"MultiPolygon\",\n      arcs: components.map(function(polygons) {\n        var arcs = [];\n\n        // Extract the exterior (unique) arcs.\n        polygons.forEach(function(polygon) {\n          polygon.forEach(function(ring) {\n            ring.forEach(function(arc) {\n              if (polygonsByArc[arc < 0 ? ~arc : arc].length < 2) {\n                arcs.push(arc);\n              }\n            });\n          });\n        });\n\n        // Stitch the arcs into one or more rings.\n        arcs = stitchArcs(topology, arcs);\n\n        // If more than one ring is returned,\n        // at most one of these rings can be the exterior;\n        // this exterior ring has the same winding order\n        // as any exterior ring in the original polygons.\n        if ((n = arcs.length) > 1) {\n          var sgn = exterior(polygons[0][0]);\n          for (var i = 0, t; i < n; ++i) {\n            if (sgn === exterior(arcs[i])) {\n              t = arcs[0], arcs[0] = arcs[i], arcs[i] = t;\n              break;\n            }\n          }\n        }\n\n        return arcs;\n      })\n    };\n  }\n\n  function featureOrCollection(topology, o) {\n    return o.type === \"GeometryCollection\" ? {\n      type: \"FeatureCollection\",\n      features: o.geometries.map(function(o) { return feature(topology, o); })\n    } : feature(topology, o);\n  }\n\n  function feature(topology, o) {\n    var f = {\n      type: \"Feature\",\n      id: o.id,\n      properties: o.properties || {},\n      geometry: object(topology, o)\n    };\n    if (o.id == null) delete f.id;\n    return f;\n  }\n\n  function object(topology, o) {\n    var absolute = transformAbsolute(topology.transform),\n        arcs = topology.arcs;\n\n    function arc(i, points) {\n      if (points.length) points.pop();\n      for (var a = arcs[i < 0 ? ~i : i], k = 0, n = a.length, p; k < n; ++k) {\n        points.push(p = a[k].slice());\n        absolute(p, k);\n      }\n      if (i < 0) reverse(points, n);\n    }\n\n    function point(p) {\n      p = p.slice();\n      absolute(p, 0);\n      return p;\n    }\n\n    function line(arcs) {\n      var points = [];\n      for (var i = 0, n = arcs.length; i < n; ++i) arc(arcs[i], points);\n      if (points.length < 2) points.push(points[0].slice());\n      return points;\n    }\n\n    function ring(arcs) {\n      var points = line(arcs);\n      while (points.length < 4) points.push(points[0].slice());\n      return points;\n    }\n\n    function polygon(arcs) {\n      return arcs.map(ring);\n    }\n\n    function geometry(o) {\n      var t = o.type;\n      return t === \"GeometryCollection\" ? {type: t, geometries: o.geometries.map(geometry)}\n          : t in geometryType ? {type: t, coordinates: geometryType[t](o)}\n          : null;\n    }\n\n    var geometryType = {\n      Point: function(o) { return point(o.coordinates); },\n      MultiPoint: function(o) { return o.coordinates.map(point); },\n      LineString: function(o) { return line(o.arcs); },\n      MultiLineString: function(o) { return o.arcs.map(line); },\n      Polygon: function(o) { return polygon(o.arcs); },\n      MultiPolygon: function(o) { return o.arcs.map(polygon); }\n    };\n\n    return geometry(o);\n  }\n\n  function reverse(array, n) {\n    var t, j = array.length, i = j - n; while (i < --j) t = array[i], array[i++] = array[j], array[j] = t;\n  }\n\n  function bisect(a, x) {\n    var lo = 0, hi = a.length;\n    while (lo < hi) {\n      var mid = lo + hi >>> 1;\n      if (a[mid] < x) lo = mid + 1;\n      else hi = mid;\n    }\n    return lo;\n  }\n\n  function neighbors(objects) {\n    var indexesByArc = {}, // arc index -> array of object indexes\n        neighbors = objects.map(function() { return []; });\n\n    function line(arcs, i) {\n      arcs.forEach(function(a) {\n        if (a < 0) a = ~a;\n        var o = indexesByArc[a];\n        if (o) o.push(i);\n        else indexesByArc[a] = [i];\n      });\n    }\n\n    function polygon(arcs, i) {\n      arcs.forEach(function(arc) { line(arc, i); });\n    }\n\n    function geometry(o, i) {\n      if (o.type === \"GeometryCollection\") o.geometries.forEach(function(o) { geometry(o, i); });\n      else if (o.type in geometryType) geometryType[o.type](o.arcs, i);\n    }\n\n    var geometryType = {\n      LineString: line,\n      MultiLineString: polygon,\n      Polygon: polygon,\n      MultiPolygon: function(arcs, i) { arcs.forEach(function(arc) { polygon(arc, i); }); }\n    };\n\n    objects.forEach(geometry);\n\n    for (var i in indexesByArc) {\n      for (var indexes = indexesByArc[i], m = indexes.length, j = 0; j < m; ++j) {\n        for (var k = j + 1; k < m; ++k) {\n          var ij = indexes[j], ik = indexes[k], n;\n          if ((n = neighbors[ij])[i = bisect(n, ik)] !== ik) n.splice(i, 0, ik);\n          if ((n = neighbors[ik])[i = bisect(n, ij)] !== ij) n.splice(i, 0, ij);\n        }\n      }\n    }\n\n    return neighbors;\n  }\n\n  function presimplify(topology, triangleArea) {\n    var absolute = transformAbsolute(topology.transform),\n        relative = transformRelative(topology.transform),\n        heap = minAreaHeap();\n\n    if (!triangleArea) triangleArea = cartesianTriangleArea;\n\n    topology.arcs.forEach(function(arc) {\n      var triangles = [],\n          maxArea = 0,\n          triangle;\n\n      // To store each point’s effective area, we create a new array rather than\n      // extending the passed-in point to workaround a Chrome/V8 bug (getting\n      // stuck in smi mode). For midpoints, the initial effective area of\n      // Infinity will be computed in the next step.\n      for (var i = 0, n = arc.length, p; i < n; ++i) {\n        p = arc[i];\n        absolute(arc[i] = [p[0], p[1], Infinity], i);\n      }\n\n      for (var i = 1, n = arc.length - 1; i < n; ++i) {\n        triangle = arc.slice(i - 1, i + 2);\n        triangle[1][2] = triangleArea(triangle);\n        triangles.push(triangle);\n        heap.push(triangle);\n      }\n\n      for (var i = 0, n = triangles.length; i < n; ++i) {\n        triangle = triangles[i];\n        triangle.previous = triangles[i - 1];\n        triangle.next = triangles[i + 1];\n      }\n\n      while (triangle = heap.pop()) {\n        var previous = triangle.previous,\n            next = triangle.next;\n\n        // If the area of the current point is less than that of the previous point\n        // to be eliminated, use the latter's area instead. This ensures that the\n        // current point cannot be eliminated without eliminating previously-\n        // eliminated points.\n        if (triangle[1][2] < maxArea) triangle[1][2] = maxArea;\n        else maxArea = triangle[1][2];\n\n        if (previous) {\n          previous.next = next;\n          previous[2] = triangle[2];\n          update(previous);\n        }\n\n        if (next) {\n          next.previous = previous;\n          next[0] = triangle[0];\n          update(next);\n        }\n      }\n\n      arc.forEach(relative);\n    });\n\n    function update(triangle) {\n      heap.remove(triangle);\n      triangle[1][2] = triangleArea(triangle);\n      heap.push(triangle);\n    }\n\n    return topology;\n  };\n\n  function cartesianRingArea(ring) {\n    var i = -1,\n        n = ring.length,\n        a,\n        b = ring[n - 1],\n        area = 0;\n\n    while (++i < n) {\n      a = b;\n      b = ring[i];\n      area += a[0] * b[1] - a[1] * b[0];\n    }\n\n    return area * .5;\n  }\n\n  function cartesianTriangleArea(triangle) {\n    var a = triangle[0], b = triangle[1], c = triangle[2];\n    return Math.abs((a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]));\n  }\n\n  function compareArea(a, b) {\n    return a[1][2] - b[1][2];\n  }\n\n  function minAreaHeap() {\n    var heap = {},\n        array = [],\n        size = 0;\n\n    heap.push = function(object) {\n      up(array[object._ = size] = object, size++);\n      return size;\n    };\n\n    heap.pop = function() {\n      if (size <= 0) return;\n      var removed = array[0], object;\n      if (--size > 0) object = array[size], down(array[object._ = 0] = object, 0);\n      return removed;\n    };\n\n    heap.remove = function(removed) {\n      var i = removed._, object;\n      if (array[i] !== removed) return; // invalid request\n      if (i !== --size) object = array[size], (compareArea(object, removed) < 0 ? up : down)(array[object._ = i] = object, i);\n      return i;\n    };\n\n    function up(object, i) {\n      while (i > 0) {\n        var j = ((i + 1) >> 1) - 1,\n            parent = array[j];\n        if (compareArea(object, parent) >= 0) break;\n        array[parent._ = i] = parent;\n        array[object._ = i = j] = object;\n      }\n    }\n\n    function down(object, i) {\n      while (true) {\n        var r = (i + 1) << 1,\n            l = r - 1,\n            j = i,\n            child = array[j];\n        if (l < size && compareArea(array[l], child) < 0) child = array[j = l];\n        if (r < size && compareArea(array[r], child) < 0) child = array[j = r];\n        if (j === i) break;\n        array[child._ = i] = child;\n        array[object._ = i = j] = object;\n      }\n    }\n\n    return heap;\n  }\n\n  function transformAbsolute(transform) {\n    if (!transform) return noop;\n    var x0,\n        y0,\n        kx = transform.scale[0],\n        ky = transform.scale[1],\n        dx = transform.translate[0],\n        dy = transform.translate[1];\n    return function(point, i) {\n      if (!i) x0 = y0 = 0;\n      point[0] = (x0 += point[0]) * kx + dx;\n      point[1] = (y0 += point[1]) * ky + dy;\n    };\n  }\n\n  function transformRelative(transform) {\n    if (!transform) return noop;\n    var x0,\n        y0,\n        kx = transform.scale[0],\n        ky = transform.scale[1],\n        dx = transform.translate[0],\n        dy = transform.translate[1];\n    return function(point, i) {\n      if (!i) x0 = y0 = 0;\n      var x1 = (point[0] - dx) / kx | 0,\n          y1 = (point[1] - dy) / ky | 0;\n      point[0] = x1 - x0;\n      point[1] = y1 - y0;\n      x0 = x1;\n      y0 = y1;\n    };\n  }\n\n  function noop() {}\n\n  if (typeof define === \"function\" && define.amd) define(topojson);\n  else if (typeof module === \"object\" && module.exports) module.exports = topojson;\n  else this.topojson = topojson;\n}();\n","module.exports.VectorTile = require('./lib/vectortile.js');\nmodule.exports.VectorTileFeature = require('./lib/vectortilefeature.js');\nmodule.exports.VectorTileLayer = require('./lib/vectortilelayer.js');\n","'use strict';\n\nvar VectorTileLayer = require('./vectortilelayer');\n\nmodule.exports = VectorTile;\n\nfunction VectorTile(pbf, end) {\n    this.layers = pbf.readFields(readTile, {}, end);\n}\n\nfunction readTile(tag, layers, pbf) {\n    if (tag === 3) {\n        var layer = new VectorTileLayer(pbf, pbf.readVarint() + pbf.pos);\n        if (layer.length) layers[layer.name] = layer;\n    }\n}\n\n","'use strict';\n\nvar Point = require('point-geometry');\n\nmodule.exports = VectorTileFeature;\n\nfunction VectorTileFeature(pbf, end, extent, keys, values) {\n    // Public\n    this.properties = {};\n    this.extent = extent;\n    this.type = 0;\n\n    // Private\n    this._pbf = pbf;\n    this._geometry = -1;\n    this._keys = keys;\n    this._values = values;\n\n    pbf.readFields(readFeature, this, end);\n}\n\nfunction readFeature(tag, feature, pbf) {\n    if (tag == 1) feature._id = pbf.readVarint();\n    else if (tag == 2) readTag(pbf, feature);\n    else if (tag == 3) feature.type = pbf.readVarint();\n    else if (tag == 4) feature._geometry = pbf.pos;\n}\n\nfunction readTag(pbf, feature) {\n    var end = pbf.readVarint() + pbf.pos;\n\n    while (pbf.pos < end) {\n        var key = feature._keys[pbf.readVarint()],\n            value = feature._values[pbf.readVarint()];\n        feature.properties[key] = value;\n    }\n}\n\nVectorTileFeature.types = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nVectorTileFeature.prototype.loadGeometry = function() {\n    var pbf = this._pbf;\n    pbf.pos = this._geometry;\n\n    var end = pbf.readVarint() + pbf.pos,\n        cmd = 1,\n        length = 0,\n        x = 0,\n        y = 0,\n        lines = [],\n        line;\n\n    while (pbf.pos < end) {\n        if (!length) {\n            var cmdLen = pbf.readVarint();\n            cmd = cmdLen & 0x7;\n            length = cmdLen >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += pbf.readSVarint();\n            y += pbf.readSVarint();\n\n            if (cmd === 1) { // moveTo\n                if (line) lines.push(line);\n                line = [];\n            }\n\n            line.push(new Point(x, y));\n\n        } else if (cmd === 7) {\n            line.push(line[0].clone()); // closePolygon\n\n        } else {\n            throw new Error('unknown command ' + cmd);\n        }\n    }\n\n    if (line) lines.push(line);\n\n    return lines;\n};\n\nVectorTileFeature.prototype.bbox = function() {\n    var pbf = this._pbf;\n    pbf.pos = this._geometry;\n\n    var end = pbf.readVarint() + pbf.pos,\n        cmd = 1,\n        length = 0,\n        x = 0,\n        y = 0,\n        x1 = Infinity,\n        x2 = -Infinity,\n        y1 = Infinity,\n        y2 = -Infinity;\n\n    while (pbf.pos < end) {\n        if (!length) {\n            var cmdLen = pbf.readVarint();\n            cmd = cmdLen & 0x7;\n            length = cmdLen >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += pbf.readSVarint();\n            y += pbf.readSVarint();\n            if (x < x1) x1 = x;\n            if (x > x2) x2 = x;\n            if (y < y1) y1 = y;\n            if (y > y2) y2 = y;\n\n        } else if (cmd !== 7) {\n            throw new Error('unknown command ' + cmd);\n        }\n    }\n\n    return [x1, y1, x2, y2];\n};\n\nVectorTileFeature.prototype.toGeoJSON = function(x, y, z) {\n    var size = this.extent * Math.pow(2, z),\n        x0 = this.extent * x,\n        y0 = this.extent * y,\n        coords = this.loadGeometry(),\n        type = VectorTileFeature.types[this.type];\n\n    for (var i = 0; i < coords.length; i++) {\n        var line = coords[i];\n        for (var j = 0; j < line.length; j++) {\n            var p = line[j], y2 = 180 - (p.y + y0) * 360 / size;\n            line[j] = [\n                (p.x + x0) * 360 / size - 180,\n                360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90\n            ];\n        }\n    }\n\n    if (type === 'Point' && coords.length === 1) {\n        coords = coords[0][0];\n    } else if (type === 'Point') {\n        coords = coords[0];\n        type = 'MultiPoint';\n    } else if (type === 'LineString' && coords.length === 1) {\n        coords = coords[0];\n    } else if (type === 'LineString') {\n        type = 'MultiLineString';\n    }\n\n    return {\n        type: \"Feature\",\n        geometry: {\n            type: type,\n            coordinates: coords\n        },\n        properties: this.properties\n    };\n};\n","'use strict';\n\nvar VectorTileFeature = require('./vectortilefeature.js');\n\nmodule.exports = VectorTileLayer;\n\nfunction VectorTileLayer(pbf, end) {\n    // Public\n    this.version = 1;\n    this.name = null;\n    this.extent = 4096;\n    this.length = 0;\n\n    // Private\n    this._pbf = pbf;\n    this._keys = [];\n    this._values = [];\n    this._features = [];\n\n    pbf.readFields(readLayer, this, end);\n\n    this.length = this._features.length;\n}\n\nfunction readLayer(tag, layer, pbf) {\n    if (tag === 15) layer.version = pbf.readVarint();\n    else if (tag === 1) layer.name = pbf.readString();\n    else if (tag === 5) layer.extent = pbf.readVarint();\n    else if (tag === 2) layer._features.push(pbf.pos);\n    else if (tag === 3) layer._keys.push(pbf.readString());\n    else if (tag === 4) layer._values.push(readValueMessage(pbf));\n}\n\nfunction readValueMessage(pbf) {\n    var value = null,\n        end = pbf.readVarint() + pbf.pos;\n\n    while (pbf.pos < end) {\n        var tag = pbf.readVarint() >> 3;\n\n        value = tag === 1 ? pbf.readString() :\n            tag === 2 ? pbf.readFloat() :\n            tag === 3 ? pbf.readDouble() :\n            tag === 4 ? pbf.readVarint64() :\n            tag === 5 ? pbf.readVarint() :\n            tag === 6 ? pbf.readSVarint() :\n            tag === 7 ? pbf.readBoolean() : null;\n    }\n\n    return value;\n}\n\n// return feature `i` from this layer as a `VectorTileFeature`\nVectorTileLayer.prototype.feature = function(i) {\n    if (i < 0 || i >= this._features.length) throw new Error('feature index out of bounds');\n\n    this._pbf.pos = this._features[i];\n\n    var end = this._pbf.readVarint() + this._pbf.pos;\n    return new VectorTileFeature(this._pbf, end, this.extent, this._keys, this._values);\n};\n","'use strict';\n\nmodule.exports = Point;\n\nfunction Point(x, y) {\n    this.x = x;\n    this.y = y;\n}\n\nPoint.prototype = {\n    clone: function() { return new Point(this.x, this.y); },\n\n    add:     function(p) { return this.clone()._add(p);     },\n    sub:     function(p) { return this.clone()._sub(p);     },\n    mult:    function(k) { return this.clone()._mult(k);    },\n    div:     function(k) { return this.clone()._div(k);     },\n    rotate:  function(a) { return this.clone()._rotate(a);  },\n    matMult: function(m) { return this.clone()._matMult(m); },\n    unit:    function() { return this.clone()._unit(); },\n    perp:    function() { return this.clone()._perp(); },\n    round:   function() { return this.clone()._round(); },\n\n    mag: function() {\n        return Math.sqrt(this.x * this.x + this.y * this.y);\n    },\n\n    equals: function(p) {\n        return this.x === p.x &&\n               this.y === p.y;\n    },\n\n    dist: function(p) {\n        return Math.sqrt(this.distSqr(p));\n    },\n\n    distSqr: function(p) {\n        var dx = p.x - this.x,\n            dy = p.y - this.y;\n        return dx * dx + dy * dy;\n    },\n\n    angle: function() {\n        return Math.atan2(this.y, this.x);\n    },\n\n    angleTo: function(b) {\n        return Math.atan2(this.y - b.y, this.x - b.x);\n    },\n\n    angleWith: function(b) {\n        return this.angleWithSep(b.x, b.y);\n    },\n\n    // Find the angle of the two vectors, solving the formula for the cross product a x b = |a||b|sin(θ) for θ.\n    angleWithSep: function(x, y) {\n        return Math.atan2(\n            this.x * y - this.y * x,\n            this.x * x + this.y * y);\n    },\n\n    _matMult: function(m) {\n        var x = m[0] * this.x + m[1] * this.y,\n            y = m[2] * this.x + m[3] * this.y;\n        this.x = x;\n        this.y = y;\n        return this;\n    },\n\n    _add: function(p) {\n        this.x += p.x;\n        this.y += p.y;\n        return this;\n    },\n\n    _sub: function(p) {\n        this.x -= p.x;\n        this.y -= p.y;\n        return this;\n    },\n\n    _mult: function(k) {\n        this.x *= k;\n        this.y *= k;\n        return this;\n    },\n\n    _div: function(k) {\n        this.x /= k;\n        this.y /= k;\n        return this;\n    },\n\n    _unit: function() {\n        this._div(this.mag());\n        return this;\n    },\n\n    _perp: function() {\n        var y = this.y;\n        this.y = this.x;\n        this.x = -y;\n        return this;\n    },\n\n    _rotate: function(angle) {\n        var cos = Math.cos(angle),\n            sin = Math.sin(angle),\n            x = cos * this.x - sin * this.y,\n            y = sin * this.x + cos * this.y;\n        this.x = x;\n        this.y = y;\n        return this;\n    },\n\n    _round: function() {\n        this.x = Math.round(this.x);\n        this.y = Math.round(this.y);\n        return this;\n    }\n};\n\n// constructs Point from an array if necessary\nPoint.convert = function (a) {\n    if (a instanceof Point) {\n        return a;\n    }\n    if (Array.isArray(a)) {\n        return new Point(a[0], a[1]);\n    }\n    return a;\n};\n","/*global Camera */\nimport Geo from './geo';\nimport Utils from './utils/utils';\nimport ShaderProgram from './gl/shader_program';\n\nimport glMatrix from 'gl-matrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\n// Abstract base class\nexport default class Camera {\n\n    constructor(name, scene, options = {}) {\n        this.scene = scene;\n        this.position = options.position;\n        this.zoom = options.zoom;\n        // this.updateScene();\n    }\n\n    // Create a camera by type name, factory-style\n    static create(name, scene, config) {\n        switch (config.type) {\n            case 'isometric':\n                return new IsometricCamera(name, scene, config);\n            case 'flat':\n                return new FlatCamera(name, scene, config);\n            case 'perspective':\n            /* falls through */\n            default:\n                return new PerspectiveCamera(name, scene, config);\n        }\n    }\n\n    // Update method called once per frame\n    update() {\n        // this.updateScene();\n    }\n\n    // Called once per frame per program (e.g. for main render pass, then for each additional pass for feature selection, etc.)\n    setupProgram(program) {\n    }\n\n    /**\n        Sync camera position and/or zoom to scene\n        position: [lat, lng] or [lat, lng, zoom]\n        zoom: zoom\n    */\n    updateScene () {\n        if (this.position || this.zoom) {\n            var view = {};\n            if (this.position) {\n                view = { lng: this.position[0], lat: this.position[1], zoom: this.position[2] };\n            }\n            if (this.zoom) {\n                view.zoom = this.zoom;\n            }\n            this.scene.setView(view);\n        }\n    }\n\n}\n\n/**\n    Perspective matrix projection\n\n    This is a specialized perspective camera that, given a desired camera focal length (which can also vary by zoom level),\n    constrains the camera height above the ground plane such that the displayed ground area of the map matches that of\n    a traditional web mercator map. This means you can set the camera location by [lat, lng, zoom] as you would a typical\n    web mercator map, then adjust the focal length as needed.\n\n    Vanishing point can also be adjusted to achieve different \"viewing angles\", e.g. instead of looking straight down into\n    the center of the viewport, the camera appears to be tilted at an angle. For example:\n\n    [0, 0] = looking towards center of viewport\n    [-250, -250] = looking 250 pixels from the viewport center to the lower-left corner\n    [400, 0] = looking 400 pixels to the right of the viewport center\n*/\nclass PerspectiveCamera extends Camera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'perspective';\n\n        // a single scalar, or pairs of stops mapping zoom levels, e.g. [zoom, focal length]\n        this.focal_length = options.focal_length;\n        this.fov = options.fov;\n        if (!this.focal_length && !this.fov) {\n            // Default focal length ranges by zoom\n            this.focal_length = [[16, 2], [17, 2.5], [18, 3], [19, 4], [20, 6]];\n        }\n\n        this.vanishing_point = options.vanishing_point || [0, 0]; // [x, y]\n        this.vanishing_point = this.vanishing_point.map(parseFloat); // we implicitly only support px units here\n        this.vanishing_point_skew = [];\n\n        this.position_meters = null;\n        this.viewMatrix = new Float64Array(16);\n        this.projectionMatrix = new Float32Array(16);\n\n        // 'camera' is the name of the shader block, e.g. determines where in the shader this code is injected\n        ShaderProgram.replaceBlock('camera', `\n            uniform mat4 u_projection;\n            uniform vec3 u_eye;\n            uniform vec2 u_vanishing_point;\n\n            void cameraProjection (inout vec4 position) {\n                position = u_projection * position;\n            }`\n        );\n    }\n\n    // Constrains the camera so that the viewable area matches given the viewport height\n    // (in world space, e.g. meters), given either a camera focal length or field-of-view\n    // (focal length is used if both are passed).\n    constrainCamera({ view_height, height, focal_length, fov }) {\n        // Solve for camera height\n        if (!height) {\n            // We have focal length, calculate FOV\n            if (focal_length) {\n                fov = Math.atan(1 / focal_length) * 2;\n            }\n            // We have FOV, calculate focal length\n            else if (fov) {\n                fov = fov * Math.PI / 180; // convert FOV degrees to radians\n                focal_length = 1 / Math.tan(fov / 2);\n            }\n\n            // Distance that camera should be from ground such that it fits the field of view expected\n            // for a conventional web mercator map at the current zoom level and camera focal length\n            height = view_height / 2 * focal_length;\n        }\n        // Solve for camera focal length / field-of-view\n        else {\n            focal_length = 2 * height / view_height;\n            fov = Math.atan(1 / focal_length) * 2;\n        }\n\n        return { view_height, height, focal_length, fov };\n    }\n\n    updateMatrices() {\n        // TODO: only re-calculate these vars when necessary\n\n        // Height of the viewport in meters at current zoom\n        var viewport_height = this.scene.css_size.height * Geo.metersPerPixel(this.scene.zoom);\n\n        // Compute camera properties to fit desired view\n        var { height, fov } = this.constrainCamera({\n            view_height: viewport_height,\n            focal_length: Utils.interpolate(this.scene.zoom, this.focal_length),\n            fov: Utils.interpolate(this.scene.zoom, this.fov)\n         });\n\n        // View matrix\n        var position = [this.scene.center_meters.x, this.scene.center_meters.y, height];\n        this.position_meters = position;\n\n        // mat4.lookAt(this.viewMatrix,\n        //     vec3.fromValues(...position),\n        //     vec3.fromValues(position[0], position[1], height - 1),\n        //     vec3.fromValues(0, 1, 0));\n        // Exclude camera height from view matrix\n        mat4.lookAt(this.viewMatrix,\n            vec3.fromValues(position[0], position[1], 0),\n            vec3.fromValues(position[0], position[1], -1),\n            vec3.fromValues(0, 1, 0));\n\n        // Projection matrix\n        mat4.perspective(this.projectionMatrix, fov, this.scene.view_aspect, 1, height * 2);\n\n        // Convert vanishing point from pixels to viewport space\n        this.vanishing_point_skew[0] = this.vanishing_point[0] / this.scene.css_size.width;\n        this.vanishing_point_skew[1] = this.vanishing_point[1] / this.scene.css_size.height;\n\n        // Adjust projection matrix to include vanishing point skew\n        this.projectionMatrix[8] = -this.vanishing_point_skew[0]; // z column of x row, e.g. amount z skews x\n        this.projectionMatrix[9] = -this.vanishing_point_skew[1]; // z column of y row, e.g. amount z skews y\n\n        // Translate geometry into the distance so that camera is appropriate height above ground\n        // Additionally, adjust xy to compensate for any vanishing point skew, e.g. move geometry so that the displayed g\n        // plane of the map matches that expected by a traditional web mercator map at this [lat, lng, zoom].\n        mat4.translate(this.projectionMatrix, this.projectionMatrix,\n            vec3.fromValues(\n                viewport_height/2 * this.scene.view_aspect * -this.vanishing_point_skew[0],\n                viewport_height/2 * -this.vanishing_point_skew[1],\n                0\n            )\n        );\n\n        // Include camera height in projection matrix\n        mat4.translate(this.projectionMatrix, this.projectionMatrix, vec3.fromValues(0, 0, -height));\n    }\n\n    update() {\n        super.update();\n        this.updateMatrices();\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projectionMatrix);\n        program.uniform('3f', 'u_eye', 0, 0, this.position_meters[2]);\n        program.uniform('2fv', 'u_vanishing_point', this.vanishing_point_skew);\n    }\n\n}\n\n// Isometric-style projection\n// Note: this is actually an \"axonometric\" projection, but I'm using the colloquial term isometric because it is more recognizable.\n// An isometric projection is a specific subset of axonometric projections.\n// 'axis' determines the xy skew applied to a vertex based on its z coordinate, e.g. [0, 1] axis causes buildings to be drawn\n// straight upwards on screen at their true height, [0, .5] would draw them up at half-height, [1, 0] would be sideways, etc.\nclass IsometricCamera extends Camera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'isometric';\n        this.axis = options.axis || { x: 0, y: 1 };\n        if (this.axis.length === 2) {\n            this.axis = { x: this.axis[0], y: this.axis[1] }; // allow axis to also be passed as 2-elem array\n        }\n\n        this.position_meters = null;\n        this.viewport_height = null;\n\n        this.viewMatrix = new Float64Array(16);\n        this.projectionMatrix = new Float32Array(16);\n\n        // 'camera' is the name of the shader block, e.g. determines where in the shader this code is injected\n        ShaderProgram.replaceBlock('camera', `\n            uniform mat4 u_projection;\n            uniform vec3 u_eye;\n            uniform vec2 u_vanishing_point;\n\n            void cameraProjection (inout vec4 position) {\n                position = u_projection * position;\n                // position.xy += position.z * u_isometric_axis;\n\n                // Reverse z for depth buffer so up is negative,\n                // and scale down values so objects higher than one screen height will not get clipped\n                // pull forward slightly to avoid going past far clipping plane\n                position.z = -position.z / 100. + 1. - 0.001;\n            }`\n        );\n    }\n\n    update() {\n        super.update();\n\n        this.viewport_height = this.scene.css_size.height * Geo.metersPerPixel(this.scene.zoom);\n        var position = [this.scene.center_meters.x, this.scene.center_meters.y, this.viewport_height];\n        this.position_meters = position;\n\n        // View\n        mat4.identity(this.viewMatrix);\n        mat4.translate(this.viewMatrix, this.viewMatrix, vec3.fromValues(-position[0], -position[1], 0));\n\n        // Projection\n        mat4.identity(this.projectionMatrix);\n\n        // apply isometric skew\n        this.projectionMatrix[8] = this.axis.x / this.scene.view_aspect;    // z column of x row, e.g. amount z skews x\n        this.projectionMatrix[9] = this.axis.y;                             // z column of x row, e.g. amount z skews y\n\n        // convert meters to viewport\n        mat4.scale(this.projectionMatrix, this.projectionMatrix,\n            vec3.fromValues(\n                2 / this.scene.viewport_meters.x,\n                2 / this.scene.viewport_meters.y,\n                2 / this.scene.viewport_meters.y\n            )\n        );\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projectionMatrix);\n\n        program.uniform('3f', 'u_eye', 0, 0, this.viewport_height);\n        // program.uniform('3f', 'u_eye', this.viewport_height * this.axis.x, this.viewport_height * this.axis.y, this.viewport_height);\n        program.uniform('2f', 'u_vanishing_point', 0, 0);\n    }\n\n}\n\n// Flat projection (e.g. just top-down, no perspective) - a degenerate isometric camera\nclass FlatCamera extends IsometricCamera {\n\n    constructor(name, scene, options = {}) {\n        super(name, scene, options);\n        this.type = 'flat';\n    }\n\n    update() {\n        // Axis is fixed to (0, 0) for flat camera\n        this.axis.x = 0;\n        this.axis.y = 0;\n\n        super.update();\n    }\n\n}\n","// Miscellaneous geo functions\n\nvar Geo;\nexport default Geo = {};\n\n// Projection constants\nGeo.tile_size = 256;\nGeo.half_circumference_meters = 20037508.342789244;\nGeo.circumference_meters = Geo.half_circumference_meters * 2;\nGeo.min_zoom_meters_per_pixel = Geo.circumference_meters / Geo.tile_size; // min zoom draws world as 2 tiles wide\nGeo.meters_per_pixel = [];\nGeo.meters_per_tile = [];\nGeo.max_zoom = 18;\nfor (var z=0; z <= Geo.max_zoom; z++) {\n    Geo.meters_per_pixel[z] = Geo.min_zoom_meters_per_pixel / Math.pow(2, z);\n    Geo.meters_per_tile[z] = Geo.circumference_meters / Math.pow(2, z);\n}\n\nGeo.metersPerPixel = function (zoom) {\n    return Geo.min_zoom_meters_per_pixel / Math.pow(2, zoom);\n};\n\n// Conversion functions based on an defined tile scale\nGeo.units_per_meter = [];\nGeo.tile_scale = 4096; // coordinates are locally scaled to the range [0, tile_scale]\nGeo.units_per_pixel = Geo.tile_scale / Geo.tile_size;\n\nfor (let z=0; z <= Geo.max_zoom; z++) {\n    Geo.units_per_meter[z] = Geo.tile_scale / (Geo.tile_size * Geo.meters_per_pixel[z]);\n}\n\n// Convert tile location to mercator meters - multiply by pixels per tile, then by meters per pixel, adjust for map origin\nGeo.metersForTile = function (tile) {\n    return {\n        x: tile.x * Geo.circumference_meters / Math.pow(2, tile.z) - Geo.half_circumference_meters,\n        y: -(tile.y * Geo.circumference_meters / Math.pow(2, tile.z) - Geo.half_circumference_meters)\n    };\n};\n\n/**\n   Given a point in mercator meters and a zoom level, return the tile X/Y/Z that the point lies in\n*/\nGeo.tileForMeters = function ([x, y], zoom) {\n    return {\n        x: Math.floor((x + Geo.half_circumference_meters) / (Geo.circumference_meters / Math.pow(2, zoom))),\n        y: Math.floor((-y + Geo.half_circumference_meters) / (Geo.circumference_meters / Math.pow(2, zoom))),\n        z: zoom\n    };\n};\n\n// Wrap a tile to positive #s for zoom\n// Optionally specify the axes to wrap\nGeo.wrapTile = function({ x, y, z }, mask = { x: true, y: false }) {\n    var m = (1 << z) - 1;\n    if (mask.x) {\n        x = x & m;\n    }\n    if (mask.y) {\n        y = y & m;\n    }\n    return { x, y, z };\n};\n\n/**\n   Convert mercator meters to lat-lng\n*/\nGeo.metersToLatLng = function ([x, y]) {\n\n    x /= Geo.half_circumference_meters;\n    y /= Geo.half_circumference_meters;\n\n    y = (2 * Math.atan(Math.exp(y * Math.PI)) - (Math.PI / 2)) / Math.PI;\n\n    x *= 180;\n    y *= 180;\n\n    return [x, y];\n};\n\n/**\n  Convert lat-lng to mercator meters\n*/\nGeo.latLngToMeters = function([x, y]) {\n\n    // Latitude\n    y = Math.log(Math.tan(y*Math.PI/360 + Math.PI/4)) / Math.PI;\n    y *= Geo.half_circumference_meters;\n\n    // Longitude\n    x *= Geo.half_circumference_meters / 180;\n\n    return [x, y];\n};\n\nGeo.wrapLng = function(x) {\n    if (x > 180 || x < -180) {\n        x = ((x + 180) % 360 + 360) % 360 - 180;\n    }\n    return x;\n};\n\n// Run an in-place transform function on each cooordinate in a GeoJSON geometry\nGeo.transformGeometry = function (geometry, transform) {\n    if (geometry.type === 'Point') {\n        transform(geometry.coordinates);\n    }\n    else if (geometry.type === 'LineString' || geometry.type === 'MultiPoint') {\n        geometry.coordinates.forEach(transform);\n    }\n    else if (geometry.type === 'Polygon' || geometry.type === 'MultiLineString') {\n        geometry.coordinates.forEach(coordinates => coordinates.forEach(transform));\n    }\n    else if (geometry.type === 'MultiPolygon') {\n        geometry.coordinates.forEach(polygon => {\n            polygon.forEach(coordinates => coordinates.forEach(transform));\n        });\n    }\n    // TODO: support GeometryCollection\n};\n\nGeo.boxIntersect = function (b1, b2) {\n    return !(\n        b2.sw.x > b1.ne.x ||\n        b2.ne.x < b1.sw.x ||\n        b2.sw.y > b1.ne.y ||\n        b2.ne.y < b1.sw.y\n    );\n};\n\n// Finds the axis-aligned bounding box for a polygon\nGeo.findBoundingBox = function (polygon) {\n    var min_x = Infinity,\n        max_x = -Infinity,\n        min_y = Infinity,\n        max_y = -Infinity;\n\n    // Only need to examine outer ring (polygon[0])\n    var num_coords = polygon[0].length;\n    for (var c=0; c < num_coords; c++) {\n        var coord = polygon[0][c];\n\n        if (coord[0] < min_x) {\n            min_x = coord[0];\n        }\n        if (coord[1] < min_y) {\n            min_y = coord[1];\n        }\n        if (coord[0] > max_x) {\n            max_x = coord[0];\n        }\n        if (coord[1] > max_y) {\n            max_y = coord[1];\n        }\n    }\n\n    return [min_x, min_y, max_x, max_y];\n};\n\n// Convert geometry type to one of: 'point', 'line', 'polygon'\nGeo.geometryType = function(type) {\n    if (type === 'Polygon' || type === 'MultiPolygon') {\n        return 'polygon';\n    }\n    else if (type === 'LineString' || type === 'MultiLineString') {\n        return 'line';\n    }\n    if (type === 'Point' || type === 'MultiPoint') {\n        return 'point';\n    }\n};\n\nGeo.centroid = function (polygon) {\n    let n = polygon.length;\n    let centroid = [0, 0];\n\n    for (let p=0; p < polygon.length; p++) {\n        centroid[0] += polygon[p][0];\n        centroid[1] += polygon[p][1];\n    }\n\n    centroid[0] /= n;\n    centroid[1] /= n;\n\n    return centroid;\n};\n\nGeo.multiCentroid = function (polygons) {\n    let n = polygons.length;\n    let centroid = [0, 0];\n\n    for (let p=0; p < polygons.length; p++) {\n        let polygon = polygons[p][0];\n        let c = Geo.centroid(polygon);\n        centroid[0] += c[0];\n        centroid[1] += c[1];\n    }\n\n    centroid[0] /= n;\n    centroid[1] /= n;\n\n    return centroid;\n};\n\nGeo.signedPolygonAreaSum = function (polygon) {\n    let area = 0;\n    let n = polygon.length;\n\n    for (let i = 0; i < n - 1; i++) {\n        let p0 = polygon[i];\n        let p1 = polygon[i+1];\n\n        area += p0[0] * p1[1] - p1[0] * p0[1];\n    }\n\n    area += polygon[n - 1][0] * polygon[0][1] - polygon[0][0] * polygon[n - 1][1];\n    return area;\n};\n\n// TODO: subtract inner ring areas\nGeo.polygonArea = function (polygon) {\n    return Math.abs(Geo.signedPolygonAreaSum(polygon)) / 2;\n};\n\nGeo.multiPolygonArea = function (polygons) {\n    let area = 0;\n\n    for (let p=0; p < polygons.length; p++) {\n        let polygon = polygons[p][0];\n        area += Geo.polygonArea(polygon);\n    }\n\n    return area;\n};\n\nGeo.ringWinding = function (ring) {\n    return Geo.signedPolygonAreaSum(ring) > 0 ? 'CW' : 'CCW';\n};\n\n// Enforce winding order on outer/inner rings\n// winding: 'CW' or 'CCW'\nGeo.enforceWinding = function (geom, winding) {\n    let polys;\n    if (geom.type === 'Polygon') {\n        polys = [geom.coordinates];\n    }\n    else if (geom.type === 'MultiPolygon') {\n        polys = geom.coordinates;\n    }\n    else {\n        return geom;\n    }\n\n    for (let p=0; p < polys.length; p++) {\n        let poly = polys[p];\n\n        // If first ring winding doesn't match, reverse all rings\n        // NOTE: assumes ring winding orders already alternate as expected\n        if (Geo.ringWinding(poly[0]) !== winding) {\n            for (let ring of poly) {\n                ring.reverse();\n            }\n        }\n    }\n    return geom;\n};\n","// WebGL constants - need to import these separately to make them available in the web worker\n\nvar gl;\nexport default gl = {};\n\n/* DataType */\ngl.BYTE                           = 0x1400;\ngl.UNSIGNED_BYTE                  = 0x1401;\ngl.SHORT                          = 0x1402;\ngl.UNSIGNED_SHORT                 = 0x1403;\ngl.INT                            = 0x1404;\ngl.UNSIGNED_INT                   = 0x1405;\ngl.FLOAT                          = 0x1406;\n","// WebGL context wrapper\n\nvar Context;\nexport default Context = {};\n\n// Setup a WebGL context\n// If no canvas element is provided, one is created and added to the document body\nContext.getContext = function getContext (canvas, options)\n{\n    var fullscreen = false;\n    if (canvas == null) {\n        canvas = document.createElement('canvas');\n        canvas.style.position = 'absolute';\n        canvas.style.top = 0;\n        canvas.style.left = 0;\n        canvas.style.zIndex = -1;\n        document.body.appendChild(canvas);\n        fullscreen = true;\n    }\n\n    var gl = canvas.getContext('webgl', options) || canvas.getContext('experimental-webgl', options);\n    if (!gl) {\n        throw new Error(\"Couldn't create WebGL context.\");\n    }\n\n    Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\n    if (fullscreen === true) {\n        window.addEventListener('resize', function () {\n            Context.resize(gl, window.innerWidth, window.innerHeight);\n        });\n    }\n\n    return gl;\n};\n\nContext.resize = function (gl, width, height, device_pixel_ratio)\n{\n    device_pixel_ratio = device_pixel_ratio || window.devicePixelRatio || 1;\n    gl.canvas.style.width = width + 'px';\n    gl.canvas.style.height = height + 'px';\n    gl.canvas.width = Math.round(gl.canvas.style.width * device_pixel_ratio);\n    gl.canvas.height = Math.round(gl.canvas.style.width * device_pixel_ratio);\n    gl.viewport(0, 0, gl.canvas.width, gl.canvas.height);\n};\n","// WebGL extension wrapper\n// Stores extensions by name and GL context\n\nlet extensions = new Map(); // map of extensions by GL context\n\nexport default function getExtension (gl, name) {\n    let exts = extensions.get(gl);\n    if (!exts) {\n        extensions.set(gl, new Map());\n        exts = extensions.get(gl);\n    }\n\n    if (!exts.get(name)) {\n        exts.set(name, gl.getExtension(name));\n    }\n    return exts.get(name);\n}\n","var GLSL = {};\nexport default GLSL;\n\n/**\n    Parse uniforms from a JS object, infers types and returns an array of objects with the\n    necessary information to set uniform values on a GL program. Each object in the returned\n    array has the form:\n    { type, method, name, value }\n\n    type: the GL uniform type, such as 'vec3', 'float', etc.\n    method: the GL uniform setter method to use, such as '1f', '3fv', etc.\n    name: the fully qualified name of the GL uniform location, e.g. 'array[0].field', etc.\n    value: the value to be passed to the GL uniform setter for that type, e.g. [1, 2, 3] for a vec3\n\n    Textures have special behavior: uniforms with string values are treated as textures, and\n    the string is used as a unique texture 'key' to be interpreted by the caller (which is responsible\n    for actually setting the uniforms). For example, this could be used as a key into a dictionary of\n    known texture names, or it could simply be used as a URL to dynamically load the texture from.\n*/\nGLSL.parseUniforms = function (uniforms, prefix = null) {\n    var parsed = [];\n\n    for (var name in uniforms) {\n        var key = name; // save the original name\n        var uniform = uniforms[name];\n        var u;\n\n        if (prefix) {\n            name = prefix + '.' + name;\n        }\n\n        // Single float\n        if (typeof uniform === 'number') {\n            parsed.push({\n                type: 'float',\n                method: '1f',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Array: vector, array of floats, array of textures, or array of structs\n        else if (Array.isArray(uniform)) {\n            // Numeric values\n            if (typeof uniform[0] === 'number') {\n                // float vectors (vec2, vec3, vec4)\n                if (uniform.length >= 2 && uniform.length <= 4) {\n                    parsed.push({\n                        type: 'vec' + uniform.length,\n                        method: uniform.length + 'fv',\n                        name,\n                        value: uniform,\n                        key,\n                        uniforms\n                    });\n                }\n                // float array\n                else if (uniform.length > 4) {\n                    parsed.push({\n                        type: 'float[]',\n                        method: '1fv',\n                        name: name + '[0]',\n                        value: uniform,\n                        key,\n                        uniforms\n                    });\n                }\n                // TODO: assume matrix for (typeof == Float32Array && length == 16)?\n            }\n            // Array of textures\n            else if (typeof uniform[0] === 'string') {\n                for (u=0; u < uniform.length; u++) {\n                    parsed.push({\n                        type: 'sampler2D',\n                        method: '1i',\n                        name: name + '[' + u + ']',\n                        value: uniform[u],\n                        key: u,\n                        uniforms: uniform\n                    });\n                }\n            }\n            // Array of arrays - but only arrays of vectors are allowed in this case\n            else if (Array.isArray(uniform[0]) && typeof uniform[0][0] === 'number') {\n                // float vectors (vec2, vec3, vec4)\n                if (uniform[0].length >= 2 && uniform[0].length <= 4) {\n                    // Set each vector in the array\n                    for (u=0; u < uniform.length; u++) {\n                        parsed.push({\n                            type: 'vec' + uniform[0].length,\n                            method: uniform[u].length + 'fv',\n                            name: name + '[' + u + ']',\n                            value: uniform[u],\n                            key: u,\n                            uniforms: uniform\n                        });\n                    }\n                }\n                // else error?\n            }\n            // Array of structures\n            else if (typeof uniform[0] === 'object') {\n                for (u=0; u < uniform.length; u++) {\n                    // Set each struct in the array\n                    parsed.push(...GLSL.parseUniforms(uniform[u], name + '[' + u + ']'));\n                }\n            }\n        }\n        // Boolean\n        else if (typeof uniform === 'boolean') {\n            parsed.push({\n                type: 'bool',\n                method: '1i',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Texture\n        else if (typeof uniform === 'string') {\n            parsed.push({\n                type: 'sampler2D',\n                method: '1i',\n                name,\n                value: uniform,\n                key,\n                uniforms\n            });\n        }\n        // Structure\n        else if (typeof uniform === 'object') {\n            // Set each field in the struct\n            parsed.push(...GLSL.parseUniforms(uniform, name));\n        }\n\n        // TODO: support other non-float types? (int, etc.)\n    }\n\n    return parsed;\n};\n\n/**\n    Generate a GLSL variable definition from a JS object\n*/\nGLSL.defineVariable = function (name, value, prefix = null) {\n    var type, array;\n    var structs = '';\n    prefix = prefix ? prefix + '_' + name : name;\n\n    // Single float\n    if (typeof value === 'number') {\n        type = 'float';\n    }\n    // Multiple floats - vector or array\n    else if (Array.isArray(value)) {\n        // Numeric values\n        if (typeof value[0] === 'number') {\n            // float vectors (vec2, vec3, vec4)\n            if (value.length >= 2 && value.length <= 4) {\n                type = 'vec' + value.length;\n            }\n            // float array\n            else { //if (value.length > 4) {\n                type = 'float';\n                array = value.length;\n            }\n            // TODO: assume matrix for (typeof == Float32Array && length == 16)?\n        }\n        // Array of textures\n        else if (typeof value[0] === 'string') {\n            type = 'sampler2D';\n            array = value.length;\n        }\n        // Array of arrays - but only arrays of vectors are allowed in this case\n        else if (Array.isArray(value[0]) && typeof value[0][0] === 'number') {\n            // float vectors (vec2, vec3, vec4)\n            if (value[0].length >= 2 && value[0].length <= 4) {\n                type = 'vec' + value[0].length;\n            }\n            // else error?\n            array = value[0].length;\n        }\n        // Array of structures\n        else if (typeof value[0] === 'object') {\n            type = '_type_' + prefix; // custom struct name\n            array = value.length;\n            structs += GLSL.defineStruct(type, value[0], prefix) + '\\n'; // build & add to list of dependent structs\n        }\n    }\n    // Boolean\n    else if (typeof value === 'boolean') {\n        type = 'bool';\n    }\n    // Texture\n    else if (typeof value === 'string') {\n        type = 'sampler2D';\n    }\n    // Structure\n    else if (typeof value === 'object') {\n        type = '_type_' + prefix; // custom struct name\n        structs += GLSL.defineStruct(type, value, prefix) + '\\n'; // build & add to list of dependent structs\n    }\n\n    // Construct variable definition\n    var variable = '';\n    variable += `${type} ${name}`;\n    if (array) {\n        variable += `[${array}]`;\n    }\n    variable += ';\\n';\n\n    // Return the variable definition itself, and any dependent struct definitions\n    return { variable, structs };\n};\n\n/**\n    Generate a GLSL structure definition from a JS object\n*/\nGLSL.defineStruct = function (type, value, prefix = null) {\n    var struct = `struct ${type} {\\n`;\n    var dependents = '';\n    for (var field in value) {\n        var subvar = GLSL.defineVariable(field, value[field], prefix);\n        struct += '    ' + subvar.variable;\n        dependents += subvar.structs;\n    }\n    struct += '};\\n';\n    struct = dependents + struct;\n    return struct;\n};\n\n/**\n    Generate a GLSL uniform definition from a JS object\n*/\nGLSL.defineUniform = function (name, value) {\n    var def = GLSL.defineVariable(name, value);\n    def = def.structs + 'uniform ' + def.variable;\n    return def;\n};\n\n/**\n    Check for a uniform definition of 'name' in the provided GLSL source\n    Simple regex check for 'uniform' keyword and var name, does not attempt to parse/extract GLSL\n    NOTE: assumes comments have been stripped from source\n*/\nGLSL.isUniformDefined = function (name, source) {\n    // Match, in order:\n    // - the keyword 'uniform'\n    // - at least one character that is anything except a semicolon, ;\n    // - optionally, anything enclosed in curly braces, { ... } (an inline structure definition can go here)\n    // - optionally, any # of characters that is not a semicolon, ;\n    // - the name of the uniform\n\n    var re = new RegExp('uniform[^;]+(?:{[\\\\s\\\\S]*})?[^;]*\\\\b' + name + '\\\\b', 'g');\n    if (source.match(re)) {\n        return true;\n    }\n    return false;\n};\n\n/**\n    Check that a symbol is referenced in the GLSL source\n    NOTE: assumes comments have been stripped from source\n*/\nGLSL.isSymbolReferenced = function (name, source) {\n    var re = new RegExp('\\\\b' + name + '\\\\b', 'g');\n    if (source.search(re) >= 0) {\n        return true;\n    }\n    return false;\n};\n\n/**\n    Expand a single value or 2-element array into a 3-element array, with the last ( z )\n    coordinate defaulting to 1 (with option to specify). Also runs parseFloat to try to maintain\n    data integrity. Returns null if input couldn't be parsed.\n*/\nGLSL.expandVec3 = function (v, z = 1) {\n    let x;\n    if (Array.isArray(v) && v.length === 2) {\n        x = [...v, z].map(parseFloat);\n    }\n    else {\n        x = [v, v, v].map(parseFloat);\n    }\n\n    if (x && x.every(n => typeof n === 'number' && !isNaN(n))) {\n        return x;\n    }\n};\n\n/**\n    Expand a single value or 3-element array into a 4-element array, with the last (e.g. w or a)\n    coordinate defaulting to 1 (with option to specify). Also runs parseFloat to try to maintain\n    data integrity. Returns null if input couldn't be parsed.\n*/\nGLSL.expandVec4 = function (v, w = 1) {\n    let x;\n    if (Array.isArray(v) && v.length === 3) {\n        x = [...v, w].map(parseFloat);\n    }\n    else {\n        x = [v, v, v, w].map(parseFloat);\n    }\n\n    if (x && x.every(n => typeof n === 'number' && !isNaN(n))) {\n        return x;\n    }\n};\n\n\n","\nexport default class RenderState {\n\tconstructor (value, setup) {\n        setup(value);\n        this.value = value;\n        this.setup = setup;\n    }\n\n    set (value) {\n    \t// if the states are different, call the GL context for a state change\n    \tif (JSON.stringify(this.value) !== JSON.stringify(value)) {\n    \t\tthis.setup(value);\n    \t\tthis.value = value;\n    \t}\n    }\n\n    static initialize (gl) {\n    \t// Culling\n    \tRenderState.culling = new RenderState(\n    \t\t{ cull: true, face: gl.BACK },\n    \t\t(value) => {\n    \t\t\tif (value.cull) {\n    \t\t\t\tgl.enable(gl.CULL_FACE);\n            \t\tgl.cullFace(value.face);\n    \t\t\t} else {\n    \t\t\t\tgl.disable(gl.CULL_FACE);\n    \t\t\t}\n    \t\t}\n    \t);\n\n    \t// Blending mode\n    \tRenderState.blending = new RenderState(\n    \t\t{ blend: false, src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA},\n    \t\t(value) => {\n    \t\t\tif (value.blend) {\n            \t\tgl.enable(gl.BLEND);\n                \tgl.blendFunc(value.src, value.dst);\n    \t\t\t} else {\n    \t\t\t\tgl.disable(gl.BLEND);\n    \t\t\t}\n    \t\t}\n    \t);\n\n    \t// Depth write\n    \tRenderState.depth_write = new RenderState(\n    \t\t{ depth_write: true },\n    \t\t(value) => {\n        \t\tgl.depthMask(value.depth_write);\n    \t\t}\n    \t);\n\n    \t// Depth test\n    \tRenderState.depth_test = new RenderState(\n    \t\t{ depth_test: true, depth_func: gl.LEQUAL },\n    \t\t(value) => {\n    \t\t\tif (value.depth_test) {\n            \t\tgl.enable(gl.DEPTH_TEST);\n        \t\t\tgl.depthFunc(value.depth_func);\n    \t\t\t} else {\n            \t\tgl.disable(gl.DEPTH_TEST);\n    \t\t\t}\n    \t\t}\n    \t);\n    }\n}\n","/* global ShaderProgram */\n// GL program wrapper to cache uniform locations/values, do compile-time pre-processing\n// (injecting #defines and #pragma blocks into shaders), etc.\n\nimport GLSL from './glsl';\nimport Texture from './texture';\nimport getExtension from './extensions';\n\nimport log from 'loglevel';\nimport strip from 'strip-comments';\nimport { default as parseShaderErrors } from 'gl-shader-errors';\n\nexport default class ShaderProgram {\n\n    constructor(gl, vertex_source, fragment_source, options) {\n        options = options || {};\n\n        this.gl = gl;\n        this.program = null;\n        this.compiled = false;\n        this.compiling = false;\n        this.error = null;\n\n        // key/values inserted as #defines into shaders at compile-time\n        this.defines = Object.assign({}, options.defines||{});\n\n        // key/values for blocks that can be injected into shaders at compile-time\n        this.blocks = Object.assign({}, options.blocks||{});\n        this.block_scopes = Object.assign({}, options.block_scopes||{});\n\n        // list of extensions to activate\n        this.extensions = options.extensions || [];\n\n        // JS-object uniforms that are expected by this program\n        // If they are not found in the existing shader source, their types will be inferred and definitions\n        // for each will be injected.\n        this.dependent_uniforms = options.uniforms;\n\n        this.uniforms = {}; // program locations of uniforms, lazily added as each uniform is set\n        this.attribs = {}; // program locations of vertex attributes, lazily added as each attribute is accessed\n\n        this.vertex_source = vertex_source;\n        this.fragment_source = fragment_source;\n\n        this.id = ShaderProgram.id++;\n        ShaderProgram.programs[this.id] = this;\n        this.name = options.name; // can provide a program name (useful for debugging)\n    }\n\n    destroy() {\n        this.gl.useProgram(null);\n        this.gl.deleteProgram(this.program);\n        this.program = null;\n        this.uniforms = {};\n        this.attribs = {};\n        delete ShaderProgram.programs[this.id];\n        this.compiled = false;\n    }\n\n    // Use program wrapper with simple state cache\n    use() {\n        if (!this.compiled) {\n            return;\n        }\n\n        if (ShaderProgram.current !== this) {\n            this.gl.useProgram(this.program);\n        }\n        ShaderProgram.current = this;\n    }\n\n    compile() {\n        if (this.compiling) {\n            throw(new Error(`ShaderProgram.compile(): skipping for ${this.id} (${this.name}) because already compiling`));\n        }\n        this.compiling = true;\n        this.compiled = false;\n        this.error = null;\n\n        // Copy sources from pre-modified template\n        this.computed_vertex_source = this.vertex_source;\n        this.computed_fragment_source = this.fragment_source;\n\n        // Check for extension availability\n        let extensions = this.checkExtensions();\n\n        // Make list of defines to be injected later\n        var defines = this.buildDefineList();\n\n        // Inject user-defined blocks (arbitrary code points matching named #pragmas)\n        // Replace according to this pattern:\n        // #pragma tangram: [key]\n        // e.g. #pragma tangram: global\n\n        // Gather all block code snippets\n        var blocks = this.buildShaderBlockList();\n        var regexp;\n\n        for (var key in blocks) {\n            var block = blocks[key];\n            if (!block || (Array.isArray(block) && block.length === 0)) {\n                continue;\n            }\n\n            // First find code replace points in shaders\n            regexp = new RegExp('^\\\\s*#pragma\\\\s+tangram:\\\\s+' + key + '\\\\s*$', 'm');\n            var inject_vertex = this.computed_vertex_source.match(regexp);\n            var inject_fragment = this.computed_fragment_source.match(regexp);\n\n            // Avoid network request if nothing to replace\n            if (inject_vertex == null && inject_fragment == null) {\n                continue;\n            }\n\n            // Combine all blocks into one string\n            var source = '';\n            block.forEach(val => {\n                // Mark start and end of each block with metadata (which can be extracted from\n                // final source for error handling, debugging, etc.)\n                let mark = `${val.scope}, ${val.key}, ${val.num}`;\n                source += `\\n// tangram-block-start: ${mark}\\n`;\n                source += val.source;\n                source += `\\n// tangram-block-end: ${mark}\\n`;\n            });\n\n            // Inject\n            if (inject_vertex != null) {\n                this.computed_vertex_source = this.computed_vertex_source.replace(regexp, source);\n            }\n            if (inject_fragment != null) {\n                this.computed_fragment_source = this.computed_fragment_source.replace(regexp, source);\n            }\n\n            // Add a #define for this injection point\n            defines['TANGRAM_BLOCK_' + key.replace(/[\\s-]+/g, '_').toUpperCase()] = true;\n        }\n\n        // Clean-up any #pragmas that weren't replaced (to prevent compiler warnings)\n        regexp = new RegExp('^\\\\s*#pragma.*$', 'gm');\n        this.computed_vertex_source = this.computed_vertex_source.replace(regexp, '');\n        this.computed_fragment_source = this.computed_fragment_source.replace(regexp, '');\n\n        // Detect uniform definitions, inject any missing ones\n        this.ensureUniforms(this.dependent_uniforms);\n\n        // Build & inject extensions & defines\n        // This is done *after* code injection so that we can add defines for which code points were injected\n        let info = (this.name ? (this.name + ' / id ' + this.id) : ('id ' + this.id));\n        let header = `// Program: ${info}\\n` +\n            ShaderProgram.buildExtensionString(extensions);\n\n        defines['TANGRAM_VERTEX_SHADER'] = true;\n        defines['TANGRAM_FRAGMENT_SHADER'] = false;\n        this.computed_vertex_source = header + ShaderProgram.buildDefineString(defines) + this.computed_vertex_source;\n\n        defines['TANGRAM_VERTEX_SHADER'] = false;\n        defines['TANGRAM_FRAGMENT_SHADER'] = true;\n        this.computed_fragment_source = header + ShaderProgram.buildDefineString(defines) + this.computed_fragment_source;\n\n        // Add precision qualifier\n        this.computed_fragment_source = '#ifdef GL_ES\\nprecision highp float;\\n#endif\\n\\n' + this.computed_fragment_source;\n\n        // Compile & set uniforms to cached values\n        try {\n            this.program = ShaderProgram.updateProgram(this.gl, this.program, this.computed_vertex_source, this.computed_fragment_source);\n            this.compiled = true;\n            this.compiling = false;\n        }\n        catch(error) {\n            this.program = null;\n            this.compiled = false;\n            this.compiling = false;\n            this.error = error;\n\n            // shader error info\n            if (error.type === 'vertex' || error.type === 'fragment') {\n                this.shader_errors = error.errors;\n                for (let e of this.shader_errors) {\n                    e.type = error.type;\n                    e.block = this.block(error.type, e.line);\n                }\n            }\n\n            throw(new Error(`ShaderProgram.compile(): program ${this.id} (${this.name}) error:`, error));\n        }\n\n        this.use();\n        this.refreshUniforms();\n        this.refreshAttributes();\n    }\n\n    // Make list of defines (global, then program-specific)\n    buildDefineList() {\n        var d, defines = {};\n        for (d in ShaderProgram.defines) {\n            defines[d] = ShaderProgram.defines[d];\n        }\n        for (d in this.defines) {\n            defines[d] = this.defines[d];\n        }\n        return defines;\n    }\n\n    // Make list of shader blocks (global, then program-specific)\n    buildShaderBlockList() {\n        let key, blocks = {};\n\n        // Global blocks\n        for (key in ShaderProgram.blocks) {\n            blocks[key] = [];\n\n            if (Array.isArray(ShaderProgram.blocks[key])) {\n                blocks[key].push(\n                    ...ShaderProgram.blocks[key].map((source, num) => {\n                        return { key, source, num, scope: 'ShaderProgram' };\n                    })\n                );\n            }\n            else {\n                blocks[key] = [{ key, source: ShaderProgram.blocks[key], num: 0, scope: 'ShaderProgram' }];\n            }\n        }\n\n        // Program-specific blocks\n        for (key in this.blocks) {\n            blocks[key] = blocks[key] || [];\n\n            if (Array.isArray(this.blocks[key])) {\n                let scopes = (this.block_scopes && this.block_scopes[key]) || [];\n                let cur_scope = null, num = 0;\n\n                for (let b=0; b < this.blocks[key].length; b++) {\n                    // Count blocks relative to current scope\n                    if (scopes[b] !== cur_scope) {\n                        cur_scope = scopes[b];\n                        num = 0;\n                    }\n\n                    blocks[key].push({\n                        key,\n                        source: this.blocks[key][b],\n                        num,\n                        scope: cur_scope || this.name\n                    });\n\n                    num++;\n                }\n            }\n            else {\n                // TODO: address discrepancy in array vs. single-value blocks\n                // styles assume array when tracking block scopes\n                blocks[key].push({ key, source: this.blocks[key], num: 0, scope: this.name });\n            }\n        }\n        return blocks;\n    }\n\n    // Detect uniform definitions, inject any missing ones\n    ensureUniforms(uniforms) {\n        if (!uniforms) {\n            return;\n        }\n\n        var vs = strip(this.computed_vertex_source);\n        var fs = strip(this.computed_fragment_source);\n        var inject, vs_injections = [], fs_injections = [];\n\n        // Check for missing uniform definitions\n        for (var name in uniforms) {\n            inject = null;\n\n            // Check vertex shader\n            if (!GLSL.isUniformDefined(name, vs) && GLSL.isSymbolReferenced(name, vs)) {\n                if (!inject) {\n                    inject = GLSL.defineUniform(name, uniforms[name]);\n                }\n                log.trace(`Program ${this.name}: ${name} not defined in vertex shader, injecting: '${inject}'`);\n                vs_injections.push(inject);\n\n            }\n            // Check fragment shader\n            if (!GLSL.isUniformDefined(name, fs) && GLSL.isSymbolReferenced(name, fs)) {\n                if (!inject) {\n                    inject = GLSL.defineUniform(name, uniforms[name]);\n                }\n                log.trace(`Program ${this.name}: ${name} not defined in fragment shader, injecting: '${inject}'`);\n                fs_injections.push(inject);\n            }\n        }\n\n        // Inject missing uniforms\n        // NOTE: these are injected at the very top of the shaders, even before any #defines or #pragmas are added\n        // this could cause some issues with certain #pragmas, or other functions that might expect #defines\n        if (vs_injections.length > 0) {\n            this.computed_vertex_source = vs_injections.join('\\n') + this.computed_vertex_source;\n        }\n\n        if (fs_injections.length > 0) {\n            this.computed_fragment_source = fs_injections.join('\\n') + this.computed_fragment_source;\n        }\n    }\n\n    // Set uniforms from a JS object, with inferred types\n    setUniforms(uniforms, reset_texture_unit = true) {\n        if (!this.compiled) {\n            return;\n        }\n\n        // TODO: only update uniforms when changed\n\n        // Texture units must be tracked and incremented each time a texture sampler uniform is set.\n        // By default, the texture unit is reset to 0 each time setUniforms is called, but they can\n        // also be preserved, for example in cases where multiple calls to setUniforms are expected\n        // (e.g. program-specific uniforms followed by mesh-specific ones).\n        if (reset_texture_unit) {\n            this.texture_unit = 0;\n        }\n\n        // Parse uniform types and values from the JS object\n        var parsed = GLSL.parseUniforms(uniforms);\n\n        // Set each uniform\n        for (var uniform of parsed) {\n            if (uniform.type === 'sampler2D') {\n                // For textures, we need to track texture units, so we have a special setter\n                this.setTextureUniform(uniform.name, uniform.value);\n            }\n            else {\n                this.uniform(uniform.method, uniform.name, uniform.value);\n            }\n        }\n    }\n\n    // Cache some or all uniform values so they can be restored\n    saveUniforms(subset) {\n        let uniforms = subset || this.uniforms;\n        for (let u in uniforms) {\n            let uniform = this.uniforms[u];\n            if (uniform) {\n                uniform.saved_value = uniform.value;\n            }\n        }\n        this.saved_texture_unit = this.texture_unit || 0;\n    }\n\n    // Restore some or all uniforms to saved values\n    restoreUniforms(subset) {\n        let uniforms = subset || this.uniforms;\n        for (let u in uniforms) {\n            let uniform = this.uniforms[u];\n            if (uniform && uniform.saved_value) {\n                uniform.value = uniform.saved_value;\n                this.updateUniform(u);\n            }\n        }\n        this.texture_unit = this.saved_texture_unit || 0;\n    }\n\n    // Set a texture uniform, finds texture by name or creates a new one\n    setTextureUniform(uniform_name, texture_name) {\n        var texture = Texture.textures[texture_name];\n        if (texture == null) {\n            texture = new Texture(this.gl, texture_name);\n            texture.load(texture_name);\n        }\n\n        texture.bind(this.texture_unit);\n        this.uniform('1i', uniform_name, this.texture_unit);\n        this.texture_unit++; // TODO: track max texture units and log/throw errors\n    }\n\n    // ex: program.uniform('3f', 'position', x, y, z);\n    // TODO: only update uniforms when changed\n    uniform(method, name, ...value) { // 'value' is a method-appropriate arguments list\n        if (!this.compiled) {\n            return;\n        }\n\n        this.uniforms[name] = this.uniforms[name] || {};\n        let uniform = this.uniforms[name];\n        uniform.name = name;\n        if (uniform.location === undefined) {\n            uniform.location = this.gl.getUniformLocation(this.program, name);\n        }\n        uniform.method = 'uniform' + method;\n        uniform.value = value;\n        this.updateUniform(name);\n    }\n\n    // Set a single uniform\n    updateUniform(name) {\n        if (!this.compiled) {\n            return;\n        }\n\n        var uniform = this.uniforms[name];\n        if (!uniform || uniform.location == null) {\n            return;\n        }\n\n        this.use();\n        this.gl[uniform.method].apply(this.gl, [uniform.location].concat(uniform.value)); // call appropriate GL uniform method and pass through arguments\n    }\n\n    // Refresh uniform locations and set to last cached values\n    refreshUniforms() {\n        if (!this.compiled) {\n            return;\n        }\n\n        for (var u in this.uniforms) {\n            this.uniforms[u].location = this.gl.getUniformLocation(this.program, u);\n            this.updateUniform(u);\n        }\n    }\n\n    refreshAttributes() {\n        // var len = this.gl.getProgramParameter(this.program, this.gl.ACTIVE_ATTRIBUTES);\n        // for (var i=0; i < len; i++) {\n        //     var a = this.gl.getActiveAttrib(this.program, i);\n        // }\n        this.attribs = {};\n    }\n\n    // Get the location of a vertex attribute\n    attribute(name) {\n        if (!this.compiled) {\n            return;\n        }\n\n        var attrib = (this.attribs[name] = this.attribs[name] || {});\n        if (attrib.location != null) {\n            return attrib;\n        }\n\n        attrib.name = name;\n        attrib.location = this.gl.getAttribLocation(this.program, name);\n\n        // var info = this.gl.getActiveAttrib(this.program, attrib.location);\n        // attrib.type = info.type;\n        // attrib.size = info.size;\n\n        return attrib;\n    }\n\n    // Get shader source as string\n    source(type) {\n        if (type === 'vertex') {\n            return this.computed_vertex_source;\n        }\n        else if (type === 'fragment') {\n            return this.computed_fragment_source;\n        }\n    }\n\n    // Get shader source as array of line strings\n    lines(type) {\n        let source = this.source(type);\n        if (source) {\n            return source.split('\\n');\n        }\n        return [];\n    }\n\n    // Get a specific line from shader source\n    line(type, num) {\n        let source = this.lines(type);\n        if (source) {\n            return source[num];\n        }\n    }\n\n    // Get info on which shader block (if any) a particular line number in a shader is in\n    // Returns an object with the following info if a block is found: { name, line, source }\n    //  scope: where the shader block originated, either a style name, or global such as ShaderProgram\n    //  name: shader block name (e.g. 'color', 'position', 'global')\n    //  num: the block number *within* local scope (e.g. if a style has multiple 'color' blocks)\n    //  line: line number *within* the shader block (not the whole shader program), useful for error highlighting\n    //  source: the code for the line\n    // NOTE: this does a bruteforce loop over the shader source and looks for shader block start/end markers\n    // We could track line ranges for shader blocks as they are inserted, but as this code is only used for\n    // error handling on compilation failure, it was simpler to keep it separate than to burden the core\n    // compilation path.\n    block(type, num) {\n        let lines = this.lines(type);\n        let block;\n        for (let i=0; i < num && i < lines.length; i++) {\n            let line = lines[i];\n            let match = line.match(/\\/\\/ tangram-block-start: (\\w+), (\\w+), (\\d+)/);\n            if (match && match.length > 1) {\n                // mark current block\n                block = {\n                    scope: match[1],\n                    name: match[2],\n                    num: match[3]\n                };\n            }\n            else {\n                match = line.match(/\\/\\/ tangram-block-end: (\\w+), (\\w+), (\\d+)/);\n                if (match && match.length > 1) {\n                    block = null; // clear current block\n                }\n            }\n\n            // update line # and content\n            if (block) {\n                // init to -1 so that line 0 is first actual line of block code, after comment marker\n                block.line = (block.line == null) ? -1 : block.line + 1;\n                block.source = line;\n            }\n        }\n        return block;\n    }\n\n    // Returns list of available extensions from those requested\n    // Sets internal #defines indicating availability of each requested extension\n    checkExtensions() {\n        let exts = [];\n        for (let name of this.extensions) {\n            let ext = getExtension(this.gl, name);\n            let def = `TANGRAM_EXTENSION_${name}`;\n\n            this.defines[def] = (ext != null);\n\n            if (ext) {\n                exts.push(name);\n            }\n            else {\n                log.debug(`Could not enable extension '${name}'`);\n            }\n        }\n        return exts;\n    }\n\n}\n\n\n// Static methods and state\n\nShaderProgram.id = 0;           // assign each program a unique id\nShaderProgram.programs = {};    // programs, by id\nShaderProgram.current = null;   // currently bound program\n\n// Global config applied to all programs (duplicate properties for a specific program will take precedence)\nShaderProgram.defines = {};\nShaderProgram.blocks = {};\n\n// Turn an object of key/value pairs into single string of #define statements\nShaderProgram.buildDefineString = function (defines) {\n    var define_str = \"\";\n    for (var d in defines) {\n        if (defines[d] === false) {\n            continue;\n        }\n        else if (typeof defines[d] === 'boolean' && defines[d] === true) { // booleans are simple defines with no value\n            define_str += \"#define \" + d + \"\\n\";\n        }\n        else if (typeof defines[d] === 'number' && Math.floor(defines[d]) === defines[d]) { // int to float conversion to satisfy GLSL floats\n            define_str += \"#define \" + d + \" \" + defines[d].toFixed(1) + \"\\n\";\n        }\n        else { // any other float or string value\n            define_str += \"#define \" + d + \" \" + defines[d] + \"\\n\";\n        }\n    }\n    return define_str;\n};\n\n// Turn a list of extension names into single string of #extension statements\nShaderProgram.buildExtensionString = function (extensions) {\n    extensions = extensions || [];\n    let str = \"\";\n    for (let ext of extensions) {\n        str += `#extension GL_${ext} : enable\\n`;\n    }\n    return str;\n};\n\nShaderProgram.addBlock = function (key, ...blocks) {\n    ShaderProgram.blocks[key] = ShaderProgram.blocks[key] || [];\n    ShaderProgram.blocks[key].push(...blocks);\n};\n\n// Remove all global shader blocks for a given key\nShaderProgram.removeBlock = function (key) {\n    ShaderProgram.blocks[key] = [];\n};\n\nShaderProgram.replaceBlock = function (key, ...blocks) {\n    ShaderProgram.removeBlock(key);\n    ShaderProgram.addBlock(key, ...blocks);\n};\n\n// Compile & link a WebGL program from provided vertex and fragment shader sources\n// update a program if one is passed in. Create one if not. Alert and don't update anything if the shaders don't compile.\nShaderProgram.updateProgram = function (gl, program, vertex_shader_source, fragment_shader_source) {\n    try {\n        var vertex_shader = ShaderProgram.createShader(gl, vertex_shader_source, gl.VERTEX_SHADER);\n        var fragment_shader = ShaderProgram.createShader(gl, fragment_shader_source, gl.FRAGMENT_SHADER);\n    }\n    catch(err) {\n        log.error(err.message);\n        throw err;\n    }\n\n    gl.useProgram(null);\n    if (program != null) {\n        var old_shaders = gl.getAttachedShaders(program);\n        for(var i = 0; i < old_shaders.length; i++) {\n            gl.detachShader(program, old_shaders[i]);\n        }\n    } else {\n        program = gl.createProgram();\n    }\n\n    if (vertex_shader == null || fragment_shader == null) {\n        return program;\n    }\n\n    gl.attachShader(program, vertex_shader);\n    gl.attachShader(program, fragment_shader);\n\n    gl.deleteShader(vertex_shader);\n    gl.deleteShader(fragment_shader);\n\n    gl.linkProgram(program);\n\n    if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {\n        let message = new Error(\n            `WebGL program error:\n            VALIDATE_STATUS: ${gl.getProgramParameter(program, gl.VALIDATE_STATUS)}\n            ERROR: ${gl.getError()}\n            --- Vertex Shader ---\n            ${vertex_shader_source}\n            --- Fragment Shader ---\n            ${fragment_shader_source}`);\n\n        let error = { type: 'program', message };\n        log.error(error.message);\n        throw error;\n    }\n\n    return program;\n};\n\n// Compile a vertex or fragment shader from provided source\nShaderProgram.createShader = function (gl, source, stype) {\n    let shader = gl.createShader(stype);\n\n    gl.shaderSource(shader, source);\n    gl.compileShader(shader);\n\n    if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {\n        let type = (stype === gl.VERTEX_SHADER ? 'vertex' : 'fragment');\n        let message = gl.getShaderInfoLog(shader);\n        let errors = parseShaderErrors(message);\n        throw { type, message, errors };\n    }\n\n    return shader;\n};\n","// Generated from GLSL files, don't edit!\nvar shaderSources = {};\n\nshaderSources['gl/shaders/ambientLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct AmbientLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in AmbientLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"    light_accumulator_ambient += _light.ambient;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/directionalLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct DirectionalLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec3 direction;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in DirectionalLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    light_accumulator_ambient += _light.ambient;\\n\" +\n\"\\n\" +\n\"    float nDotVP = clamp(dot(_normal, -normalize(_light.direction)), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        float pf = 0.0;\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(normalize(_light.direction), _normal);\\n\" +\n\"            float eyeDotR = max(dot(normalize(_eyeToPoint), reflectVector), 0.0);\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"        light_accumulator_specular += _light.specular * pf;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/layer_order'] =\n\"// Apply layer ordering to avoid z-fighting\\n\" +\n\"void applyLayerOrder (float layer, inout vec4 position) {\\n\" +\n\"    position.z -= layer * TANGRAM_LAYER_DELTA * position.w;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/material'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Defines globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"// MATERIALS\\n\" +\n\"//\\n\" +\n\"struct Material {\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_EMISSION\\n\" +\n\"        vec4 emission;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"            vec3 emissionScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_AMBIENT\\n\" +\n\"        vec4 ambient;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"            vec3 ambientScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        vec4 diffuse;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"            vec3 diffuseScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        vec4 specular;\\n\" +\n\"        float shininess;\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"            vec3 specularScale;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"        vec3 normalScale;\\n\" +\n\"        float normalAmount;\\n\" +\n\"    #endif\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"// Note: uniform is copied to a global instance to allow modification\\n\" +\n\"uniform Material u_material;\\n\" +\n\"Material material = u_material;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"uniform sampler2D u_material_emission_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"uniform sampler2D u_material_ambient_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"uniform sampler2D u_material_diffuse_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"uniform sampler2D u_material_specular_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"uniform sampler2D u_material_normal_texture;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Global light accumulators for each property\\n\" +\n\"vec4 light_accumulator_ambient = vec4(0.0);\\n\" +\n\"vec4 light_accumulator_diffuse = vec4(0.0);\\n\" +\n\"#ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"    vec4 light_accumulator_specular = vec4(0.0);\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\\n\" +\n\"vec4 getSphereMap (in sampler2D _tex, in vec3 _eyeToPoint, in vec3 _normal, in vec2 _skew) {\\n\" +\n\"    vec3 eye = normalize(_eyeToPoint);\\n\" +\n\"    eye.xy -= _skew;\\n\" +\n\"    eye = normalize(eye);\\n\" +\n\"\\n\" +\n\"    vec3 r = reflect(eye, _normal);\\n\" +\n\"    r.z += 1.0;\\n\" +\n\"    float m = 2. * length(r);\\n\" +\n\"    vec2 uv = r.xy / m + .5;\\n\" +\n\"    return texture2D(_tex, uv);\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_TRIPLANAR\\n\" +\n\"vec3 getTriPlanarBlend (in vec3 _normal) {\\n\" +\n\"    vec3 blending = abs(_normal);\\n\" +\n\"    blending = normalize(max(blending, 0.00001));\\n\" +\n\"    float b = (blending.x + blending.y + blending.z);\\n\" +\n\"    return blending / b;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"vec4 getTriPlanar (in sampler2D _tex, in vec3 _pos, in vec3 _normal, in vec3 _scale) {\\n\" +\n\"    vec3 blending = getTriPlanarBlend(_normal);\\n\" +\n\"    vec4 xaxis = texture2D(_tex, fract(_pos.yz * _scale.x));\\n\" +\n\"    vec4 yaxis = texture2D(_tex, fract(_pos.xz * _scale.y));\\n\" +\n\"    vec4 zaxis = texture2D(_tex, fract(_pos.xy * _scale.z));\\n\" +\n\"    return  xaxis * blending.x + yaxis * blending.y + zaxis * blending.z;\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_TEXTURE_PLANAR\\n\" +\n\"vec4 getPlanar (in sampler2D _tex, in vec3 _pos, in vec2 _scale) {\\n\" +\n\"    return texture2D( _tex, fract(_pos.xy * _scale.x) );\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"void calculateNormal (inout vec3 _normal) {\\n\" +\n\"    // Get NORMALMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_UV\\n\" +\n\"    _normal += texture2D(u_material_normal_texture, fract(v_texcoord*material.normalScale.xy)).rgb*2.0-1.0;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_PLANAR\\n\" +\n\"    vec3 normalTex = getPlanar(u_material_normal_texture, v_world_position.xyz, material.normalScale.xy).rgb*2.0-1.0;\\n\" +\n\"    _normal += normalTex;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE_TRIPLANAR\\n\" +\n\"    vec3 normalTex = getTriPlanar(u_material_normal_texture, v_world_position.xyz, _normal, material.normalScale).rgb*2.0-1.0;\\n\" +\n\"    _normal += normalTex;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    _normal = normalize(_normal);\\n\" +\n\"}\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"void calculateMaterial (in vec3 _eyeToPoint, inout vec3 _normal) {\\n\" +\n\"    // get EMISSION TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_UV\\n\" +\n\"        material.emission *= texture2D(u_material_emission_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_PLANAR\\n\" +\n\"        material.emission *= getPlanar(u_material_emission_texture, v_world_position.xyz, material.emissionScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_TRIPLANAR\\n\" +\n\"        material.emission *= getTriPlanar(u_material_emission_texture, v_world_position.xyz, _normal, material.emissionScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_EMISSION_TEXTURE_SPHEREMAP\\n\" +\n\"        material.emission *= getSphereMap(u_material_emission_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get AMBIENT TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_UV\\n\" +\n\"        material.ambient *= texture2D(u_material_ambient_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_PLANAR\\n\" +\n\"        material.ambient *= getPlanar(u_material_ambient_texture, v_world_position.xyz, material.ambientScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_TRIPLANAR\\n\" +\n\"        material.ambient *= getTriPlanar(u_material_ambient_texture, v_world_position.xyz, _normal, material.ambientScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_AMBIENT_TEXTURE_SPHEREMAP\\n\" +\n\"        material.ambient *= getSphereMap(u_material_ambient_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get DIFFUSE TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_UV\\n\" +\n\"        material.diffuse *= texture2D(u_material_diffuse_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_PLANAR\\n\" +\n\"        material.diffuse *= getPlanar(u_material_diffuse_texture, v_world_position.xyz, material.diffuseScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_TRIPLANAR\\n\" +\n\"        material.diffuse *= getTriPlanar(u_material_diffuse_texture, v_world_position.xyz, _normal, material.diffuseScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_DIFFUSE_TEXTURE_SPHEREMAP\\n\" +\n\"        material.diffuse *= getSphereMap(u_material_diffuse_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // get SPECULAR TEXTUREMAP\\n\" +\n\"    //------------------------------------------------\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_UV\\n\" +\n\"        material.specular *= texture2D(u_material_specular_texture,v_texcoord);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_PLANAR\\n\" +\n\"        material.specular *= getPlanar(u_material_specular_texture, v_world_position.xyz, material.specularScale.xy);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_TRIPLANAR\\n\" +\n\"        material.specular *= getTriPlanar(u_material_specular_texture, v_world_position.xyz, _normal, material.specularScale);\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_MATERIAL_SPECULAR_TEXTURE_SPHEREMAP\\n\" +\n\"        material.specular *= getSphereMap(u_material_specular_texture, _eyeToPoint, _normal, u_vanishing_point);\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/pointLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct PointLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec4 position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"    float attenuationExponent;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"    float innerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"    float outerRadius;\\n\" +\n\"#endif\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in PointLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    float dist = length(_light.position.xyz - _eyeToPoint);\\n\" +\n\"\\n\" +\n\"    // Compute vector from surface to light position\\n\" +\n\"    vec3 VP = (_light.position.xyz - _eyeToPoint) / dist;\\n\" +\n\"\\n\" +\n\"    // Normalize the vector from surface to light position\\n\" +\n\"    float nDotVP = clamp(dot(VP, _normal), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    // Attenuation defaults\\n\" +\n\"    float attenuation = 1.0;\\n\" +\n\"    #ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"        float Rin = 1.0;\\n\" +\n\"        float e = _light.attenuationExponent;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"            float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"            float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"            attenuation = 1.0-(pow(d,e));\\n\" +\n\"        #else\\n\" +\n\"            // If no outer is provide behaves like:\\n\" +\n\"            // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"            float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"            attenuation = clamp(1.0/(pow(d,e)), 0.0, 1.0);\\n\" +\n\"        #endif\\n\" +\n\"    #else\\n\" +\n\"        float Rin = 0.0;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"                float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                // If no outer is provide behaves like:\\n\" +\n\"                // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"                float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"                attenuation = clamp(1.0/d, 0.0, 1.0);\\n\" +\n\"            #endif\\n\" +\n\"        #else\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float d = clamp(dist/_light.outerRadius, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                attenuation = 1.0;\\n\" +\n\"            #endif\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Computer accumulators\\n\" +\n\"    light_accumulator_ambient += _light.ambient * attenuation;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP * attenuation;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        float pf = 0.0; // power factor for shiny speculars\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(-VP, _normal);\\n\" +\n\"            float eyeDotR = max(0.0, dot(-normalize(_eyeToPoint), reflectVector));\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"\\n\" +\n\"        light_accumulator_specular += _light.specular * pf * attenuation;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_fragment'] =\n\"// Fragment shader for feature selection passes\\n\" +\n\"// Renders in silhouette according to selection (picking) color, or black if none defined\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_FEATURE_SELECTION\\n\" +\n\"    varying vec4 v_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    #ifdef TANGRAM_FEATURE_SELECTION\\n\" +\n\"        gl_FragColor = v_selection_color;\\n\" +\n\"    #else\\n\" +\n\"        gl_FragColor = vec4(0., 0., 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_globals'] =\n\"// Vertex attribute + varying for feature selection\\n\" +\n\"#if defined(TANGRAM_FEATURE_SELECTION) && defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"    attribute vec4 a_selection_color;\\n\" +\n\"    varying vec4 v_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['gl/shaders/selection_vertex'] =\n\"// Selection pass-specific rendering\\n\" +\n\"#if defined(TANGRAM_FEATURE_SELECTION) && defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"    if (a_selection_color.rgb == vec3(0.)) {\\n\" +\n\"        // Discard by forcing invalid triangle if we\\'re in the feature\\n\" +\n\"        // selection pass but have no selection info\\n\" +\n\"        // TODO: in some cases we may actually want non-selectable features to occlude selectable ones?\\n\" +\n\"        gl_Position = vec4(0., 0., 0., 1.);\\n\" +\n\"        return;\\n\" +\n\"    }\\n\" +\n\"    v_selection_color = a_selection_color;\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['gl/shaders/spherical_environment_map'] =\n\"// Spherical environment map\\n\" +\n\"// Based on: http://www.clicktorelease.com/blog/creating-spherical-environment-mapping-shader\\n\" +\n\"\\n\" +\n\"// view: location of camera\\n\" +\n\"// position: location of current point on surface\\n\" +\n\"// normal: normal of current point on surface\\n\" +\n\"// skew: skewing factor (used to compensate for altered vanishing point)\\n\" +\n\"// envmap: spherical environment map texture\\n\" +\n\"\\n\" +\n\"vec4 sphericalEnvironmentMap(vec3 view, vec3 position, vec3 normal, vec2 skew, sampler2D envmap) {\\n\" +\n\"    // Normalized vector from camera to surface\\n\" +\n\"    vec3 eye = normalize(position.xyz - view.xyz);\\n\" +\n\"\\n\" +\n\"    // Skew\\n\" +\n\"    eye.xy -= skew;\\n\" +\n\"    eye = normalize(eye);\\n\" +\n\"\\n\" +\n\"    // Reflection of eye off of surface normal\\n\" +\n\"    vec3 r = reflect(eye, normal);\\n\" +\n\"\\n\" +\n\"    // Map reflected vector onto the surface of a sphere\\n\" +\n\"    r.z += 1.;\\n\" +\n\"    float m = 2. * length(r);\\n\" +\n\"\\n\" +\n\"    // Adjust xy to account for spherical shape, and center in middle of texture\\n\" +\n\"    vec2 uv = r.xy / m + .5;\\n\" +\n\"\\n\" +\n\"    // Sample the environment map\\n\" +\n\"    return texture2D(envmap, uv);\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/spotLight'] =\n\"/*\\n\" +\n\"\\n\" +\n\"Expected globals:\\n\" +\n\"material\\n\" +\n\"light_accumulator_*\\n\" +\n\"\\n\" +\n\"*/\\n\" +\n\"\\n\" +\n\"struct SpotLight {\\n\" +\n\"    vec4 ambient;\\n\" +\n\"    vec4 diffuse;\\n\" +\n\"    vec4 specular;\\n\" +\n\"    vec4 position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"    float attenuationExponent;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"    float innerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"    float outerRadius;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"    vec3 direction;\\n\" +\n\"    float spotCosCutoff;\\n\" +\n\"    float spotExponent;\\n\" +\n\"};\\n\" +\n\"\\n\" +\n\"void calculateLight(in SpotLight _light, in vec3 _eyeToPoint, in vec3 _normal) {\\n\" +\n\"\\n\" +\n\"    float dist = length(_light.position.xyz - _eyeToPoint);\\n\" +\n\"\\n\" +\n\"    // Compute vector from surface to light position\\n\" +\n\"    vec3 VP = (_light.position.xyz - _eyeToPoint) / dist;\\n\" +\n\"\\n\" +\n\"    // normal . light direction\\n\" +\n\"    float nDotVP = clamp(dot(_normal, VP), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    // Attenuation defaults\\n\" +\n\"    float attenuation = 1.0;\\n\" +\n\"    #ifdef TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT\\n\" +\n\"        float Rin = 1.0;\\n\" +\n\"        float e = _light.attenuationExponent;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"        #endif\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"            float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"            float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"            attenuation = 1.0-(pow(d,e));\\n\" +\n\"        #else\\n\" +\n\"            // If no outer is provide behaves like:\\n\" +\n\"            // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"            float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"            attenuation = clamp(1.0/(pow(d,e)), 0.0, 1.0);\\n\" +\n\"        #endif\\n\" +\n\"    #else\\n\" +\n\"        float Rin = 0.0;\\n\" +\n\"\\n\" +\n\"        #ifdef TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS\\n\" +\n\"            Rin = _light.innerRadius;\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float Rdiff = _light.outerRadius-Rin;\\n\" +\n\"                float d = clamp(max(0.0,dist-Rin)/Rdiff, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                // If no outer is provide behaves like:\\n\" +\n\"                // https://imdoingitwrong.wordpress.com/2011/01/31/light-attenuation/\\n\" +\n\"                float d = max(0.0,dist-Rin)/Rin+1.0;\\n\" +\n\"                attenuation = clamp(1.0/d, 0.0, 1.0);\\n\" +\n\"            #endif\\n\" +\n\"        #else\\n\" +\n\"            #ifdef TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS\\n\" +\n\"                float d = clamp(dist/_light.outerRadius, 0.0, 1.0);\\n\" +\n\"                attenuation = 1.0-d*d;\\n\" +\n\"            #else\\n\" +\n\"                attenuation = 1.0;\\n\" +\n\"            #endif\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // spotlight attenuation factor\\n\" +\n\"    float spotAttenuation = 0.0;\\n\" +\n\"\\n\" +\n\"    // See if point on surface is inside cone of illumination\\n\" +\n\"    float spotDot = clamp(dot(-VP, normalize(_light.direction)), 0.0, 1.0);\\n\" +\n\"\\n\" +\n\"    if (spotDot >= _light.spotCosCutoff) {\\n\" +\n\"        spotAttenuation = pow(spotDot, _light.spotExponent);\\n\" +\n\"    }\\n\" +\n\"\\n\" +\n\"    light_accumulator_ambient += _light.ambient * attenuation * spotAttenuation;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_DIFFUSE\\n\" +\n\"        light_accumulator_diffuse += _light.diffuse * nDotVP * attenuation * spotAttenuation;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_SPECULAR\\n\" +\n\"        // Power factor for shiny speculars\\n\" +\n\"        float pf = 0.0;\\n\" +\n\"        if (nDotVP > 0.0) {\\n\" +\n\"            vec3 reflectVector = reflect(-VP, _normal);\\n\" +\n\"            float eyeDotR = max(dot(-normalize(_eyeToPoint), reflectVector), 0.0);\\n\" +\n\"            pf = pow(eyeDotR, material.shininess);\\n\" +\n\"        }\\n\" +\n\"        light_accumulator_specular += _light.specular * pf * attenuation * spotAttenuation;\\n\" +\n\"    #endif\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['gl/shaders/world_position_wrap'] =\n\"// Define a wrap value for world coordinates (allows more precision at higher zooms)\\n\" +\n\"// e.g. at wrap 1000, the world space will wrap every 1000 meters\\n\" +\n\"#if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"    vec2 world_position_anchor = vec2(floor(u_tile_origin / TANGRAM_WORLD_POSITION_WRAP) * TANGRAM_WORLD_POSITION_WRAP);\\n\" +\n\"\\n\" +\n\"    // Convert back to absolute world position if needed\\n\" +\n\"    vec4 absoluteWorldPosition () {\\n\" +\n\"        return vec4(v_world_position.xy + world_position_anchor, v_world_position.z, v_world_position.w);\\n\" +\n\"    }\\n\" +\n\"#else\\n\" +\n\"    vec4 absoluteWorldPosition () {\\n\" +\n\"        return v_world_position;\\n\" +\n\"    }\\n\" +\n\"#endif\\n\" +\n\"\";\n\nshaderSources['styles/points/points_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"\\n\" +\n\"uniform sampler2D u_texture;\\n\" +\n\"\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec2 v_texcoord;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"// Alpha discard threshold (substitute for alpha blending)\\n\" +\n\"#ifndef TANGRAM_ALPHA_DISCARD\\n\" +\n\"#define TANGRAM_ALPHA_DISCARD 0.5\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Alpha fade range for edges of points\\n\" +\n\"#ifndef TANGRAM_FADE_RANGE\\n\" +\n\"#define TANGRAM_FADE_RANGE .15\\n\" +\n\"#endif\\n\" +\n\"#define TANGRAM_FADE_START (1. - TANGRAM_FADE_RANGE)\\n\" +\n\"\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"\\n\" +\n\"    // Apply a texture\\n\" +\n\"    #ifdef TANGRAM_POINT_TEXTURE\\n\" +\n\"        color *= texture2D(u_texture, v_texcoord);\\n\" +\n\"    // Draw a point\\n\" +\n\"    #else\\n\" +\n\"        // Fade alpha near circle edge\\n\" +\n\"        vec2 uv = v_texcoord * 2. - 1.;\\n\" +\n\"        float point_dist = length(uv);\\n\" +\n\"        color.a = clamp(1. - (smoothstep(0., TANGRAM_FADE_RANGE, (point_dist - TANGRAM_FADE_START)) / TANGRAM_FADE_RANGE), 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // If blending is off, use alpha discard as a lower-quality substitute\\n\" +\n\"    #ifndef TANGRAM_BLEND_OVERLAY\\n\" +\n\"        if (color.a < TANGRAM_ALPHA_DISCARD) {\\n\" +\n\"            discard;\\n\" +\n\"        }\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Manually un-multiply alpha, for cases where texture has pre-multiplied alpha\\n\" +\n\"    #ifdef TANGRAM_UNMULTIPLY_ALPHA\\n\" +\n\"        color.rgb /= max(color.a, 0.001);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"    #pragma tangram: filter\\n\" +\n\"\\n\" +\n\"    gl_FragColor = color;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/points/points_vertex'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"\\n\" +\n\"uniform mat4 u_model;\\n\" +\n\"uniform mat4 u_modelView;\\n\" +\n\"\\n\" +\n\"attribute vec4 a_position;\\n\" +\n\"attribute vec4 a_shape;\\n\" +\n\"attribute vec4 a_color;\\n\" +\n\"attribute vec2 a_texcoord;\\n\" +\n\"attribute vec2 a_offset;\\n\" +\n\"\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec2 v_texcoord;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"vec2 rotate2D(vec2 _st, float _angle) {\\n\" +\n\"    return mat2(cos(_angle),-sin(_angle),\\n\" +\n\"                sin(_angle),cos(_angle)) * _st;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Adds vertex shader support for feature selection\\n\" +\n\"    #pragma tangram: feature-selection-vertex\\n\" +\n\"\\n\" +\n\"    v_color = a_color;\\n\" +\n\"    v_texcoord = a_texcoord;\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = u_modelView * vec4(a_position.xyz * 32767., 1.);\\n\" +\n\"\\n\" +\n\"    // Apply positioning and scaling in screen space\\n\" +\n\"    float zscale = fract(u_map_position.z) * (a_shape.w * 256. - 1.) + 1.;\\n\" +\n\"    // float zscale = log(fract(u_map_position.z) + 1.) / log(2.) * (a_shape.w - 1.) + 1.;\\n\" +\n\"    vec2 shape = a_shape.xy * 256. * zscale;     //\\n\" +\n\"    vec2 offset = vec2(a_offset.x, -a_offset.y); // flip y to make it point down\\n\" +\n\"    float theta = radians(a_shape.z * 360.);\\n\" +\n\"\\n\" +\n\"    shape = rotate2D(shape, theta);             // apply rotation to vertex\\n\" +\n\"    shape += rotate2D(offset * 32767., theta);  // apply offset on rotated axis (e.g. so line labels follow text axis)\\n\" +\n\"\\n\" +\n\"    // World coordinates for 3d procedural textures\\n\" +\n\"    v_world_position = u_model * position;\\n\" +\n\"    v_world_position.xy += shape * u_meters_per_pixel;\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"        v_world_position.xy -= world_position_anchor;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify position before camera projection\\n\" +\n\"    #pragma tangram: position\\n\" +\n\"\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_LAYER_ORDER\\n\" +\n\"        applyLayerOrder(a_position.w * 32767., position);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    position.xy += shape * 2. * position.w / u_resolution;\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/polygons/polygons_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"\\n\" +\n\"varying vec4 v_position;\\n\" +\n\"varying vec3 v_normal;\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    varying vec4 v_lighting;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"    vec3 normal = v_normal;\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_MATERIAL_NORMAL_TEXTURE\\n\" +\n\"        calculateNormal(normal);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify normal before lighting\\n\" +\n\"    #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"    // Modify color and material properties before lighting\\n\" +\n\"    #if !defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT)\\n\" +\n\"        color = calculateLighting(v_position.xyz - u_eye, normal, color);\\n\" +\n\"    #elif defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        color = v_lighting;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Modify color after lighting (filter-like effects that don\\'t require a additional render passes)\\n\" +\n\"    #pragma tangram: filter\\n\" +\n\"\\n\" +\n\"    gl_FragColor = color;\\n\" +\n\"}\\n\" +\n\"\";\n\nshaderSources['styles/polygons/polygons_vertex'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec3 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat4 u_model;\\n\" +\n\"uniform mat4 u_modelView;\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"\\n\" +\n\"attribute vec4 a_position;\\n\" +\n\"attribute vec4 a_color;\\n\" +\n\"\\n\" +\n\"// Optional normal attribute, otherwise default to up\\n\" +\n\"#ifdef TANGRAM_NORMAL_ATTRIBUTE\\n\" +\n\"    attribute vec3 a_normal;\\n\" +\n\"    #define TANGRAM_NORMAL a_normal\\n\" +\n\"#else\\n\" +\n\"    #define TANGRAM_NORMAL vec3(0., 0., 1.)\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Optional dynamic line extrusion\\n\" +\n\"#ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"    // xy: extrusion direction in xy plane\\n\" +\n\"    // z:  half-width of line (amount to extrude)\\n\" +\n\"    // w:  scaling factor for interpolating width between zooms\\n\" +\n\"    attribute vec4 a_extrude;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"varying vec4 v_position;\\n\" +\n\"varying vec3 v_normal;\\n\" +\n\"varying vec4 v_color;\\n\" +\n\"varying vec4 v_world_position;\\n\" +\n\"\\n\" +\n\"// Optional texture UVs\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    attribute vec2 a_texcoord;\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"    varying vec4 v_lighting;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#pragma tangram: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Adds vertex shader support for feature selection\\n\" +\n\"    #pragma tangram: feature-selection-vertex\\n\" +\n\"\\n\" +\n\"    // Texture UVs\\n\" +\n\"    #ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"        v_texcoord = a_texcoord;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = vec4(a_position.xyz * 32767., 1.);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"        vec2 extrude = a_extrude.xy * 255.;\\n\" +\n\"        float width = a_extrude.z * 32767.;\\n\" +\n\"        float scale = a_extrude.w * 255.;\\n\" +\n\"\\n\" +\n\"        // Keep line width constant in screen-space\\n\" +\n\"        float zscale = u_tile_origin.z - u_map_position.z;\\n\" +\n\"        width *= pow(2., zscale);\\n\" +\n\"\\n\" +\n\"        // Smoothly interpolate line width between zooms\\n\" +\n\"        width = mix(width, width * scale, -zscale);\\n\" +\n\"\\n\" +\n\"        // Modify line width before extrusion\\n\" +\n\"        #pragma tangram: width\\n\" +\n\"\\n\" +\n\"        position.xy += extrude * width;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // World coordinates for 3d procedural textures\\n\" +\n\"    v_world_position = u_model * position;\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"        v_world_position.xy -= world_position_anchor;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Adjust for tile and view position\\n\" +\n\"    position = u_modelView * position;\\n\" +\n\"\\n\" +\n\"    // Modify position before camera projection\\n\" +\n\"    #pragma tangram: position\\n\" +\n\"\\n\" +\n\"    // Setup varyings\\n\" +\n\"    v_position = position;\\n\" +\n\"    v_normal = normalize(u_normalMatrix * TANGRAM_NORMAL);\\n\" +\n\"    v_color = a_color;\\n\" +\n\"\\n\" +\n\"    // Vertex lighting\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        vec4 color = a_color;\\n\" +\n\"        vec3 normal = TANGRAM_NORMAL;\\n\" +\n\"\\n\" +\n\"        // Modify normal before lighting\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"        // Modify color and material properties before lighting\\n\" +\n\"        #pragma tangram: color\\n\" +\n\"\\n\" +\n\"        v_lighting = calculateLighting(position.xyz, normal, color);\\n\" +\n\"        v_color = color;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Camera\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"    applyLayerOrder(a_position.w * 32767., position);\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nmodule.exports = shaderSources;\n","/*global Texture */\n// Texture management\nimport Utils from '../utils/utils';\nimport subscribeMixin from '../utils/subscribe';\nimport WorkerBroker from '../utils/worker_broker';\nimport Builders from '../styles/builders';\nimport log from 'loglevel';\n\n// GL texture wrapper object for keeping track of a global set of textures, keyed by a unique user-defined name\nexport default class Texture {\n\n    constructor(gl, name, options = {}) {\n        this.gl = gl;\n        this.texture = gl.createTexture();\n        if (this.texture) {\n            this.valid = true;\n        }\n        this.bind();\n        this.image = null;      // an Image object/element that is the source for this texture\n        this.canvas = null;     // a Canvas object/element that is the source for this texture\n        this.loading = null;    // a Promise object to track the loading state of this texture\n\n        // Default to a 1-pixel black texture so we can safely render while we wait for an image to load\n        // See: http://stackoverflow.com/questions/19722247/webgl-wait-for-texture-to-load\n        this.setData(1, 1, new Uint8Array([0, 0, 0, 255]), { filtering: 'nearest' });\n\n        // TODO: better support for non-URL sources: canvas/video elements, raw pixel buffers\n\n        this.name = name;\n        this.filtering = options.filtering;\n\n        // Destroy previous texture if present\n        if (Texture.textures[this.name]) {\n            Texture.textures[this.name].destroy();\n        }\n\n        Texture.textures[this.name] = this;\n\n        this.sprites = options.sprites;\n        this.texcoords = {};\n    }\n\n    // Destroy a single texture instance\n    destroy() {\n        if (!this.valid) {\n            return;\n        }\n        this.gl.deleteTexture(this.texture);\n        this.texture = null;\n        delete this.data;\n        this.data = null;\n        delete Texture.textures[this.name];\n        this.valid = false;\n    }\n\n    bind(unit) {\n        if (!this.valid) {\n            return;\n        }\n        if (typeof unit === 'number') {\n            if (Texture.activeUnit !== unit) {\n                this.gl.activeTexture(this.gl.TEXTURE0 + unit);\n                Texture.activeUnit = unit;\n            }\n        }\n        if (Texture.activeTexture !== this.texture) {\n            this.gl.bindTexture(this.gl.TEXTURE_2D, this.texture);\n            Texture.activeTexture = this.texture;\n        }\n    }\n\n    // Loads a texture from a URL\n    load(url, options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        if (Texture.base_url) {\n            url = Utils.addBaseURL(url, Texture.base_url);\n        }\n\n        this.loading = new Promise((resolve, reject) => {\n            this.image = new Image();\n            this.image.onload = () => {\n                try {\n                    this.update(options);\n                    this.setTextureFiltering(options);\n                    this.calculateSprites();\n\n                    this.canvas = null; // mutually exclusive with other types\n                    this.data = null;\n                }\n                catch (e) {\n                    log.warn(`Texture: failed to load url: '${url}'`, e, options);\n                    Texture.trigger('warning', { message: `Failed to load texture from ${url}`, error: e, texture: options });\n                }\n\n                resolve(this);\n            };\n            this.image.onerror = e => {\n                // Warn and resolve on error\n                log.warn(`Texture: failed to load url: '${url}'`, e, options);\n                Texture.trigger('warning', { message: `Failed to load texture from ${url}`, error: e, texture: options });\n                resolve(this);\n            };\n            this.image.crossOrigin = 'anonymous';\n            this.image.src = url;\n        });\n        return this.loading;\n    }\n\n    // Sets texture to a raw image buffer\n    setData(width, height, data, options = {}) {\n        this.width = width;\n        this.height = height;\n        this.data = data;\n\n        this.image = null; // mutually exclusive with other types\n        this.canvas = null;\n\n        this.update(options);\n        this.setTextureFiltering(options);\n    }\n\n    // Sets the texture to track a canvas element\n    setCanvas(canvas, options) {\n        this.canvas = canvas;\n        this.update(options);\n        this.setTextureFiltering(options);\n\n        this.image = null; // mutually exclusive with other types\n        this.data = null;\n    }\n\n    // Uploads current image or buffer to the GPU (can be used to update animated textures on the fly)\n    update(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        this.bind();\n        this.gl.pixelStorei(this.gl.UNPACK_FLIP_Y_WEBGL, (options.UNPACK_FLIP_Y_WEBGL === false ? false : true));\n        this.gl.pixelStorei(this.gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, options.UNPACK_PREMULTIPLY_ALPHA_WEBGL || false);\n\n        // Image element\n        if (this.image && this.image.complete) {\n            this.width = this.image.width;\n            this.height = this.image.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.image);\n        }\n        // Canvas element\n        else if (this.canvas) {\n            this.width = this.canvas.width;\n            this.height = this.canvas.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.canvas);\n        }\n        // Raw image buffer\n        else if (this.width && this.height) { // NOTE: this.data can be null, to zero out texture\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.width, this.height, 0, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.data);\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Determines appropriate filtering mode\n    setTextureFiltering(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        options.filtering = options.filtering || this.filtering || 'linear';\n\n        var gl = this.gl;\n        this.bind();\n\n        // For power-of-2 textures, the following presets are available:\n        // mipmap: linear blend from nearest mip\n        // linear: linear blend from original image (no mips)\n        // nearest: nearest pixel from original image (no mips, 'blocky' look)\n        if (Utils.isPowerOf2(this.width) && Utils.isPowerOf2(this.height)) {\n            this.power_of_2 = true;\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, options.TEXTURE_WRAP_S || (options.repeat && gl.REPEAT) || gl.CLAMP_TO_EDGE);\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, options.TEXTURE_WRAP_T || (options.repeat && gl.REPEAT) || gl.CLAMP_TO_EDGE);\n\n            // gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, options.TEXTURE_WRAP_S || gl.REPEAT);\n            // gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, options.TEXTURE_WRAP_T || gl.REPEAT);\n\n            if (options.filtering === 'mipmap') {\n                log.trace('power-of-2 MIPMAP');\n                this.filtering = 'mipmap';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR_MIPMAP_LINEAR); // TODO: use trilinear filtering by defualt instead?\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n                gl.generateMipmap(gl.TEXTURE_2D);\n            }\n            else if (options.filtering === 'linear') {\n                log.trace('power-of-2 LINEAR');\n                this.filtering = 'linear';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n            }\n            else if (options.filtering === 'nearest') {\n                log.trace('power-of-2 NEAREST');\n                this.filtering = 'nearest';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n            }\n        }\n        else {\n            // WebGL has strict requirements on non-power-of-2 textures:\n            // No mipmaps and must clamp to edge\n            this.power_of_2 = false;\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n            gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n            if (options.filtering === 'nearest') {\n                log.trace('power-of-2 NEAREST');\n                this.filtering = 'nearest';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n            }\n            else { // default to linear for non-power-of-2 textures\n                log.trace('power-of-2 LINEAR');\n                this.filtering = 'linear';\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n            }\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Pre-calc sprite regions for a texture sprite in UV [0, 1] space\n    calculateSprites() {\n        if (this.sprites) {\n            for (let s in this.sprites) {\n                let sprite = this.sprites[s];\n\n                // Map [0, 0] to [1, 1] coords to the appropriate sprite sub-area of the texture\n                this.texcoords[s] = Builders.getTexcoordsForSprite(\n                    [sprite[0], sprite[1]],\n                    [sprite[2], sprite[3]],\n                    [this.width, this.height]\n                );\n            }\n        }\n    }\n\n}\n\n\n// Static/class methods and state\n\n// Destroy all texture instances for a given GL context\nTexture.destroy = function (gl) {\n    var textures = Object.keys(Texture.textures);\n    for (var t of textures) {\n        var texture = Texture.textures[t];\n        if (texture.gl === gl) {\n            log.trace(`destroying Texture ${texture.name}`);\n            texture.destroy();\n        }\n    }\n};\n\n// Get sprite sub-area to use for texture coordinates (default is [0, 1])\nTexture.getSpriteTexcoords = function (texname, sprite) {\n    let texture = Texture.textures[texname];\n    return texture && texture.texcoords[sprite];\n};\n\n// Create a set of textures keyed in an object\n// Optionally load each if it has a URL specified\nTexture.createFromObject = function (gl, textures) {\n    let loading = [];\n    if (textures) {\n        for (let texname in textures) {\n            let config = textures[texname];\n            let texture = new Texture(gl, texname, config);\n            if (config.url) {\n                loading.push(texture.load(config.url, config));\n            }\n        }\n    }\n    return Promise.all(loading);\n};\n\n// Get metadata for a texture by name\n// Returns via promise, in case texture is still loading\n// Can be called on main thread from worker, to sync texture info to worker\nTexture.getInfo = function (name) {\n    // Get info for all textures by default\n    if (!name) {\n        name = Object.keys(Texture.textures);\n    }\n\n    // Get multiple textures\n    if (Array.isArray(name)) {\n        return Promise.all(name.map(n => Texture.getInfo(n)));\n    }\n\n    // Get single texture\n    var tex = Texture.textures[name];\n    if (tex) {\n        // Wait for this texture to finish loading, or return immediately\n        var loading = tex.loading || Promise.resolve(tex);\n        return loading.then(() => {\n            // Return a subset of texture info\n            // (compatible w/structured cloning, suitable for passing to a worker)\n            return {\n                name: tex.name,\n                width: tex.width,\n                height: tex.height,\n                sprites: tex.sprites,\n                texcoords: tex.texcoords,\n                filtering: tex.filtering,\n                power_of_2: tex.power_of_2,\n                valid: tex.valid\n            };\n        });\n    }\n    else {\n        // No texture found\n        return Promise.resolve(null);\n    }\n};\n\n// Sync texture info to worker\n// Called from worker, gets info on one or more textures info from main thread via remote call, then stores it\n// locally in worker. 'textures' can be an array of texture names to sync, or if null, all textures are synced.\nTexture.syncTexturesToWorker = function (names) {\n    return WorkerBroker.postMessage('Texture', 'getInfo', names).\n        then(textures => {\n            for (var tex of textures) {\n                Texture.textures[tex.name] = tex;\n            }\n            return Texture.textures;\n        });\n};\n\n// Global set of textures, by name\nTexture.textures = {};\nTexture.boundTexture = -1;\nTexture.activeUnit = -1;\n\nTexture.base_url = null; // optional base URL to add to textures\n\nsubscribeMixin(Texture);\n","// Creates a Vertex Array Object if the extension is available, or falls back on standard attribute calls\n\nimport log from 'loglevel';\n\nvar VertexArrayObject;\nexport default VertexArrayObject = {};\n\nVertexArrayObject.disabled = false; // set to true to disable VAOs even if extension is available\nVertexArrayObject.bound_vao = null; // currently bound VAO\n\nVertexArrayObject.init = function (gl) {\n    if (VertexArrayObject.ext == null) {\n        if (VertexArrayObject.disabled !== true) {\n            VertexArrayObject.ext = gl.getExtension(\"OES_vertex_array_object\");\n        }\n\n        if (VertexArrayObject.ext != null) {\n            log.info('Vertex Array Object extension available');\n        }\n        else if (VertexArrayObject.disabled !== true) {\n            log.warn('Vertex Array Object extension NOT available');\n        }\n        else {\n            log.warn('Vertex Array Object extension force disabled');\n        }\n    }\n};\n\nVertexArrayObject.create = function (setup, teardown) {\n    let vao = {};\n    vao.setup = setup;\n    vao.teardown = teardown;\n\n    let ext = VertexArrayObject.ext;\n    if (ext != null) {\n        vao._vao = ext.createVertexArrayOES();\n        ext.bindVertexArrayOES(vao._vao);\n    }\n\n    vao.setup(true);\n\n    return vao;\n};\n\nVertexArrayObject.bind = function (vao) {\n    let ext = VertexArrayObject.ext;\n    if (vao != null) {\n        if (ext != null && vao._vao != null) {\n            ext.bindVertexArrayOES(vao._vao);\n            VertexArrayObject.bound_vao = vao;\n        }\n        else {\n            vao.setup(false);\n        }\n    }\n    else {\n        if (ext != null) {\n            ext.bindVertexArrayOES(null);\n        }\n        else if (VertexArrayObject.bound_vao != null && typeof VertexArrayObject.bound_vao.teardown === 'function') {\n            VertexArrayObject.bound_vao.teardown();\n        }\n        VertexArrayObject.bound_vao = null;\n    }\n};\n","/* global VBOMesh */\n// Manage rendering for primitives\nimport GLSL from './glsl';\nimport ShaderProgram from './shader_program';\nimport Texture from './texture';\nimport VertexArrayObject from './vao';\nimport log from 'loglevel';\n\n// A single mesh/VBO, described by a vertex layout, that can be drawn with one or more programs\nexport default class VBOMesh  {\n\n    constructor(gl, vertex_data, vertex_layout, options) {\n        options = options || {};\n\n        this.gl = gl;\n        this.vertex_data = vertex_data; // typed array\n        this.vertex_layout = vertex_layout;\n        this.buffer = this.gl.createBuffer();\n        this.draw_mode = options.draw_mode || this.gl.TRIANGLES;\n        this.data_usage = options.data_usage || this.gl.STATIC_DRAW;\n        this.vertices_per_geometry = 3; // TODO: support lines, strip, fan, etc.\n        this.uniforms = options.uniforms;\n        this.retain = options.retain || false; // whether to retain mesh data in CPU after uploading to GPU\n\n        this.vertex_count = this.vertex_data.byteLength / this.vertex_layout.stride;\n        this.geometry_count = this.vertex_count / this.vertices_per_geometry;\n        this.vaos = new Map(); // map of VertexArrayObjects, keyed by program\n\n        this.gl.bindBuffer(this.gl.ARRAY_BUFFER, this.buffer);\n        this.gl.bufferData(this.gl.ARRAY_BUFFER, this.vertex_data, this.data_usage);\n\n        if (!this.retain) {\n            delete this.vertex_data;\n        }\n        this.valid = true;\n    }\n\n    // Render, by default with currently bound program, or otherwise with optionally provided one\n    render(options = {}) {\n        if (!this.valid) {\n            return false;\n        }\n\n        if (typeof this._render_setup === 'function') {\n            this._render_setup();\n        }\n\n        var program = options.program || ShaderProgram.current;\n        program.use();\n\n        if (this.uniforms) {\n            program.saveUniforms(this.uniforms);\n            program.setUniforms(this.uniforms, false); // don't reset texture unit\n        }\n\n        this.bind(program);\n\n        // TODO: support element array mode\n        this.gl.drawArrays(this.draw_mode, 0, this.vertex_count);\n        VertexArrayObject.bind(null);\n\n        if (this.uniforms) {\n            program.restoreUniforms(this.uniforms);\n        }\n\n        return true;\n    }\n\n    // Bind buffers and vertex attributes to prepare for rendering\n    bind(program) {\n        // Bind VAO for this progam, or create one\n        let vao = this.vaos.get(program);\n        if (vao) {\n            VertexArrayObject.bind(vao);\n        }\n        else {\n            this.vaos.set(program, VertexArrayObject.create((force) => {\n                this.gl.bindBuffer(this.gl.ARRAY_BUFFER, this.buffer);\n                this.vertex_layout.enable(this.gl, program, force);\n            }));\n        }\n    }\n\n    destroy() {\n        if (!this.valid) {\n            return false;\n        }\n        this.valid = false;\n\n        log.trace('VBOMesh.destroy: delete buffer' + (this.vertex_data ? ` of size ${this.vertex_data.byteLength}` : ''));\n\n        this.gl.deleteBuffer(this.buffer);\n        this.buffer = null;\n        delete this.vertex_data;\n\n        // Free texture uniforms that are owned by this mesh\n        for (let {type, value} of GLSL.parseUniforms(this.uniforms)) {\n            if (type === 'sampler2D' && Texture.textures[value]) {\n                Texture.textures[value].destroy();\n            }\n        }\n\n        return true;\n    }\n\n}\n","/* global VertexData */\n\nimport gl from './constants'; // web workers don't have access to GL context, so import all GL constants\nimport {log} from '../utils/utils';\n\n// Maps GL types to JS array types\nlet array_types = {\n    [gl.FLOAT]: Float32Array,\n    [gl.BYTE]: Int8Array,\n    [gl.UNSIGNED_BYTE]: Uint8Array,\n    [gl.INT]: Int32Array,\n    [gl.UNSIGNED_INT]: Uint32Array,\n    [gl.SHORT]: Int16Array,\n    [gl.UNSIGNED_SHORT]: Uint16Array\n};\n\n// An intermediary object that holds vertex data in typed arrays, according to a given vertex layout\n// Used to construct a mesh/VBO for rendering\nexport default class VertexData {\n\n    constructor (vertex_layout, { prealloc } = {}) {\n        this.vertex_layout = vertex_layout;\n\n        if (VertexData.array_pool.length > 0) {\n            this.buffer = VertexData.array_pool.pop();\n            this.buffer_length = this.buffer.byteLength;\n            this.buffer_size = Math.floor(this.buffer_length / this.vertex_layout.stride);\n            log('trace', `VertexData: reused buffer of bytes ${this.buffer_length}, ${this.buffer_size} vertices`);\n        }\n        else {\n            this.buffer_size = prealloc || 500; // # of vertices to allocate\n            this.buffer_length = this.vertex_layout.stride * this.buffer_size;\n            this.buffer = new Uint8Array(this.buffer_length);\n        }\n        this.buffer_offset = 0;             // byte offset into currently allocated buffer\n\n        this.components = [];\n        for (var component of this.vertex_layout.components) {\n            this.components.push([...component]);\n        }\n        this.vertex_count = 0;\n        this.realloc_count = 0;\n        this.setBufferViews();\n    }\n\n    // (Re-)allocate typed views into the main buffer - only create the types we need for this layout\n    setBufferViews () {\n        this.buffer_views = {};\n        this.buffer_views[gl.UNSIGNED_BYTE] = this.buffer;\n        for (var attrib of this.vertex_layout.attribs) {\n            // Need view for this type?\n            if (this.buffer_views[attrib.type] == null) {\n                var array_type = array_types[attrib.type];\n                this.buffer_views[attrib.type] = new array_type(this.buffer.buffer);\n            }\n        }\n\n        // Update component buffer pointers\n        for (var component of this.components) {\n            component[1] = this.buffer_views[component[0]];\n        }\n    }\n\n    // Check allocated buffer size, expand/realloc buffer if needed\n    checkBufferSize () {\n        if ((this.buffer_offset + this.vertex_layout.stride) > this.buffer_length) {\n            this.buffer_size = Math.floor(this.buffer_size * 1.5);\n            this.buffer_size -= this.buffer_size % 4;\n            this.buffer_length = this.vertex_layout.stride * this.buffer_size;\n            var new_view = new Uint8Array(this.buffer_length);\n            new_view.set(this.buffer); // copy existing data to new buffer\n            VertexData.array_pool.push(this.buffer); // save previous buffer for use by next tile\n            this.buffer = new_view;\n            this.setBufferViews();\n            this.realloc_count++;\n            // log.info(`VertexData: expanded vertex block to ${this.buffer_size} vertices`);\n        }\n    }\n\n    // Add a vertex, copied from a plain JS array of elements matching the order of the vertex layout.\n    // Note: uses pre-calculated info about each attribute, including pointer to appropriate typed array\n    // view and offset into it. This was the fastest method profiled so far for filling a mixed-type\n    // vertex layout (though still slower than the previous method that only supported Float32Array attributes).\n    addVertex (vertex) {\n        this.checkBufferSize();\n        var i=0;\n\n        var clen = this.components.length;\n        for (var c=0; c < clen; c++) {\n            var component = this.components[c];\n            component[1][(this.buffer_offset >> component[2]) + component[3]] = vertex[i++];\n        }\n\n        this.buffer_offset += this.vertex_layout.stride;\n        this.vertex_count++;\n    }\n\n    // Finalize vertex buffer for use in constructing a mesh\n    end () {\n        // Clip the buffer to size used for this VBO\n        this.buffer = this.buffer.subarray(0, this.buffer_offset);\n        log('trace', `VertexData: ${this.buffer_size} vertices total, realloc count ${this.realloc_count}`);\n        return this;\n    }\n\n}\n\nVertexData.array_pool = []; // pool of currently available (previously used) buffers (uint8)\n","/* global VertexLayout */\n\nimport gl from './constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexData from './vertex_data';\n\n// Describes a vertex layout that can be used with many different GL programs.\nexport default class VertexLayout {\n    // Attribs are an array, in layout order, of: name, size, type, normalized\n    // ex: { name: 'position', size: 3, type: gl.FLOAT, normalized: false }\n    constructor (attribs) {\n        this.attribs = attribs; // dictionary of attributes, specified as standard GL attrib options\n        this.components = [];   // list of type and offset info about each attribute component\n        this.index = {};        // linear buffer index of each attribute component, e.g. this.index.position.x\n\n        // Calc vertex stride\n        this.stride = 0;\n\n        var count = 0;\n        for (var attrib of this.attribs) {\n            attrib.offset = this.stride;\n            attrib.byte_size = attrib.size;\n            var shift = 0;\n\n            switch (attrib.type) {\n                case gl.FLOAT:\n                case gl.INT:\n                case gl.UNSIGNED_INT:\n                    attrib.byte_size *= 4;\n                    shift = 2;\n                    break;\n                case gl.SHORT:\n                case gl.UNSIGNED_SHORT:\n                    attrib.byte_size *= 2;\n                    shift = 1;\n                    break;\n            }\n\n            // Force 4-byte alignment on attributes\n            this.stride += attrib.byte_size;\n            if (this.stride & 3) { // pad to multiple of 4 bytes\n                this.stride += 4 - (this.stride & 3);\n            }\n\n            // Add info to list of attribute components\n            // Used to build the vertex data, provides pointers and offsets into each typed array view\n            // Each component is an array of:\n            // [GL attrib type, pointer to typed array view, bits to shift right to determine buffer offset, additional buffer offset for the component]\n            var offset_typed = attrib.offset >> shift;\n            if (attrib.size > 1) {\n                for (var a=0; a < attrib.size; a++) {\n                    this.components.push([attrib.type, null, shift, offset_typed++]);\n                }\n            }\n            else {\n                this.components.push([attrib.type, null, shift, offset_typed]);\n            }\n\n            // Provide an index into the vertex data buffer for each attribute component\n            this.index[attrib.name] = count;\n            count += attrib.size;\n        }\n    }\n\n    // Setup a vertex layout for a specific GL program\n    // Assumes that the desired vertex buffer (VBO) is already bound\n    // If a given program doesn't include all attributes, it can still use the vertex layout\n    // to read those attribs that it does recognize, using the attrib offsets to skip others.\n    enable (gl, program, force)\n    {\n        var attrib, location;\n\n        // Enable all attributes for this layout\n        for (var a=0; a < this.attribs.length; a++) {\n            attrib = this.attribs[a];\n            location = program.attribute(attrib.name).location;\n\n            if (location !== -1) {\n                if (!VertexLayout.enabled_attribs[location] || force) {\n                    gl.enableVertexAttribArray(location);\n                }\n                gl.vertexAttribPointer(location, attrib.size, attrib.type, attrib.normalized, this.stride, attrib.offset);\n                VertexLayout.enabled_attribs[location] = program;\n            }\n        }\n\n        // Disable any previously bound attributes that aren't for this layout\n        for (location in VertexLayout.enabled_attribs) {\n            this.disableUnusedAttribute(gl, location, program);\n        }\n    }\n\n    // Disable an attribute if it was not enabled for the specified program\n    // NOTE: this was moved out of the inner loop in enable() to assist w/VM optimization\n    disableUnusedAttribute (gl, location, program) {\n        if (VertexLayout.enabled_attribs[location] !== program) {\n            gl.disableVertexAttribArray(location);\n            delete VertexLayout.enabled_attribs[location];\n        }\n    }\n\n    createVertexData () {\n        return new VertexData(this);\n    }\n\n}\n\n// Track currently enabled attribs, by the program they are bound to\n// Static class property to reflect global GL state\nVertexLayout.enabled_attribs = {};\n","import Utils from './utils/utils';\nimport Scene from './scene';\nimport Geo from './geo';\n\n// Exports must appear outside a function, but will only be defined in main thread (below)\nexport var LeafletLayer;\nexport function leafletLayer(options) {\n    return new LeafletLayer(options);\n}\n\n// Leaflet layer functionality is only defined in main thread\nif (Utils.isMainThread) {\n\n    // Determine if we are extending the leaflet 0.7.x TileLayer class, or the newer\n    // leaflet 1.x GridLayer class.\n    let layerBaseClass = L.GridLayer ? L.GridLayer : L.TileLayer;\n    let leafletVersion = layerBaseClass === L.GridLayer ? '1.x' : '0.7.x';\n    let layerClassConfig = {};\n\n    // If extending leaflet 0.7.x TileLayer, make add/remove tile no ops\n    if (layerBaseClass === L.TileLayer) {\n        layerClassConfig._addTile = function(){};\n        layerClassConfig._removeTile = function(){};\n    }\n\n    // Define custom layer methods\n    Object.assign(layerClassConfig, {\n\n        initialize: function (options) {\n            // Defaults\n            options.showDebug = (!options.showDebug ? false : true);\n\n            L.setOptions(this, options);\n            this.createScene();\n            this.hooks = {};\n            this._updating_tangram = false;\n\n            // Force leaflet zoom animations off\n            this._zoomAnimated = false;\n        },\n\n        createScene: function () {\n            this.scene = Scene.create(\n                this.options.scene,\n                {\n                    numWorkers: this.options.numWorkers,\n                    preUpdate: this.options.preUpdate,\n                    postUpdate: this.options.postUpdate,\n                    continuousZoom: (LeafletLayer.leafletVersion === '1.x'),\n                    highDensityDisplay: this.options.highDensityDisplay,\n                    logLevel: this.options.logLevel,\n                    // advanced option, app will have to manually called scene.update() per frame\n                    disableRenderLoop: this.options.disableRenderLoop,\n                    // advanced option, will require library to be served as same host as page\n                    allowCrossDomainWorkers: this.options.allowCrossDomainWorkers\n                });\n        },\n\n        // Finish initializing scene and setup events when layer is added to map\n        onAdd: function (map) {\n            if (!this.scene) {\n                this.createScene();\n            }\n\n            layerBaseClass.prototype.onAdd.apply(this, arguments);\n\n            this.hooks.resize = () => {\n                this._updating_tangram = true;\n                var size = map.getSize();\n                this.scene.resizeMap(size.x, size.y);\n                this._updating_tangram = false;\n            };\n            map.on('resize', this.hooks.resize);\n\n            this.hooks.move = () => {\n                if (this._updating_tangram) {\n                    return;\n                }\n\n                this._updating_tangram = true;\n                var view = map.getCenter();\n                view.zoom = Math.min(map.getZoom(), map.getMaxZoom() || Geo.max_zoom);\n\n                this.scene.setView(view);\n                this.scene.immediateRedraw();\n                this._updating_tangram = false;\n            };\n            map.on('move', this.hooks.move);\n\n            this.hooks.zoomstart = () => {\n                if (this._updating_tangram) {\n                    return;\n                }\n\n                this._updating_tangram = true;\n                this.scene.startZoom();\n                this._updating_tangram = false;\n            };\n            map.on('zoomstart', this.hooks.zoomstart);\n\n            this.hooks.dragstart = () => {\n                this.scene.panning = true;\n            };\n            map.on('dragstart', this.hooks.dragstart);\n\n            this.hooks.dragend = () => {\n                this.scene.panning = false;\n            };\n            map.on('dragend', this.hooks.dragend);\n\n            // Force leaflet zoom animations off\n            map._zoomAnimated = false;\n\n            // Modify default leaflet scroll wheel behavior\n            this.modifyScrollWheelBehavior(map);\n\n            // Canvas element will be inserted after map container (leaflet transforms shouldn't be applied to the GL canvas)\n            // TODO: find a better way to deal with this? right now GL map only renders correctly as the bottom layer\n            this.scene.container = map.getContainer();\n\n            // Initial view\n            var view = map.getCenter();\n            view.zoom = Math.min(map.getZoom(), map.getMaxZoom() || Geo.max_zoom);\n            this.scene.setView(view);\n\n            // Subscribe to tangram events\n            this.scene.subscribe({\n                move: this.onTangramViewUpdate.bind(this)\n            });\n\n            // Use leaflet's existing event system as the callback mechanism\n            this.scene.load().then(() => {\n                this.fire('init');\n            }).catch(error => {\n                this.fire('error', error);\n            });\n        },\n\n        onRemove: function (map) {\n            layerBaseClass.prototype.onRemove.apply(this, arguments);\n\n            map.off('resize', this.hooks.resize);\n            map.off('move', this.hooks.move);\n            map.off('zoomstart', this.hooks.zoomstart);\n            map.off('dragstart', this.hooks.dragstart);\n            map.off('dragend', this.hooks.dragend);\n            this.hooks = {};\n\n            if (this.scene) {\n                this.scene.destroy();\n                this.scene = null;\n            }\n        },\n\n        createTile: function (coords) {\n            var key = coords.x + '/' + coords.y + '/' + coords.z;\n            var div = document.createElement('div');\n            div.setAttribute('data-tile-key', key);\n            div.style.width = '256px';\n            div.style.height = '256px';\n\n            if (this.options.showDebug) {\n                var debug_overlay = document.createElement('div');\n                debug_overlay.textContent = key;\n                debug_overlay.style.position = 'absolute';\n                debug_overlay.style.left = 0;\n                debug_overlay.style.top = 0;\n                debug_overlay.style.color = 'white';\n                debug_overlay.style.fontSize = '16px';\n                debug_overlay.style.textOutline = '1px #000000';\n                debug_overlay.style.padding = '8px';\n\n                div.appendChild(debug_overlay);\n                div.style.borderStyle = 'solid';\n                div.style.borderColor = 'white';\n                div.style.borderWidth = '1px';\n            }\n\n            return div;\n        },\n\n        // Modify leaflet's default scroll wheel behavior to have a much more sensitve/continuous zoom\n        // Note: this should be deprecated once leaflet continuous zoom is more widely used and the\n        // default behavior is presumably improved\n        modifyScrollWheelBehavior: function (map) {\n            if (this.scene.continuous_zoom && map.scrollWheelZoom && this.options.modifyScrollWheel !== false) {\n                map.scrollWheelZoom._performZoom = function () {\n                    var map = this._map,\n                        delta = this._delta,\n                        zoom = map.getZoom();\n\n                    map.stop(); // stop panning and fly animations if any\n\n                    // NOTE: this is the only real modification to default leaflet behavior\n                    delta /= 40;\n\n                    delta = Math.max(Math.min(delta, 4), -4);\n                    delta = map._limitZoom(zoom + delta) - zoom;\n\n                    this._delta = 0;\n                    this._startTime = null;\n\n                    if (!delta) { return; }\n\n                    if (map.options.scrollWheelZoom === 'center') {\n                        map.setZoom(zoom + delta);\n                    } else {\n                        map.setZoomAround(this._lastMousePos, zoom + delta);\n                    }\n                    return false;\n                };\n            }\n        },\n\n        onTangramViewUpdate: function () {\n            if (!this._map || this._updating_tangram) {\n                return;\n            }\n            this._updating_tangram = true;\n            this._map.setView([this.scene.center.lat, this.scene.center.lng], this.scene.zoom, { animate: false });\n            this._updating_tangram = false;\n        },\n\n        render: function () {\n            if (!this.scene) {\n                return;\n            }\n            this.scene.update();\n        }\n\n    });\n\n    // Create the layer class\n    LeafletLayer = layerBaseClass.extend(layerClassConfig);\n\n    // Polyfill some 1.0 methods\n    if (typeof LeafletLayer.remove !== 'function') {\n        LeafletLayer.prototype.remove = function() {\n            if (this._map) {\n                this._map.removeLayer(this);\n            }\n            this.fire('remove');\n        };\n    }\n\n    LeafletLayer.layerBaseClass = layerBaseClass;\n    LeafletLayer.leafletVersion = leafletVersion;\n\n}\n","/*global Light */\nimport ShaderProgram from './gl/shader_program';\nimport shaderSources from './gl/shader_sources'; // built-in shaders\nimport GLSL from './gl/glsl';\nimport Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\n\n// Abstract light\nexport default class Light {\n\n    constructor (scene, config) {\n        this.name = config.name;\n        this.scene = scene;\n\n        if (config.ambient == null || typeof config.ambient === 'number') {\n            this.ambient = GLSL.expandVec4(config.ambient || 0);\n        }\n        else {\n            this.ambient = StyleParser.parseColor(config.ambient);\n        }\n\n        if (config.diffuse == null || typeof config.diffuse === 'number') {\n            this.diffuse = GLSL.expandVec4(config.diffuse != null ? config.diffuse : 1);\n        }\n        else {\n            this.diffuse = StyleParser.parseColor(config.diffuse);\n        }\n\n        if (config.specular == null || typeof config.specular === 'number') {\n            this.specular = GLSL.expandVec4(config.specular || 0);\n        }\n        else {\n            this.specular = StyleParser.parseColor(config.specular);\n        }\n    }\n\n    // Create a light by type name, factory-style\n    // 'config' must include 'name' and 'type', along with any other type-specific properties\n    static create (scene, config) {\n        if (Light.types[config.type]) {\n            return new Light.types[config.type](scene, config);\n        }\n    }\n\n    // Set light for a style: fragment lighting, vertex lighting, or none\n    static setMode (mode, style) {\n        if (mode === true) {\n            mode = 'fragment';\n        }\n        mode = Light.enabled && ((mode != null) ? mode : 'fragment'); // default to fragment lighting\n        style.defines['TANGRAM_LIGHTING_FRAGMENT'] = (mode === 'fragment');\n        style.defines['TANGRAM_LIGHTING_VERTEX'] = (mode === 'vertex');\n    }\n\n    // Inject all provided light definitions, and calculate cumulative light function\n    static inject (lights) {\n        // Clear previous injections\n        ShaderProgram.removeBlock(Light.block);\n\n        // If lighting is globally disabled, nothing is injected (mostly for debugging or live editing)\n        if (!Light.enabled) {\n            return;\n        }\n\n        // Construct code to calculate each light instance\n        let calculateLights = \"\";\n        if (lights && Object.keys(lights).length > 0) {\n            // Collect uniques types of lights\n            let types = {};\n            for (let light_name in lights) {\n                types[lights[light_name].type] = true;\n            }\n\n            // Inject each type of light\n            for (let type in types) {\n                Light.types[type].inject();\n            }\n\n            // Inject per-instance blocks and construct the list of functions to calculate each light\n            for (let light_name in lights) {\n                // Define instance\n                lights[light_name].inject();\n\n                // Add the calculation function to the list\n                calculateLights += `calculateLight(${light_name}, _eyeToPoint, _normal);\\n`;\n            }\n        }\n        else {\n            // If no light is defined, use 100% omnidirectional diffuse light\n            calculateLights = `\n                #ifdef TANGRAM_MATERIAL_DIFFUSE\n                    light_accumulator_diffuse = vec4(1.);\n                #endif\n            `;\n        }\n\n        // Glue together the final lighting function that sums all the lights\n        let calculateFunction = `\n            vec4 calculateLighting(in vec3 _eyeToPoint, in vec3 _normal, in vec4 _color) {\n\n                // Do initial material calculations over normal, emission, ambient, diffuse and specular values\n                calculateMaterial(_eyeToPoint,_normal);\n\n                // Un roll the loop of individual ligths to calculate\n                ${calculateLights}\n\n                //  Final light intensity calculation\n                vec4 color = vec4(0.0);\n\n                #ifdef TANGRAM_MATERIAL_EMISSION\n                    color = material.emission;\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_AMBIENT\n                    color += light_accumulator_ambient * _color * material.ambient;\n                #else\n                    #ifdef TANGRAM_MATERIAL_DIFFUSE\n                        color += light_accumulator_ambient * _color * material.diffuse;\n                    #endif\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_DIFFUSE\n                    color += light_accumulator_diffuse * _color * material.diffuse;\n                #endif\n\n                #ifdef TANGRAM_MATERIAL_SPECULAR\n                    color += light_accumulator_specular * material.specular;\n                #endif\n\n                // Clamp final color\n                color = clamp(color, 0.0, 1.0);\n\n                return color;\n            }`;\n\n        ShaderProgram.addBlock(Light.block, calculateFunction);\n    }\n\n    // Common instance definition\n    inject () {\n        let instance =  `\n            uniform ${this.struct_name} u_${this.name};\n            ${this.struct_name} ${this.name} = u_${this.name};\\n`;\n\n        ShaderProgram.addBlock(Light.block, instance);\n    }\n\n    // Update method called once per frame\n    update () {\n    }\n\n    // Called once per frame per program (e.g. for main render pass, then for each additional\n    // pass for feature selection, etc.)\n    setupProgram (_program) {\n        //  Three common light properties\n        _program.uniform('4fv', `u_${this.name}.ambient`, this.ambient);\n        _program.uniform('4fv', `u_${this.name}.diffuse`, this.diffuse);\n        _program.uniform('4fv', `u_${this.name}.specular`, this.specular);\n    }\n\n}\n\nLight.types = {}; // references to subclasses by short name\nLight.block = 'lighting'; // shader block name\nLight.enabled = true; // lighting can be globally enabled/disabled\n\n\n// Light subclasses\nclass AmbientLight extends Light {\n\n    constructor(scene, config) {\n        super(scene, config);\n        this.type = 'ambient';\n        this.struct_name = 'AmbientLight';\n    }\n\n    // Inject struct and calculate function\n    static inject() {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/ambientLight']);\n    }\n\n    setupProgram (_program) {\n        _program.uniform('4fv', `u_${this.name}.ambient`, this.ambient);\n    }\n\n}\nLight.types['ambient'] = AmbientLight;\n\nclass DirectionalLight extends Light {\n\n    constructor(scene, config) {\n        super(scene, config);\n        this.type = 'directional';\n        this.struct_name = 'DirectionalLight';\n\n        this.direction = (config.direction || [0.2, 0.7, -0.5]).map(parseFloat); // [x, y, z]\n    }\n\n    // Inject struct and calculate function\n    static inject() {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/directionalLight']);\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n        _program.uniform('3fv', `u_${this.name}.direction`, this.direction);\n    }\n\n}\nLight.types['directional'] = DirectionalLight;\n\n\nclass PointLight extends Light {\n\n    constructor (scene, config) {\n        super(scene, config);\n        this.type = 'point';\n        this.struct_name = 'PointLight';\n\n        this.position = config.position || [0, 0, 0];\n        this.position_eye = []; // position in eyespace\n        this.origin = config.origin || 'world';\n        this.attenuation = !isNaN(parseFloat(config.attenuation)) ? parseFloat(config.attenuation) : 0;\n\n        if (config.radius) {\n            if (Array.isArray(config.radius) && config.radius.length === 2) {\n                this.radius = config.radius;\n            }\n            else {\n                this.radius = [null, config.radius];\n            }\n        }\n        else {\n            this.radius = null;\n        }\n    }\n\n    // Inject struct and calculate function\n    static inject () {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/pointLight']);\n    }\n\n    // Inject isntance-specific settings\n    inject() {\n        super.inject();\n\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT'] = (this.attenuation !== 0);\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS'] = (this.radius != null && this.radius[0] != null);\n        ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS'] = (this.radius != null);\n    }\n\n    update () {\n        this.updateEyePosition();\n    }\n\n    updateEyePosition () {\n        if (this.origin === 'world') {\n            // For world origin, format is: [longitude, latitude, meters (default) or pixels w/px units]\n\n            // Move light's world position into camera space\n            let [x, y] = Geo.latLngToMeters(this.position);\n            this.position_eye[0] = x - this.scene.camera.position_meters[0];\n            this.position_eye[1] = y - this.scene.camera.position_meters[1];\n\n            this.position_eye[2] = StyleParser.convertUnits(this.position[2], { zoom: this.scene.zoom });\n            this.position_eye[2] = this.position_eye[2] - this.scene.camera.position_meters[2];\n        }\n        if (this.origin === 'ground' || this.origin === 'camera') {\n            // For camera or ground origin, format is: [x, y, z] in meters (default) or pixels w/px units\n\n            // Light is in camera space by default\n            this.position_eye = StyleParser.convertUnits(this.position, { zoom: this.scene.zoom });\n\n            if (this.origin === 'ground') {\n                // Leave light's xy in camera space, but z needs to be moved relative to ground plane\n                this.position_eye[2] = this.position_eye[2] - this.scene.camera.position_meters[2];\n            }\n        }\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n\n        _program.uniform('4f', `u_${this.name}.position`,\n            this.position_eye[0], this.position_eye[1], this.position_eye[2], 1);\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT']) {\n            _program.uniform('1f', `u_${this.name}.attenuationExponent`, this.attenuation);\n        }\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS']) {\n            _program.uniform('1f', `u_${this.name}.innerRadius`,\n                StyleParser.convertUnits(this.radius[0], { zoom: this.scene.zoom }));\n        }\n\n        if(ShaderProgram.defines['TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS']) {\n            _program.uniform('1f', `u_${this.name}.outerRadius`,\n                StyleParser.convertUnits(this.radius[1], { zoom: this.scene.zoom }));\n        }\n    }\n}\nLight.types['point'] = PointLight;\n\n\nclass SpotLight extends PointLight {\n\n    constructor (scene, config) {\n        super(scene, config);\n        this.type = 'spotlight';\n        this.struct_name = 'SpotLight';\n\n        this.direction = (config.direction || [0, 0, -1]).map(parseFloat); // [x, y, z]\n        this.exponent = config.exponent ? parseFloat(config.exponent) : 0.2;\n        this.angle = config.angle ? parseFloat(config.angle) : 20;\n    }\n\n    // Inject struct and calculate function\n    static inject () {\n        ShaderProgram.addBlock(Light.block, shaderSources['gl/shaders/spotLight']);\n    }\n\n    setupProgram (_program) {\n        super.setupProgram(_program);\n\n        _program.uniform('3fv', `u_${this.name}.direction`, this.direction);\n        _program.uniform('1f', `u_${this.name}.spotCosCutoff`, Math.cos(this.angle * 3.14159 / 180));\n        _program.uniform('1f', `u_${this.name}.spotExponent`, this.exponent);\n    }\n\n}\nLight.types['spotlight'] = SpotLight;\n","/*global Material */\nimport shaderSources from './gl/shader_sources'; // built-in shaders\nimport GLSL from './gl/glsl';\nimport {StyleParser} from './styles/style_parser';\n\nexport default class Material {\n    constructor (config) {\n\n        config = config || {};\n\n        // These properties all have the same defaults, so they can be set in bulk\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            if (config[prop] != null) {\n                if (config[prop].texture) {\n                    this[prop] = {\n                        texture: config[prop].texture,\n                        mapping: config[prop].mapping || 'spheremap',\n                        scale: GLSL.expandVec3(config[prop].scale != null ? config[prop].scale : 1),\n                        amount: GLSL.expandVec4(config[prop].amount != null ? config[prop].amount : 1)\n                    };\n                }\n                else if (typeof config[prop] === 'number') {\n                    this[prop] = { amount: GLSL.expandVec4(config[prop]) };\n                }\n                else if (typeof config[prop] === 'string') {\n                    this[prop] = { amount: StyleParser.parseColor(config[prop]) };\n                }\n                else {\n                    this[prop] = config[prop];\n                }\n            }\n        }\n\n        // Extra specular props\n        if (this.specular) {\n            this.specular.shininess = config.shininess ? parseFloat(config.shininess) : 0.2;\n        }\n\n        // Normal mapping\n        if (config.normal != null) {\n            this.normal = {\n                texture: config.normal.texture,\n                mapping: config.normal.mapping || 'triplanar',\n                scale: GLSL.expandVec3(config.normal.scale != null ? config.normal.scale : 1),\n                amount: config.normal.amount != null ? config.normal.amount : 1\n            };\n        }\n    }\n\n    // Determine if a material config block has sufficient properties to create a material\n    static isValid (config) {\n        if (config == null) {\n            return false;\n        }\n\n        if (config.emission == null &&\n            config.ambient == null &&\n            config.diffuse == null &&\n            config.specular == null) {\n            return false;\n        }\n\n        return true;\n    }\n\n    inject (style) {\n        // For each property, sets defines to configure texture mapping, with a pattern like:\n        //   TANGRAM_MATERIAL_DIFFUSE, TANGRAM_MATERIAL_DIFFUSE_TEXTURE, TANGRAM_MATERIAL_DIFFUSE_TEXTURE_SPHEREMAP\n        // Also sets flags to keep track of each unique mapping type being used, e.g.:\n        //   TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\n        // Enables texture coordinates if needed and not already on\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            let def = `TANGRAM_MATERIAL_${prop.toUpperCase()}`;\n            let texdef = def + '_TEXTURE';\n            style.defines[def] = (this[prop] != null);\n            if (this[prop] && this[prop].texture) {\n                style.defines[texdef] = true;\n                style.defines[texdef + '_' + this[prop].mapping.toUpperCase()] = true;\n                style.defines[`TANGRAM_MATERIAL_TEXTURE_${this[prop].mapping.toUpperCase()}`] = true;\n                style.texcoords = style.texcoords || (this[prop].mapping === 'uv');\n            }\n        }\n\n        // Normal mapping\n        // As anove, sets flags to keep track of each unique mapping type being used, e.g.:\n        //   TANGRAM_MATERIAL_TEXTURE_SPHEREMAP\n        if (this.normal && this.normal.texture) {\n            style.defines['TANGRAM_MATERIAL_NORMAL_TEXTURE'] = true;\n            style.defines['TANGRAM_MATERIAL_NORMAL_TEXTURE_' + this.normal.mapping.toUpperCase()] = true;\n            style.defines[`TANGRAM_MATERIAL_TEXTURE_${this.normal.mapping.toUpperCase()}`] = true;\n            style.texcoords = style.texcoords || (this.normal.mapping === 'uv');\n        }\n\n        style.replaceShaderBlock(Material.block, shaderSources['gl/shaders/material'], 'Material');\n    }\n\n    setupProgram (_program) {\n        // For each property, sets uniforms in the pattern:\n        // u_material.diffuse, u_material.diffuseScale u_material_diffuse_texture\n        for (let prop of ['emission', 'ambient', 'diffuse', 'specular']) {\n            if (this[prop]) {\n                if (this[prop].texture) {\n                    _program.setTextureUniform(`u_material_${prop}_texture`, this[prop].texture);\n                    _program.uniform('3fv', `u_material.${prop}Scale`, this[prop].scale);\n                    _program.uniform('4fv', `u_material.${prop}`, this[prop].amount);\n                } else if (this[prop].amount) {\n                    _program.uniform('4fv', `u_material.${prop}`, this[prop].amount);\n                }\n            }\n        }\n\n        // Extra specular props\n        if (this.specular) {\n            _program.uniform('1f', 'u_material.shininess', this.specular.shininess);\n        }\n\n        // Normal mapping\n        if (this.normal && this.normal.texture) {\n            _program.setTextureUniform('u_material_normal_texture', this.normal.texture);\n            _program.uniform('3fv', 'u_material.normalScale', this.normal.scale);\n            _program.uniform('1f', 'u_material.normalAmount', this.normal.amount);\n        }\n    }\n}\n\nMaterial.block = 'material';\n","/*jshint worker: true*/\n\n// Modules and dependencies to expose in the public Tangram module\nimport Utils from './utils/utils';\n\n// The leaflet layer plugin is currently the primary public API\nimport {LeafletLayer, leafletLayer} from './leaflet_layer';\n\n// The scene worker is only activated when a worker thread is instantiated, but must always be loaded\nimport {SceneWorker} from '../src/scene_worker';\n\n// Additional modules are exposed for debugging\nimport version from './utils/version';\nimport log from 'loglevel';\nimport Geo from './geo';\nimport DataSource from './sources/data_source';\nimport './sources/geojson';\nimport './sources/topojson';\nimport './sources/mvt';\nimport TileManager from './tile_manager';\nimport GLSL from './gl/glsl';\nimport ShaderProgram from './gl/shader_program';\nimport VertexData from './gl/vertex_data';\nimport Texture from './gl/texture';\nimport Material from './material';\nimport Light from './light';\nimport WorkerBroker from './utils/worker_broker';\nimport {ruleCache} from './styles/rule';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport FeatureSelection from './selection';\n\nimport yaml from 'js-yaml';\nimport glMatrix from 'gl-matrix';\n\n// Default to 64-bit because we need the extra precision when multiplying matrices w/mercator projected values\nglMatrix.glMatrix.setMatrixArrayType(Float64Array);\n\n// Make some modules accessible for debugging\nvar debug = {\n    log,\n    yaml,\n    Utils,\n    Geo,\n    DataSource,\n    TileManager,\n    GLSL,\n    ShaderProgram,\n    VertexData,\n    Texture,\n    Material,\n    Light,\n    SceneWorker,\n    WorkerBroker,\n    ruleCache,\n    StyleManager,\n    StyleParser,\n    FeatureSelection\n};\n\n// Window can only be set in main thread\nif (Utils.isMainThread) {\n    // Main thread objects that can be called from workers\n    WorkerBroker.addTarget('Texture', Texture);\n\n    window.Tangram = module.exports = {\n        LeafletLayer,\n        leafletLayer,\n        debug,\n        version: version.string\n    };\n\n}\n\nif (Utils.isWorkerThread) {\n    self.Tangram = {\n        debug,\n        version: version.string\n    };\n}\n\nif (Utils.isMainThread) {\n    Utils.requestAnimationFramePolyfill();\n}\n\n// Setup logging to prefix with Tangram version\nvar originalFactory = log.methodFactory;\nlog.methodFactory = function (methodName, logLevel) {\n    var rawMethod = originalFactory(methodName, logLevel);\n    return function (...message) {\n        rawMethod(`Tangram ${version.string}:`, ...message);\n    };\n};\n","/*global Scene */\nimport Geo from './geo';\nimport Utils from './utils/utils';\nimport WorkerBroker from './utils/worker_broker';\nimport subscribeMixin from './utils/subscribe';\nimport Context from './gl/context';\nimport Texture from './gl/texture';\nimport VertexArrayObject from './gl/vao';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport SceneLoader from './scene_loader';\nimport Camera from './camera';\nimport Light from './light';\nimport TileManager from './tile_manager';\nimport DataSource from './sources/data_source';\nimport FeatureSelection from './selection';\nimport RenderState from './gl/render_state';\n\nimport {Polygons} from './styles/polygons/polygons';\nimport {Lines} from './styles/lines/lines';\nimport {Points} from './styles/points/points';\nimport {TextStyle} from './styles/text/text';\n\n// Add built-in rendering styles\nStyleManager.register(Polygons);\nStyleManager.register(Lines);\nStyleManager.register(Points);\nStyleManager.register(TextStyle);\n\nimport log from 'loglevel';\nimport glMatrix from 'gl-matrix';\nlet mat4 = glMatrix.mat4;\nlet mat3 = glMatrix.mat3;\nlet vec3 = glMatrix.vec3;\n\n// Load scene definition: pass an object directly, or a URL as string to load remotely\nexport default class Scene {\n\n    constructor(config_source, options) {\n        options = options || {};\n        subscribeMixin(this);\n\n        this.initialized = false;\n        this.initializing = false;\n        this.sources = {};\n\n        this.tile_manager = TileManager;\n        this.tile_manager.init(this);\n        this.num_workers = options.numWorkers || 2;\n        this.continuous_zoom = (typeof options.continuousZoom === 'boolean') ? options.continuousZoom : true;\n        this.tile_simplification_level = 0; // level-of-detail downsampling to apply to tile loading\n        this.allow_cross_domain_workers = (options.allowCrossDomainWorkers === false ? false : true);\n        this.worker_url = options.workerUrl;\n        if (options.disableVertexArrayObjects === true) {\n            VertexArrayObject.disabled = true;\n        }\n\n        Utils.use_high_density_display = options.highDensityDisplay !== undefined ? options.highDensityDisplay : true;\n        Utils.updateDevicePixelRatio();\n\n        this.config = null;\n        this.config_source = config_source;\n        this.config_serialized = null;\n        this.last_valid_config_source = null;\n\n        this.styles = null;\n        this.active_styles = {};\n\n        this.building = null;                           // tracks current scene building state (tiles being built, etc.)\n        this.dirty = true;                              // request a redraw\n        this.animated = false;                          // request redraw every frame\n        this.preUpdate = options.preUpdate;             // optional pre-render loop hook\n        this.postUpdate = options.postUpdate;           // optional post-render loop hook\n        this.render_loop = !options.disableRenderLoop;  // disable render loop - app will have to manually call Scene.render() per frame\n        this.render_loop_active = false;\n        this.render_loop_stop = false;\n        this.frame = 0;\n        this.resetTime();\n\n        this.zoom = null;\n        this.center = null;\n\n        this.zooming = false;\n        this.preserve_tiles_within_zoom = 1;\n        this.panning = false;\n        this.container = options.container;\n\n        this.camera = null;\n        this.lights = null;\n        this.background = null;\n\n        // Model-view matrices\n        // 64-bit versions are for CPU calcuations\n        // 32-bit versions are downsampled and sent to GPU\n        this.modelMatrix = new Float64Array(16);\n        this.modelMatrix32 = new Float32Array(16);\n        this.modelViewMatrix = new Float64Array(16);\n        this.modelViewMatrix32 = new Float32Array(16);\n        this.normalMatrix = new Float64Array(9);\n        this.normalMatrix32 = new Float32Array(9);\n\n        this.selection = null;\n        this.texture_listener = null;\n\n        // Debug config\n        this.debug = {\n            profile: {\n                geometry_build: false\n            },\n            timeRebuild: n => this._timeRebuild(n)\n        };\n\n        this.updating = 0;\n        this.generation = 0; // an id that is incremented each time the scene config is invalidated\n\n        this.logLevel = options.logLevel || 'warn';\n        log.setLevel(this.logLevel);\n    }\n\n    // Load (or reload) scene config\n    // Optionally specify new scene file URL\n    load(config_source = null, config_path = null) {\n        if (this.initializing) {\n            return Promise.resolve();\n        }\n\n        this.updating++;\n        this.initialized = false;\n        this.initializing = true;\n\n        // Load scene definition (sources, styles, etc.), then create styles & workers\n        return this.loadScene(config_source, config_path)\n            .then(() => this.createWorkers())\n            .then(() => {\n                this.createCanvas();\n                this.resetFeatureSelection();\n\n                if (!this.texture_listener) {\n                    this.texture_listener = {\n                        update: () => this.dirty = true,\n                        warning: (data) => this.trigger('warning', Object.assign({ type: 'textures' }, data))\n                    };\n                    Texture.subscribe(this.texture_listener);\n                }\n\n                // Remove tiles before rebuilding\n                this.tile_manager.removeTiles(tile => !tile.visible);\n                return this.updateConfig({ rebuild: true });\n            }).then(() => {\n                this.updating--;\n                this.initializing = false;\n                this.initialized = true;\n                this.last_valid_config_source = this.config_source;\n                this.last_valid_config_path = this.config_path;\n\n                if (this.render_loop !== false) {\n                    this.setupRenderLoop();\n                }\n        }).catch(error => {\n            this.initializing = false;\n            this.updating = 0;\n\n            // Report and revert to last valid config if available\n            let type, message;\n            if (error.name === 'YAMLException') {\n                type = 'yaml';\n                message = 'Error parsing scene YAML';\n            }\n            else {\n                // TODO: more error types\n                message = 'Error initializing scene';\n            }\n            this.trigger('error', { type, message, error, url: this.config_source });\n\n            message = `Scene.load() failed to load ${this.config_source}: ${error.message}`;\n            if (this.last_valid_config_source) {\n                log.warn(message, error);\n                log.info(`Scene.load() reverting to last valid configuration`);\n                return this.load(this.last_valid_config_source, this.last_valid_config_path);\n            }\n            log.error(message, error);\n            throw error;\n        });\n    }\n\n    // For API compatibility\n    reload(config_source = null, config_path = null) {\n        return this.load(config_source, config_path);\n    }\n\n    destroy() {\n        this.initialized = false;\n        this.render_loop_stop = true; // schedule render loop to stop\n\n        this.unsubscribeAll(); // clear all event listeners\n\n        Texture.unsubscribe(this.texture_listener);\n        this.texture_listener = null;\n\n        if (this.canvas && this.canvas.parentNode) {\n            this.canvas.parentNode.removeChild(this.canvas);\n            this.canvas = null;\n        }\n        this.container = null;\n\n        if (this.selection) {\n            this.selection.destroy();\n        }\n\n        if (this.gl) {\n            Texture.destroy(this.gl);\n            StyleManager.destroy(this.gl);\n            this.styles = {};\n\n            this.gl = null;\n        }\n\n        this.sources = {};\n\n        if (Array.isArray(this.workers)) {\n            this.workers.forEach((worker) => {\n                worker.terminate();\n            });\n            this.workers = null;\n        }\n\n        this.tile_manager.destroy();\n    }\n\n    createCanvas() {\n        if (this.canvas) {\n            return;\n        }\n\n        this.container = this.container || document.body;\n        this.canvas = document.createElement('canvas');\n        this.canvas.style.position = 'absolute';\n        this.canvas.style.top = 0;\n        this.canvas.style.left = 0;\n\n        // Force tangram canvas underneath all leaflet layers, and set background to transparent\n        this.canvas.style.zIndex = -1;\n        this.container.style.cssText += 'background: transparent;';\n        this.container.appendChild(this.canvas);\n\n        try {\n            this.gl = Context.getContext(this.canvas, {\n                alpha: false /*premultipliedAlpha: false*/,\n                device_pixel_ratio: Utils.device_pixel_ratio\n            });\n        }\n        catch(e) {\n            throw new Error(\n                \"Couldn't create WebGL context. \" +\n                \"Your browser may not support WebGL, or it's turned off? \" +\n                \"Visit http://webglreport.com/ for more info.\"\n            );\n        }\n\n        this.resizeMap(this.container.clientWidth, this.container.clientHeight);\n        VertexArrayObject.init(this.gl);\n        RenderState.initialize(this.gl);\n    }\n\n    // Get the URL to load the web worker from\n    getWorkerUrl() {\n        let worker_url = this.worker_url || Utils.findCurrentURL('tangram.debug.js', 'tangram.min.js');\n\n        if (!worker_url) {\n            throw new Error(\"Can't load worker because couldn't find base URL that library was loaded from\");\n        }\n\n        if (this.allow_cross_domain_workers) {\n            let body = `importScripts('${worker_url}');`;\n            return Utils.createObjectURL(new Blob([body], { type: 'application/javascript' }));\n        }\n        return worker_url;\n    }\n\n    // Web workers handle heavy duty tile construction: networking, geometry processing, etc.\n    createWorkers() {\n        if (!this.workers) {\n            return this.makeWorkers(this.getWorkerUrl());\n        }\n        return Promise.resolve();\n    }\n\n    // Instantiate workers from URL, init event handlers\n    makeWorkers(url) {\n        var queue = [];\n\n        this.workers = [];\n        for (var id=0; id < this.num_workers; id++) {\n            var worker = new Worker(url);\n            this.workers[id] = worker;\n\n            worker.addEventListener('message', this.workerLogMessage.bind(this));\n            WorkerBroker.addWorker(worker);\n\n            log.debug(`Scene.makeWorkers: initializing worker ${id}`);\n            let _id = id;\n            queue.push(WorkerBroker.postMessage(worker, 'init', id, this.num_workers, Utils.device_pixel_ratio).then(\n                (id) => {\n                    log.debug(`Scene.makeWorkers: initialized worker ${id}`);\n                    return id;\n                },\n                (error) => {\n                    log.error(`Scene.makeWorkers: failed to initialize worker ${_id}:`, error);\n                    return Promise.reject(error);\n                })\n            );\n        }\n\n        return Promise.all(queue);\n    }\n\n    // Round robin selection of next worker\n    nextWorker() {\n        return this.workers[Math.floor(Math.random() * this.workers.length)];\n    }\n\n    /**\n        Set the map view, can be passed an object with lat/lng and/or zoom\n    */\n    setView({ lng, lat, zoom } = {}) {\n        var changed = false;\n\n        // Set center\n        if (typeof lng === 'number' && typeof lat === 'number') {\n            if (!this.center || lng !== this.center.lng || lat !== this.center.lat) {\n                changed = true;\n                this.center = { lng: Geo.wrapLng(lng), lat };\n            }\n        }\n\n        // Set zoom\n        if (typeof zoom === 'number' && zoom !== this.zoom) {\n            changed = true;\n            this.setZoom(zoom);\n        }\n\n        if (changed) {\n            this.updateBounds();\n        }\n        return changed;\n    }\n\n    startZoom() {\n        this.last_zoom = this.zoom;\n        this.zooming = true;\n    }\n\n    // Choose the base zoom level to use for a given fractional zoom\n    baseZoom(zoom) {\n        return Math.floor(zoom);\n    }\n\n    // For a given view zoom, what tile zoom should be loaded?\n    tileZoom(view_zoom) {\n        return this.baseZoom(view_zoom) - this.tile_simplification_level;\n    }\n\n    // For a given tile zoom, what style zoom should be used?\n    styleZoom(tile_zoom) {\n        return this.baseZoom(tile_zoom) + this.tile_simplification_level;\n    }\n\n    setZoom(zoom) {\n        this.zooming = false;\n        let tile_zoom = this.tileZoom(zoom);\n\n        if (!this.continuous_zoom) {\n            zoom = tile_zoom;\n        }\n\n        if (tile_zoom !== this.tileZoom(this.last_zoom)) {\n            // Remove tiles outside current zoom that are still loading\n            this.tile_manager.removeTiles(tile => {\n                if (tile.loading && this.tileZoom(tile.coords.z) !== tile_zoom) {\n                    log.trace(`removed ${tile.key} (was loading, but outside current zoom)`);\n                    return true;\n                }\n            });\n        }\n\n        this.last_zoom = this.zoom;\n        this.zoom = zoom;\n        this.tile_zoom = tile_zoom;\n\n        this.updateBounds();\n\n        this.dirty = true;\n    }\n\n    viewReady() {\n        if (this.css_size == null || this.center == null || this.zoom == null || Object.keys(this.sources).length === 0) {\n             return false;\n        }\n        return true;\n    }\n\n    // Calculate viewport bounds based on current center and zoom\n    updateBounds() {\n        // TODO: better concept of \"readiness\" state?\n        if (!this.viewReady()) {\n            return;\n        }\n\n        this.meters_per_pixel = Geo.metersPerPixel(this.zoom);\n\n        // Size of the half-viewport in meters at current zoom\n        this.viewport_meters = {\n            x: this.css_size.width * this.meters_per_pixel,\n            y: this.css_size.height * this.meters_per_pixel\n        };\n\n        // Center of viewport in meters, and tile\n        let [x, y] = Geo.latLngToMeters([this.center.lng, this.center.lat]);\n        this.center_meters = { x, y };\n\n        let z = this.tileZoom(this.zoom);\n        this.center_tile = Geo.tileForMeters([this.center_meters.x, this.center_meters.y], z);\n\n        this.bounds_meters = {\n            sw: {\n                x: this.center_meters.x - this.viewport_meters.x / 2,\n                y: this.center_meters.y - this.viewport_meters.y / 2\n            },\n            ne: {\n                x: this.center_meters.x + this.viewport_meters.x / 2,\n                y: this.center_meters.y + this.viewport_meters.y / 2\n            }\n        };\n\n        this.tile_manager.updateTilesForView();\n\n        this.trigger('move');\n        this.dirty = true;\n    }\n\n    findVisibleTileCoordinates({ buffer } = {}) {\n        if (!this.bounds_meters) {\n            return [];\n        }\n\n        let z = this.tileZoom(this.zoom);\n        let sw = Geo.tileForMeters([this.bounds_meters.sw.x, this.bounds_meters.sw.y], z);\n        let ne = Geo.tileForMeters([this.bounds_meters.ne.x, this.bounds_meters.ne.y], z);\n        buffer = buffer || 0;\n\n        let coords = [];\n        for (let x = sw.x - buffer; x <= ne.x + buffer; x++) {\n            for (let y = ne.y - buffer; y <= sw.y + buffer; y++) {\n                coords.push({ x, y, z });\n            }\n        }\n        return coords;\n    }\n\n    // Remove tiles too far outside of view\n    pruneTileCoordinatesForView(border_buffer = 2) {\n        if (!this.viewReady()) {\n            return;\n        }\n\n        // Remove tiles that are a specified # of tiles outside of the viewport border\n        let border_tiles = [\n            Math.ceil((Math.floor(this.css_size.width / Geo.tile_size) + 2) / 2),\n            Math.ceil((Math.floor(this.css_size.height / Geo.tile_size) + 2) / 2)\n        ];\n        let style_zoom = this.tileZoom(this.zoom);\n\n        this.tile_manager.removeTiles(tile => {\n            // Ignore visible tiles\n            if (tile.visible) {\n                return false;\n            }\n\n            // Discard if too far from current zoom\n            let zdiff = tile.coords.z - style_zoom;\n            if (Math.abs(zdiff) > this.preserve_tiles_within_zoom) {\n                return true;\n            }\n\n            // Handle tiles at different zooms\n            let ztrans = Math.pow(2, zdiff);\n            let coords = {\n                x: Math.floor(tile.coords.x / ztrans),\n                y: Math.floor(tile.coords.y / ztrans)\n            };\n\n            // Discard tiles outside an area surrounding the viewport\n            if (Math.abs(coords.x - this.center_tile.x) - border_tiles[0] > border_buffer) {\n                log.trace(`Scene: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${style_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            else if (Math.abs(coords.y - this.center_tile.y) - border_tiles[1] > border_buffer) {\n                log.trace(`Scene: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${style_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            return false;\n        });\n    }\n\n    resizeMap(width, height) {\n        this.dirty = true;\n\n        this.css_size = { width: width, height: height };\n        this.device_size = {\n            width: Math.round(this.css_size.width * Utils.device_pixel_ratio),\n            height: Math.round(this.css_size.height * Utils.device_pixel_ratio)\n        };\n        this.view_aspect = this.css_size.width / this.css_size.height;\n        this.updateBounds();\n\n        if (this.canvas) {\n            this.canvas.style.width = this.css_size.width + 'px';\n            this.canvas.style.height = this.css_size.height + 'px';\n            this.canvas.width = this.device_size.width;\n            this.canvas.height = this.device_size.height;\n\n            if (this.gl) {\n                this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n                this.gl.viewport(0, 0, this.canvas.width, this.canvas.height);\n            }\n        }\n    }\n\n    // Request scene be redrawn at next animation loop\n    requestRedraw() {\n        this.dirty = true;\n    }\n\n    // Redraw scene immediately - don't wait for animation loop\n    // Use sparingly, but for cases where you need the closest possible sync with other UI elements,\n    // such as other, non-WebGL map layers (e.g. Leaflet raster layers, markers, etc.)\n    immediateRedraw() {\n        this.dirty = true;\n        this.update();\n    }\n\n    renderLoop () {\n        this.render_loop_active = true; // only let the render loop instantiate once\n\n        if (this.initialized) {\n            // Render the scene\n            this.update();\n        }\n\n        // Request the next frame if not scheduled to stop\n        if (!this.render_loop_stop) {\n            window.requestAnimationFrame(this.renderLoop.bind(this));\n        }\n        else {\n            this.render_loop_stop = false;\n            this.render_loop_active = false;\n        }\n    }\n\n    // Setup the render loop\n    setupRenderLoop() {\n        if (!this.render_loop_active) {\n            setTimeout(() => { this.renderLoop(); }, 0); // delay start by one tick\n        }\n    }\n\n    update() {\n        this.tile_manager.loadQueuedCoordinates();\n\n        // Render on demand\n        var will_render = !(\n            this.dirty === false ||\n            this.initialized === false ||\n            this.updating > 0 ||\n            this.viewReady() === false\n        );\n\n        // Pre-render loop hook\n        if (typeof this.preUpdate === 'function') {\n            this.preUpdate(will_render);\n        }\n\n        // Bail if no need to render\n        if (!will_render) {\n            return false;\n        }\n        this.dirty = false; // subclasses can set this back to true when animation is needed\n\n        // Render the scene\n        this.render();\n\n        // Post-render loop hook\n        if (typeof this.postUpdate === 'function') {\n            this.postUpdate(will_render);\n        }\n\n        // Redraw every frame if animating\n        if (this.animated === true) {\n            this.dirty = true;\n        }\n\n        this.frame++;\n        log.trace('Scene.render()');\n        return true;\n    }\n\n    render() {\n        var gl = this.gl;\n\n        // Map transforms\n        if (!this.center_meters) {\n            return;\n        }\n\n        // Update styles, camera, lights\n        this.camera.update();\n        Object.keys(this.active_styles).forEach(i => this.styles[i].update());\n        Object.keys(this.lights).forEach(i => this.lights[i].update());\n\n        // Renderable tile list\n        this.renderable_tiles = this.tile_manager.getRenderableTiles();\n        this.renderable_tiles_count = this.renderable_tiles.length;\n\n        // Render main pass\n        this.render_count = this.renderPass();\n\n        // Render selection pass (if needed)\n        if (this.selection.pendingRequests()) {\n            if (this.panning) {\n                return;\n            }\n\n            this.selection.bind();                  // switch to FBO\n            this.renderPass(\n                'selection_program',                // render w/alternate program\n                { allow_alpha_blend: false });\n            this.selection.read();                  // read results from selection buffer\n\n            // Reset to screen buffer\n            gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n            gl.viewport(0, 0, this.canvas.width, this.canvas.height);\n        }\n\n        if (this.render_count !== this.last_render_count) {\n            this.getFeatureSelectionMapSize().then(size => {\n                log.info(`Scene: rendered ${this.render_count} primitives (${size} features in selection map)`);\n            }, () => {}); // no op when promise rejects (only print last response)\n        }\n        this.last_render_count = this.render_count;\n\n        return true;\n    }\n\n    // Render all active styles, grouped by blend/depth type (opaque, overlay, etc.) and by program (style)\n    // Called both for main render pass, and for secondary passes like selection buffer\n    renderPass(program_key = 'program', { allow_alpha_blend } = {}) {\n        let styles;\n        let count = 0; // how many primitives were rendered\n\n        // optionally force alpha off (e.g. for selection pass)\n        allow_alpha_blend = (allow_alpha_blend == null) ? true : allow_alpha_blend;\n\n        this.clearFrame({ clear_color: true, clear_depth: true });\n\n        // Opaque styles: depth test on, depth write on, blending off\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'opaque');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: true, alpha_blend: false });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Transparent styles: depth test off, depth write on, custom blending\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'add');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: (allow_alpha_blend && 'add') });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        styles = Object.keys(this.active_styles).filter(s => this.styles[s].blend === 'multiply');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: (allow_alpha_blend && 'multiply') });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Inlay styles: depth test on, depth write off, blending on\n        styles = Object.keys(this.styles).filter(s => this.styles[s].blend === 'inlay');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: true, depth_write: false, alpha_blend: allow_alpha_blend });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        // Overlay styles: depth test off, depth write off, blending on\n        styles = Object.keys(this.styles).filter(s => this.styles[s].blend === 'overlay');\n        if (styles.length > 0) {\n            this.setRenderState({ depth_test: false, depth_write: false, alpha_blend: allow_alpha_blend });\n            count += this.renderStyles(styles, program_key);\n        }\n\n        return count;\n    }\n\n    renderStyles(styles, program_key) {\n        let count = 0;\n        for (let style of styles) {\n            let program = this.styles[style][program_key];\n            if (!program || !program.compiled) {\n                continue;\n            }\n            count += this.renderStyle(style, program);\n        }\n        return count;\n    }\n\n    renderStyle(style, program) {\n        var first_for_style = true;\n        var render_count = 0;\n\n        // Render tile GL geometries\n        for (var t in this.renderable_tiles) {\n            var tile = this.renderable_tiles[t];\n\n            if (tile.meshes[style] != null) {\n                // Setup style if encountering for first time this frame\n                // (lazy init, not all styles will be used in all screen views; some styles might be defined but never used)\n                if (first_for_style === true) {\n                    first_for_style = false;\n\n                    program.use();\n                    this.styles[style].setup();\n\n                    // TODO: don't set uniforms when they haven't changed\n                    program.uniform('2f', 'u_resolution', this.device_size.width, this.device_size.height);\n                    program.uniform('1f', 'u_time', ((+new Date()) - this.start_time) / 1000);\n                    program.uniform('3f', 'u_map_position', this.center_meters.x, this.center_meters.y, this.zoom);\n                    // Math.floor(this.zoom) + (Math.log((this.zoom % 1) + 1) / Math.LN2 // scale fractional zoom by log\n                    program.uniform('1f', 'u_meters_per_pixel', this.meters_per_pixel);\n                    program.uniform('1f', 'u_device_pixel_ratio', Utils.device_pixel_ratio);\n\n                    // Normal matrix - transforms surface normals into view space\n                    // this matrix is constant since the view doesn't rotate for now\n                    mat3.normalFromMat4(this.normalMatrix32, this.modelViewMatrix32);\n                    program.uniform('Matrix3fv', 'u_normalMatrix', false, this.normalMatrix32);\n\n                    this.camera.setupProgram(program);\n                    for (let i in this.lights) {\n                        this.lights[i].setupProgram(program);\n                    }\n                }\n\n                // TODO: calc these once per tile (currently being needlessly re-calculated per-tile-per-style)\n\n                // Tile origin\n                program.uniform('3f', 'u_tile_origin', tile.min.x, tile.min.y, tile.style_zoom);\n\n                // Model matrix - transform tile space into world space (meters, absolute mercator position)\n                mat4.identity(this.modelMatrix);\n                mat4.translate(this.modelMatrix, this.modelMatrix, vec3.fromValues(tile.min.x, tile.min.y, 0));\n                mat4.scale(this.modelMatrix, this.modelMatrix, vec3.fromValues(tile.span.x / Geo.tile_scale, -1 * tile.span.y / Geo.tile_scale, 1)); // scale tile local coords to meters\n                mat4.copy(this.modelMatrix32, this.modelMatrix);\n                program.uniform('Matrix4fv', 'u_model', false, this.modelMatrix32);\n\n                // Model view matrix - transform tile space into view space (meters, relative to camera)\n                mat4.multiply(this.modelViewMatrix32, this.camera.viewMatrix, this.modelMatrix);\n                program.uniform('Matrix4fv', 'u_modelView', false, this.modelViewMatrix32);\n\n                // Render tile\n                tile.meshes[style].render();\n                render_count += tile.meshes[style].geometry_count;\n            }\n        }\n\n        return render_count;\n    }\n\n    clearFrame({ clear_color, clear_depth } = {}) {\n        if (!this.initialized) {\n            return;\n        }\n\n        // Defaults\n        clear_color = (clear_color === false) ? false : true; // default true\n        clear_depth = (clear_depth === false) ? false : true; // default true\n\n        // Reset frame state\n        let gl = this.gl;\n\n        if (clear_color) {\n            gl.clearColor(...this.background.color);\n        }\n\n        if (clear_depth) {\n            gl.depthMask(true); // always clear depth if requested, even if depth write will be turned off\n        }\n\n        if (clear_color || clear_depth) {\n            let mask = (clear_color && gl.COLOR_BUFFER_BIT) | (clear_depth && gl.DEPTH_BUFFER_BIT);\n            gl.clear(mask);\n        }\n    }\n\n    setRenderState({ depth_test, depth_write, cull_face, alpha_blend } = {}) {\n        if (!this.initialized) {\n            return;\n        }\n\n        // Defaults\n        // TODO: when we abstract out support for multiple render passes, these can be per-pass config options\n        depth_test = (depth_test === false) ? false : true;         // default true\n        depth_write = (depth_write === false) ? false : true;       // default true\n        cull_face = (cull_face === false) ? false : true;           // default true\n        alpha_blend = (alpha_blend != null) ? alpha_blend : false;  // default false\n\n        // Reset frame state\n        let gl = this.gl;\n\n        RenderState.depth_test.set({ depth_test: depth_test, depth_func: gl.LEQUAL });\n        RenderState.depth_write.set({ depth_write: depth_write });\n        RenderState.culling.set({ cull: cull_face, face: gl.BACK });\n\n        if (alpha_blend) {\n            // Traditional blending\n            if (alpha_blend === true) {\n                RenderState.blending.set({ blend: true, src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA });\n            }\n            // Additive blending\n            else if (alpha_blend === 'add') {\n                RenderState.blending.set({ blend: true, src: gl.ONE, dst: gl.ONE });\n            }\n            // Multiplicative blending\n            else if (alpha_blend === 'multiply') {\n                RenderState.blending.set({ blend: true, src: gl.ZERO, dst: gl.SRC_COLOR });\n            }\n        }\n        else {\n            RenderState.blending.set({ blend: false, src: null, dst: null} );\n        }\n    }\n\n    // Request feature selection at given pixel. Runs async and returns results via a promise.\n    getFeatureAt(pixel) {\n        if (!this.initialized) {\n            log.debug(\"Scene.getFeatureAt() called before scene was initialized\");\n            return Promise.resolve();\n        }\n\n        // Point scaled to [0..1] range\n        var point = {\n            x: pixel.x * Utils.device_pixel_ratio / this.device_size.width,\n            y: pixel.y * Utils.device_pixel_ratio / this.device_size.height\n        };\n\n        this.dirty = true; // need to make sure the scene re-renders for these to be processed\n        return this.selection.getFeatureAt(point);\n    }\n\n    // Rebuild geometry, without re-parsing the config or re-compiling styles\n    // TODO: detect which elements need to be refreshed/rebuilt (stylesheet changes, etc.)\n    rebuild() {\n        return this.rebuildGeometry();\n    }\n\n    // Rebuild all tiles\n    rebuildGeometry() {\n        return new Promise((resolve, reject) => {\n            // Skip rebuild if already in progress\n            if (this.building) {\n                // Queue up to one rebuild call at a time, only save last request\n                if (this.building.queued && this.building.queued.reject) {\n                    // notify previous request that it did not complete\n                    log.debug('Scene.rebuildGeometry: request superceded by a newer call');\n                    this.building.queued.resolve(false); // false flag indicates rebuild request was superceded\n                }\n\n                // Save queued request\n                this.building.queued = { resolve, reject };\n                log.trace(`Scene.rebuildGeometry(): queuing request`);\n                return;\n            }\n\n            // Track tile build state\n            this.building = { resolve, reject };\n\n            // Profiling\n            if (this.debug.profile.geometry_build) {\n                this._profile('rebuildGeometry');\n            }\n\n            // Update config (in case JS objects were manipulated directly)\n            this.syncConfigToWorker();\n            StyleManager.compile(this.updateActiveStyles(), this); // only recompile newly active styles\n            this.resetFeatureSelection();\n            this.resetTime();\n\n            // Rebuild visible tiles, sorted from center\n            let build = [];\n            this.tile_manager.forEachTile((tile) => {\n                if (tile.visible) {\n                    build.push(tile);\n                }\n                else {\n                    this.tile_manager.removeTile(tile.key);\n                }\n            });\n            this.tile_manager.buildTiles(build);\n        }).then(() => {\n            // Profiling\n            if (this.debug.profile.geometry_build) {\n                this._profileEnd('rebuildGeometry');\n            }\n        });\n    }\n\n    // Tile manager finished building tiles\n    tileManagerBuildDone() {\n        if (this.building) {\n            log.info(`Scene: build geometry finished`);\n            if (this.building.resolve) {\n                this.building.resolve(true);\n            }\n\n            // Another rebuild queued?\n            var queued = this.building.queued;\n            this.building = null;\n            if (queued) {\n                log.debug(`Scene: starting queued rebuildGeometry() request`);\n                this.rebuildGeometry().then(queued.resolve, queued.reject);\n            }\n        }\n    }\n\n    /**\n       Load (or reload) the scene config\n       @return {Promise}\n    */\n    loadScene(config_source = null, config_path = null) {\n        this.config_source = config_source || this.config_source;\n\n        if (typeof this.config_source === 'string') {\n            this.config_path = config_path || Utils.pathForURL(this.config_source);\n        }\n        else {\n            this.config_path = config_path;\n        }\n\n        return SceneLoader.loadScene(this.config_source, this.config_path).then(config => {\n            this.config = config;\n            this.trigger('load', { config: this.config });\n            return this.config;\n        });\n    }\n\n    loadDataSources() {\n        for (var name in this.config.sources) {\n            let source = this.config.sources[name];\n            this.sources[name] = DataSource.create(Object.assign({}, source, {name}));\n\n            if (!this.sources[name]) {\n                delete this.sources[name];\n                log.warn(`Scene: could not create data source`, source);\n                this.trigger('warning', { type: 'sources', source, message: `Could not create data source` });\n            }\n        }\n    }\n\n    // Load all textures in the scene definition\n    loadTextures() {\n        return Texture.createFromObject(this.gl, this.config.textures);\n    }\n\n    // Called (currently manually) after styles are updated in stylesheet\n    updateStyles() {\n        if (!this.initialized && !this.initializing) {\n            throw new Error('Scene.updateStyles() called before scene was initialized');\n        }\n\n        // (Re)build styles from config\n        StyleManager.init();\n        this.styles = StyleManager.build(this.config.styles, this);\n\n        // Optionally set GL context (used when initializing or re-initializing GL resources)\n        for (var style of Utils.values(this.styles)) {\n            style.setGL(this.gl);\n        }\n\n        // Find & compile active styles\n        this.updateActiveStyles();\n        StyleManager.compile(Object.keys(this.active_styles), this);\n\n        this.dirty = true;\n    }\n\n    updateActiveStyles() {\n        // Make a set of currently active styles (used in a draw rule)\n        // Note: doesn't actually check if any geometry matches the rule, just that the style is potentially renderable\n        let prev_styles = Object.keys(this.active_styles || {});\n        this.active_styles = {};\n        var animated = false; // is any active style animated?\n        for (var rule of Utils.recurseValues(this.config.layers)) {\n            if (rule.draw) {\n                for (let [name, group] of Utils.entries(rule.draw)) {\n                    // TODO: warn on non-object draw group\n                    if (typeof group === 'object' && group.visible !== false) {\n                        let style_name = group.style || name;\n                        let styles = [style_name];\n\n                        // optional additional outline style\n                        if (group.outline && group.outline.style) {\n                            styles.push(group.outline.style);\n                        }\n\n                        styles = styles.filter(x => this.styles[x]).forEach(style_name => {\n                            let style = this.styles[style_name];\n                            if (style) {\n                                this.active_styles[style_name] = true;\n                                if (style.animated) {\n                                    animated = true;\n                                }\n                            }\n                        });\n                    }\n                }\n            }\n        }\n\n        // Use explicitly set scene animation flag if defined, otherwise turn on animation\n        // if there are any animated styles\n        this.animated = this.config.scene.animated !== undefined ? this.config.scene.animated : animated;\n\n        // Compile newly active styles\n        return Object.keys(this.active_styles).filter(s => prev_styles.indexOf(s) === -1);\n    }\n\n    // Create camera\n    createCamera() {\n        let active_camera = this._active_camera;\n        if (active_camera) {\n            this.camera = Camera.create(active_camera, this, this.config.cameras[this._active_camera]);\n\n            // TODO: replace this and move all position info to camera\n            this.camera.updateScene();\n        }\n    }\n\n    // Get active camera - for public API\n    getActiveCamera() {\n        return this._active_camera;\n    }\n\n    // Set active camera and recompile - for public API\n    setActiveCamera(name) {\n        this._active_camera = name;\n        this.updateConfig();\n        return this._active_camera;\n    }\n\n    // Internal management of active camera\n    get _active_camera() {\n        if (this.config && this.config.cameras) {\n            for (var name in this.config.cameras) {\n                if (this.config.cameras[name].active) {\n                    return name;\n                }\n            }\n        }\n    }\n\n    set _active_camera(name) {\n        var prev = this._active_camera;\n\n        // Set new active camera\n        if (this.config.cameras[name]) {\n            this.config.cameras[name].active = true;\n\n            // Clear previously active camera\n            if (prev && prev !== name && this.config.cameras[prev]) {\n                delete this.config.cameras[prev].active;\n            }\n        }\n    }\n\n    // Create lighting\n    createLights() {\n        this.lights = {};\n        for (let i in this.config.lights) {\n            if (!this.config.lights[i] || typeof this.config.lights[i] !== 'object') {\n                continue;\n            }\n            let light = this.config.lights[i];\n            light.name = i.replace('-', '_'); // light names are injected in shaders, can't have hyphens\n            light.visible = (light.visible === false) ? false : true;\n            if (light.visible) {\n                this.lights[light.name] = Light.create(this, light);\n            }\n        }\n        Light.inject(this.lights);\n    }\n\n    // Set background color\n    setBackground() {\n        let bg = this.config.scene.background;\n        this.background = {};\n        if (bg && bg.color) {\n            this.background.color = StyleParser.parseColor(bg.color);\n        }\n        if (!this.background.color) {\n            this.background.color = [0, 0, 0, 1]; // default background to black\n        }\n    }\n\n    // Update scene config, and optionally rebuild geometry\n    updateConfig({ rebuild } = {}) {\n        this.generation++;\n        this.updating++;\n        this.config.scene = this.config.scene || {};\n        this.createCamera();\n        this.createLights();\n        this.loadDataSources();\n        this.loadTextures();\n        this.setBackground();\n        this.updateBounds();\n\n        // TODO: detect changes to styles? already (currently) need to recompile anyway when camera or lights change\n        this.updateStyles();\n        this.syncConfigToWorker();\n        if (rebuild) {\n            return this.rebuildGeometry().then(() => this.updating--);\n        }\n        else {\n            this.updating--;\n            return Promise.resolve();\n        }\n    }\n\n    // Serialize config and send to worker\n    syncConfigToWorker() {\n        // Tell workers we're about to rebuild (so they can update styles, etc.)\n        this.config_serialized = Utils.serializeWithFunctions(this.config);\n        this.workers.forEach(worker => {\n            WorkerBroker.postMessage(worker, 'updateConfig', {\n                config: this.config_serialized,\n                generation: this.generation\n            });\n        });\n    }\n\n    resetFeatureSelection() {\n        if (!this.selection) {\n            this.selection = new FeatureSelection(this.gl, this.workers);\n        }\n        else if (this.workers) {\n            this.workers.forEach(worker => WorkerBroker.postMessage(worker, 'resetFeatureSelection'));\n        }\n    }\n\n    // Gets the current feature selection map size across all workers. Returns a promise.\n    getFeatureSelectionMapSize() {\n        if (this.fetching_selection_map) {\n            return Promise.reject();\n        }\n        this.fetching_selection_map = true;\n\n        return Promise\n            .all(this.workers.map(worker => WorkerBroker.postMessage(worker, 'getFeatureSelectionMapSize')))\n            .then(sizes => {\n                this.fetching_selection_map = false;\n                return sizes.reduce((a, b) => a + b);\n            });\n    }\n\n    // Reset internal clock, mostly useful for consistent experience when changing styles/debugging\n    resetTime() {\n        this.start_time = +new Date();\n    }\n\n\n    // Stats/debug/profiling methods\n\n    // Log messages pass through from web workers\n    workerLogMessage(event) {\n        if (event.data.type !== 'log') {\n            return;\n        }\n\n        var { worker_id, level, msg } = event.data;\n\n        if (log[level]) {\n            log[level](`worker ${worker_id}:`,  ...msg);\n        }\n        else {\n            log.error(`Scene.workerLogMessage: unrecognized log level ${level}`);\n        }\n    }\n\n    // Profile helpers, issues a profile on main thread & all workers\n    _profile(name) {\n        console.profile(`main thread: ${name}`);\n        this.workers.forEach(w => WorkerBroker.postMessage(w, 'profile', name));\n    }\n\n    _profileEnd(name) {\n        console.profileEnd(`main thread: ${name}`);\n        this.workers.forEach(w => WorkerBroker.postMessage(w, 'profileEnd', name));\n    }\n\n    // Rebuild geometry a given # of times and print average, min, max timings\n    _timeRebuild (num = 1) {\n        let times = [];\n        let cycle = () => {\n            let start = +new Date();\n            this.rebuild().then(() => {\n                times.push(+new Date() - start);\n\n                if (times.length < num) {\n                    cycle();\n                }\n                else {\n                    let avg = ~~(times.reduce((a, b) => a + b) / times.length);\n                    log.info(`Profiled rebuild ${num} times: ${avg} avg (${Math.min(...times)} min, ${Math.max(...times)} max)`);\n                }\n            });\n        };\n        cycle();\n    }\n\n}\n\n// Static methods/state\n\nScene.create = function (config, options = {}) {\n    return new Scene(config, options);\n};\n","import Utils from './utils/utils';\nimport GLSL from './gl/glsl';\n// import {mergeObjects} from './styles/rule';\nimport {StyleManager} from './styles/style_manager';\n\nvar SceneLoader;\n\nexport default SceneLoader = {\n\n    // Load scenes definitions from URL & proprocess\n    loadScene(url, path = null) {\n        return SceneLoader.loadSceneRecursive(url, path).then(SceneLoader.finalize);\n    },\n\n    // Loads scene files from URL, recursively loading 'included' scenes\n    // Optional *initial* path only (won't be passed to recursive 'include' calls)\n    // Useful for loading resources in base scene file from a separate location\n    // (e.g. in Tangram Play, when modified local scene should still refer to original resource URLs)\n    loadSceneRecursive(url, path = null) {\n        if (!url) {\n            return Promise.resolve({});\n        }\n\n        if (typeof url === 'string') {\n            path = path || Utils.pathForURL(url);\n        }\n\n        return Utils.loadResource(url).then(config => {\n            return StyleManager.loadRemoteStyles(config.styles, path).\n                then(styles => StyleManager.loadShaderBlocks(styles, path)). // TODO: deprecate remote shader blocks?\n                then(() => {\n                    // accept single-string or array\n                    // if (typeof config.include === 'string') {\n                    //     config.include = [config.include];\n                    // }\n\n                    // if (!Array.isArray(config.include)) {\n                        SceneLoader.normalize(config, path);\n                        return config;\n                    // }\n\n                    // Collect URLs of scenes to include\n                    // let includes = [];\n                    // for (let url of config.include) {\n                    //     includes.push(Utils.addBaseURL(url, path));\n                    // }\n                    // delete config.include; // don't want to merge this property\n\n                    // return Promise.\n                    //     all(includes.map(url => SceneLoader.loadSceneRecursive(url))).\n                    //     then(configs => {\n                    //         config = mergeObjects({}, ...configs, config);\n                    //         SceneLoader.normalize(config, path);\n                    //         return config;\n                    //     });\n                });\n        });\n    },\n\n    // Normalize properties that should be adjust within each local scene file (usually by path)\n    normalize(config, path) {\n        SceneLoader.normalizeDataSources(config, path);\n        SceneLoader.normalizeTextures(config, path);\n        return config;\n    },\n\n    // Expand paths for data source\n    normalizeDataSources(config, path) {\n        config.sources = config.sources || {};\n\n        for (let source of  Utils.values(config.sources)) {\n            source.url = Utils.addBaseURL(source.url, path);\n        }\n\n        return config;\n    },\n\n    // Expand paths and centralize texture definitions for a scene object\n    normalizeTextures(config, path) {\n        config.textures = config.textures || {};\n\n        if (config.styles) {\n            for (let [style_name, style] of Utils.entries(config.styles)) {\n                if (style.texture) {\n                    // Texture by URL, expand relative to scene file\n                    if (typeof style.texture === 'string' && !config.textures[style.texture]) {\n                        style.texture = Utils.addBaseURL(style.texture, path);\n                    }\n                    // Texture by object, move it to the global scene texture set and give it a default name\n                    else if (typeof style.texture === 'object') {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = style.texture;\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                }\n\n                // If style has texture uniforms, expand texture URLs relative to scene file\n                if (style.shaders && style.shaders.uniforms) {\n                    for (let {type, value, key, uniforms} of GLSL.parseUniforms(style.shaders.uniforms)) {\n                        if (type === 'sampler2D' && !config.textures[value]) {\n                            uniforms[key] = Utils.addBaseURL(value, path);\n                        }\n                    }\n                }\n\n                // If style has material, expand texture URLs relative to scene file\n                if (style.material) {\n                    for (let prop of ['emission', 'ambient', 'diffuse', 'specular', 'normal']) {\n                        if (style.material[prop] != null &&\n                            style.material[prop].texture &&\n                            !config.textures[style.material[prop].texture]) {\n                            style.material[prop].texture = Utils.addBaseURL(style.material[prop].texture, path);\n                        }\n                    }\n                }\n            }\n        }\n\n        // Add path to textures\n        if (config.textures) {\n            for (let texture of Utils.values(config.textures)) {\n                texture.url = Utils.addBaseURL(texture.url, path);\n            }\n        }\n\n        return config;\n    },\n\n    // Normalize some scene-wide settings that apply to the final, merged scene\n    finalize(config) {\n        // Assign ids to data sources\n        let source_id = 0;\n        for (let source in config.sources) {\n            config.sources[source].id = source_id++;\n        }\n\n        // If only one camera specified, set it as default\n        config.cameras = config.cameras || {};\n        if (config.camera) {\n            config.cameras.default = config.camera;\n        }\n\n        // If no cameras specified, create one\n        if (Object.keys(config.cameras).length === 0) {\n            config.cameras.default = {};\n        }\n\n        // If no camera set as active, use first one\n        let active = false;\n        for (let camera of Utils.values(config.cameras)) {\n            if (camera.active) {\n                active = true;\n                break;\n            }\n        }\n\n        if (!active) {\n            config.cameras[Object.keys(config.cameras)[0]].active = true;\n        }\n\n        // Ensure top-level properties\n        config.lights = config.lights || {};\n        config.styles = config.styles || {};\n\n        return config;\n    }\n\n};\n","/*jshint worker: true*/\nimport Utils from './utils/utils';\nimport WorkerBroker from './utils/worker_broker'; // jshint ignore:line\nimport Tile from './tile';\nimport DataSource from './sources/data_source';\nimport FeatureSelection from './selection';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport {parseRules} from './styles/rule';\nimport Texture from './gl/texture';\n\nexport var SceneWorker = self;\n\n// Worker functionality will only be defined in worker thread\nUtils.isWorkerThread && Object.assign(self, {\n\n    FeatureSelection,\n\n    sources: {\n        tiles: {},\n        objects: {}\n    },\n    styles: {},\n    rules: {},\n    layers: {},\n    tiles: {},\n    objects: {},\n    config: {},\n\n    // Initialize worker\n    init (worker_id, num_workers, device_pixel_ratio) {\n        self._worker_id = worker_id;\n        self.num_workers = num_workers;\n        Utils.device_pixel_ratio = device_pixel_ratio;\n        FeatureSelection.setPrefix(self._worker_id);\n        return worker_id;\n    },\n\n    // Starts a config refresh\n    updateConfig ({ config, generation }) {\n        self.config = null;\n        config = JSON.parse(config);\n\n        self.generation = generation;\n        self.styles = null;\n\n        // Data block functions are not macro'ed and wrapped like the rest of the style functions are\n        // TODO: probably want a cleaner way to exclude these\n        for (var layer in config.layers) {\n            config.layers[layer].data = Utils.stringsToFunctions(config.layers[layer].data);\n        }\n\n        // Create data sources\n        config.sources = Utils.stringsToFunctions(StyleParser.expandMacros(config.sources));\n        for (var name in config.sources) {\n            let source = DataSource.create(Object.assign(config.sources[name], {name}));\n            if (!source) {\n                continue;\n            }\n\n            if (source.tiled) {\n                self.sources.tiles[name] = source;\n            }\n            else {\n                // Distribute object sources across workers\n                if (source.id % self.num_workers === self._worker_id) {\n                    // Load source if not cached\n                    self.sources.objects[name] = source;\n                    if (!self.objects[source.name]) {\n                        self.objects[source.name] = {};\n                        source.load(self.objects[source.name]);\n                    }\n                }\n            }\n        }\n\n        // Expand styles\n        self.config = Utils.stringsToFunctions(StyleParser.expandMacros(config), StyleParser.wrapFunction);\n        self.styles = StyleManager.build(self.config.styles, { generation: self.generation });\n\n        // Parse each top-level layer as a separate rule tree\n        // TODO: find a more graceful way to incorporate this\n\n        self.rules = parseRules(self.config.layers);\n\n        // Sync tetxure info from main thread\n        self.syncing_textures = self.syncTextures();\n\n        // Return promise for when config refresh finishes\n        self.configuring = self.syncing_textures.then(() => {\n            Utils.log('debug', `updated config`);\n        });\n    },\n\n    // Returns a promise that fulfills when config refresh is finished\n    awaitConfiguration () {\n        return self.configuring;\n    },\n\n    // Build a tile: load from tile source if building for first time, otherwise rebuild with existing data\n    buildTile ({ tile }) {\n        // Tile cached?\n        if (self.tiles[tile.key] != null) {\n            // Already loading?\n            if (self.tiles[tile.key].loading === true) {\n                return;\n            }\n        }\n\n        // Update tile cache\n        tile = self.tiles[tile.key] = Object.assign(self.tiles[tile.key] || {}, tile);\n\n        // Update config (styles, etc.), then build tile\n        return self.awaitConfiguration().then(() => {\n            // First time building the tile\n            if (tile.loaded !== true) {\n\n                return new Promise((resolve, reject) => {\n\n                    tile.loading = true;\n                    tile.loaded = false;\n                    tile.error = null;\n\n                    self.loadTileSourceData(tile).then(() => {\n                        // Warn and continue on data source error\n                        if (tile.source_data.error) {\n                            Utils.log('warn', `tile load error(s) for ${tile.key}: ${tile.source_data.error}`);\n                        }\n\n                        tile.loading = false;\n                        tile.loaded = true;\n                        Tile.buildGeometry(tile, self.config.layers, self.rules, self.styles).then(keys => {\n                            resolve({ tile: Tile.slice(tile, keys) });\n                        });\n                    }).catch((error) => {\n                        tile.loading = false;\n                        tile.loaded = false;\n                        tile.error = error.toString();\n                        Utils.log('error', `tile load error for ${tile.key}: ${error.stack}`);\n\n                        resolve({ tile: Tile.slice(tile) });\n                    });\n                });\n            }\n            // Tile already loaded, just rebuild\n            else {\n                Utils.log('trace', `used worker cache for tile ${tile.key}`);\n\n                // Build geometry\n                return Tile.buildGeometry(tile, self.config.layers, self.rules, self.styles).then(keys => {\n                    return { tile: Tile.slice(tile, keys) };\n                });\n            }\n        });\n    },\n\n    // Load this tile's data source\n    loadTileSourceData (tile) {\n        return self.sources.tiles[tile.source].load(tile);\n    },\n\n    // Remove tile\n    removeTile (key) {\n        var tile = self.tiles[key];\n\n        if (tile != null) {\n            // Cancel if loading\n            if (tile.loading === true) {\n                Utils.log('trace', `cancel tile load for ${key}`);\n                tile.loading = false;\n            }\n\n            Tile.cancel(tile);\n\n            // Remove from cache\n            FeatureSelection.clearTile(key);\n            delete self.tiles[key];\n            Utils.log('trace', `remove tile from cache for ${key}`);\n        }\n    },\n\n    // Get a feature from the selection map\n    getFeatureSelection ({ id, key } = {}) {\n        var selection = FeatureSelection.map[key];\n\n        return {\n            id: id,\n            feature: (selection && selection.feature)\n        };\n    },\n\n    // Resets the feature selection state\n    resetFeatureSelection () {\n        FeatureSelection.reset();\n    },\n\n    // Selection map size for this worker\n    getFeatureSelectionMapSize () {\n        return FeatureSelection.getMapSize();\n    },\n\n    // Texture info needs to be synced from main thread\n    syncTextures () {\n        // We're only syncing the textures that have sprites defined, since these are (currently) the only ones we\n        // need info about for geometry construction (e.g. width/height, which we only know after the texture loads)\n        let textures = [];\n        if (self.config.textures) {\n            for (let [texname, texture] of Utils.entries(self.config.textures)) {\n                if (texture.sprites) {\n                    textures.push(texname);\n                }\n            }\n        }\n\n        Utils.log('trace', 'sync textures to worker:', textures);\n        if (textures.length > 0) {\n            return Texture.syncTexturesToWorker(textures);\n        }\n        return Promise.resolve();\n    },\n\n    // Profiling helpers\n    profile (name) {\n        console.profile(`worker ${self._worker_id}: ${name}`);\n    },\n\n    profileEnd (name) {\n        console.profileEnd(`worker ${self._worker_id}: ${name}`);\n    }\n\n});\n","import Texture from './gl/texture';\nimport WorkerBroker from './utils/worker_broker';\n\nexport default class FeatureSelection {\n\n    constructor(gl, workers) {\n        this.gl = gl;\n        this.workers = workers; // pool of workers to request feature look-ups from, keyed by id\n        this.init();\n    }\n\n    init() {\n        // Selection state tracking\n        this.requests = {}; // pending selection requests\n        this.feature = null; // currently selected feature\n        this.read_delay = 5; // delay time from selection render to framebuffer sample, to avoid CPU/GPU sync lock\n        this.read_delay_timer = null; // current timer (setTimeout) for delayed selection reads\n\n        this.pixel = new Uint8Array(4);\n        this.pixel32 = new Float32Array(this.pixel.buffer);\n\n        // Frame buffer for selection\n        // TODO: initiate lazily in case we don't need to do any selection\n        this.fbo = this.gl.createFramebuffer();\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, this.fbo);\n        this.fbo_size = { width: 256, height: 256 }; // TODO: make configurable / adaptive based on canvas size\n        this.fbo_size.aspect = this.fbo_size.width / this.fbo_size.height;\n\n        // Texture for the FBO color attachment\n        var fbo_texture = new Texture(this.gl, 'selection_fbo');\n        fbo_texture.setData(this.fbo_size.width, this.fbo_size.height, null, { filtering: 'nearest' });\n        this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER, this.gl.COLOR_ATTACHMENT0, this.gl.TEXTURE_2D, fbo_texture.texture, 0);\n\n        // Renderbuffer for the FBO depth attachment\n        var fbo_depth_rb = this.gl.createRenderbuffer();\n        this.gl.bindRenderbuffer(this.gl.RENDERBUFFER, fbo_depth_rb);\n        this.gl.renderbufferStorage(this.gl.RENDERBUFFER, this.gl.DEPTH_COMPONENT16, this.fbo_size.width, this.fbo_size.height);\n        this.gl.framebufferRenderbuffer(this.gl.FRAMEBUFFER, this.gl.DEPTH_ATTACHMENT, this.gl.RENDERBUFFER, fbo_depth_rb);\n\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n    }\n\n    destroy() {\n        if (this.gl && this.fbo) {\n            this.gl.deleteFramebuffer(this.fbo);\n            this.fbo = null;\n            this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, null);\n        }\n\n        // TODO: free texture?\n    }\n\n    bind() {\n        // Switch to FBO\n        this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, this.fbo);\n        this.gl.viewport(0, 0, this.fbo_size.width, this.fbo_size.height);\n    }\n\n    // Request feature selection\n    // Runs asynchronously, schedules selection buffer to be updated\n    getFeatureAt(point) {\n        return new Promise((resolve, reject) => {\n            // Queue requests for feature selection, and they will be picked up by the render loop\n            this.selection_request_id = (this.selection_request_id + 1) || 0;\n            this.requests[this.selection_request_id] = {\n                type: 'point',\n                id: this.selection_request_id,\n                point,\n                resolve\n            };\n        });\n    }\n\n    // Any pending selection requests\n    pendingRequests() {\n        return this.requests;\n    }\n\n    // Read pending results from the selection buffer. Called after rendering to selection buffer.\n    read() {\n        // Delay reading the pixel result from the selection buffer to avoid CPU/GPU sync lock.\n        // Calling readPixels synchronously caused a massive performance hit, presumably since it\n        // forced this function to wait for the GPU to finish rendering and retrieve the texture contents.\n        if (this.read_delay_timer != null) {\n            clearTimeout(this.read_delay_timer);\n        }\n        this.read_delay_timer = setTimeout(() => {\n            var gl = this.gl;\n\n            gl.bindFramebuffer(gl.FRAMEBUFFER, this.fbo);\n\n            for (var r in this.requests) {\n                var request = this.requests[r];\n\n                // This request was already sent to the worker, we're just awaiting its reply\n                if (request.sent) {\n                    continue;\n                }\n\n                // TODO: support other selection types, such as features within a box\n                if (request.type !== 'point') {\n                    continue;\n                }\n\n                // Check selection map against FBO\n                gl.readPixels(\n                    Math.floor(request.point.x * this.fbo_size.width),\n                    Math.floor((1 - request.point.y) * this.fbo_size.height),\n                    1, 1, gl.RGBA, gl.UNSIGNED_BYTE, this.pixel);\n                var feature_key = (this.pixel[0] + (this.pixel[1] << 8) + (this.pixel[2] << 16) + (this.pixel[3] << 24)) >>> 0;\n\n                // If feature found, ask appropriate web worker to lookup feature\n                var worker_id = this.pixel[3];\n                if (worker_id !== 255) { // 255 indicates an empty selection buffer pixel\n                    if (this.workers[worker_id] != null) {\n                        WorkerBroker.postMessage(\n                            this.workers[worker_id],\n                            'getFeatureSelection',\n                            { id: request.id, key: feature_key })\n                        .then(message => {\n                            this.finishRead(message);\n                        });\n                    }\n                }\n                // No feature found, but still need to resolve promise\n                else {\n                    this.finishRead({ id: request.id, feature: null });\n                }\n\n                request.sent = true;\n            }\n\n            gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n\n        }, this.read_delay);\n    }\n\n    // Called on main thread when a web worker finds a feature in the selection buffer\n    finishRead (message) {\n        var request = this.requests[message.id];\n        if (!request) {\n            throw new Error(\"FeatureSelection.finishRead() called without any message\");\n        }\n\n        var feature = message.feature;\n        var changed = false;\n        if ((feature != null && this.feature == null) ||\n            (feature == null && this.feature != null) ||\n            (feature != null && this.feature != null && feature.id !== this.feature.id)) {\n            changed = true;\n        }\n\n        this.feature = feature; // store the most recently selected feature\n\n        // Resolve the request\n        request.resolve({ feature, changed, request });\n        delete this.requests[message.id]; // done processing this request\n    }\n\n\n    // Selection map generation\n    // Each worker will create its own independent, 'local' selection map\n\n    // Create a unique 32-bit color to identify a feature\n    // Workers independently create/modify selection colors in their own threads, but we also\n    // need the main thread to know where each feature color originated. To accomplish this,\n    // we partition the map by setting the 4th component (alpha channel) to the worker's id.\n    static makeEntry(tile) {\n        // 32-bit color key\n        this.map_entry++;\n        var ir = this.map_entry & 255;\n        var ig = (this.map_entry >> 8) & 255;\n        var ib = (this.map_entry >> 16) & 255;\n        var ia = this.map_prefix;\n        var r = ir / 255;\n        var g = ig / 255;\n        var b = ib / 255;\n        var a = ia / 255;\n        var key = (ir + (ig << 8) + (ib << 16) + (ia << 24)) >>> 0; // need unsigned right shift to convert to positive #\n\n        this.map[key] = {\n            color: [r, g, b, a],\n        };\n        this.map_size++;\n\n        this.tiles[tile.key] = this.tiles[tile.key] || [];\n        this.tiles[tile.key].push(key);\n\n        return this.map[key];\n    }\n\n    static makeColor(feature, tile) {\n        var selector = this.makeEntry(tile);\n        selector.feature = {\n            id: feature.id,\n            properties: feature.properties,\n            tile: tile.key\n        };\n\n        return selector.color;\n    }\n\n    static reset() {\n        this.tiles = {};\n        this.map = {};\n        this.map_size = 0;\n        this.map_entry = 0;\n    }\n\n    static clearTile(key) {\n        if (Array.isArray(this.tiles[key])) {\n            this.tiles[key].forEach(k => delete this.map[k]);\n            this.map_size -= this.tiles[key].length;\n            delete this.tiles[key];\n        }\n    }\n\n    static getMapSize() {\n        return this.map_size;\n    }\n\n    static setPrefix(prefix) {\n        this.map_prefix = prefix;\n    }\n\n}\n\n// Static properties\nFeatureSelection.map = {};   // this will be unique per module instance (so unique per worker)\nFeatureSelection.tiles = {}; // selection keys, by tile\nFeatureSelection.map_size = 0;\nFeatureSelection.map_entry = 0;\nFeatureSelection.map_prefix = 0; // set by worker to worker id #\nFeatureSelection.defaultColor = [0, 0, 0, 1];\n","/*jshint worker: true */\nimport Geo from '../geo';\nimport {MethodNotImplemented} from '../utils/errors';\nimport Utils from '../utils/utils';\n\nexport default class DataSource {\n\n    constructor (source) {\n        this.id = source.id;\n        this.name = source.name;\n        this.url = source.url;\n        this.pad_scale = source.pad_scale || 0.0005; // scale tile up by small factor to cover seams\n        this.enforce_winding = source.enforce_winding || false; // whether to enforce winding order\n\n        // Optional function to transform source data\n        this.transform = source.transform;\n        if (typeof this.transform === 'function') {\n            this.transform.bind(this);\n        }\n\n        // Optional additional data to pass to the transform function\n        this.extra_data = source.extra_data;\n\n        // Optional additional scripts made available to the transform function\n        if (typeof importScripts === 'function' && source.scripts) {\n            source.scripts.forEach(function(s, si) {\n                try {\n                    importScripts(s);\n                    Utils.log('info', 'DataSource: loaded library: ' + s);\n                }\n                catch (e) {\n                    Utils.log('error', 'DataSource: failed to load library: ' + s);\n                    Utils.log('error', e);\n                }\n            });\n        }\n\n        // overzoom will apply for zooms higher than this\n        this.max_zoom = Math.min(source.max_zoom || Geo.max_zoom, Geo.max_zoom);\n    }\n\n    // Create a tile source by type, factory-style\n    static create (source) {\n        if (DataSource.types[source.type]) {\n            return new DataSource.types[source.type](source);\n        }\n    }\n\n    // Mercator projection\n    static projectData (source) {\n        var timer = +new Date();\n        for (var t in source.layers) {\n            var num_features = source.layers[t].features.length;\n            for (var f=0; f < num_features; f++) {\n                var feature = source.layers[t].features[f];\n                Geo.transformGeometry(feature.geometry, coord => {\n                    var [x, y] = Geo.latLngToMeters(coord);\n                    coord[0] = x;\n                    coord[1] = y;\n                });\n            }\n        }\n\n        if (source.debug !== undefined) {\n            source.debug.projection = +new Date() - timer;\n        }\n    }\n\n    /**\n     Re-scale geometries within each source to internal tile units\n    */\n    static scaleData (source, {coords: {z}, min, max}) {\n        for (var t in source.layers) {\n            var num_features = source.layers[t].features.length;\n            for (var f=0; f < num_features; f++) {\n                var feature = source.layers[t].features[f];\n                Geo.transformGeometry(feature.geometry, coord => {\n                    coord[0] = (coord[0] - min.x) * Geo.units_per_meter[z];\n                    coord[1] = (coord[1] - min.y) * Geo.units_per_meter[z] * -1; // flip coords positive\n                });\n            }\n        }\n    }\n\n    load(dest) {\n        dest.source_data = {};\n        dest.source_data.layers = {};\n        dest.pad_scale = this.pad_scale;\n\n        return this._load(dest).then((dest) => {\n            // Post-processing\n            for (let layer in dest.source_data.layers) {\n                let data = dest.source_data.layers[layer];\n                if (data && data.features) {\n                    data.features.forEach(feature => {\n                        Geo.transformGeometry(feature.geometry, coord => {\n                            // Flip Y coords\n                            coord[1] = -coord[1];\n\n                            // Slightly scale up tile to cover seams\n                            if (this.pad_scale) {\n                                coord[0] = Math.round(coord[0] * (1 + this.pad_scale) - (Geo.tile_scale * this.pad_scale/2));\n                                coord[1] = Math.round(coord[1] * (1 + this.pad_scale) - (Geo.tile_scale * this.pad_scale/2));\n                            }\n                        });\n\n                        // Optionally enforce winding order since not all data sources guarantee it\n                        if (this.enforce_winding) {\n                            Geo.enforceWinding(feature.geometry, 'CCW');\n                        }\n                    });\n                }\n            }\n        });\n    }\n\n    // Sub-classes must implement\n    _load(dest) {\n        throw new MethodNotImplemented('_load');\n    }\n\n    // Register a new data source type, under a type name\n    static register(type_class, type_name) {\n        if (!type_class || !type_name) {\n            return;\n        }\n\n        DataSource.types[type_name] = type_class;\n    }\n\n}\n\nDataSource.types = {}; // set of supported data source classes, referenced by type name\n\n\n/*** Generic network loading source - abstract class ***/\n\nexport class NetworkSource extends DataSource {\n\n    constructor (source) {\n        super(source);\n        this.response_type = \"\"; // use to set explicit XHR type\n    }\n\n    _load (dest) {\n        // super.load(dest);\n\n        let url = this.formatUrl(dest);\n\n        let source_data = dest.source_data;\n        source_data.url = url;\n        dest.debug = dest.debug || {};\n        dest.debug.network = +new Date();\n\n        return new Promise((resolve, reject) => {\n            source_data.error = null;\n            // For testing network errors\n            // var promise = Utils.io(url, 60 * 100, this.response_type);\n            // if (Math.random() < .7) {\n            //     promise = Promise.reject(Error('fake data source error'));\n            // }\n            // promise.then((body) => {\n            let promise = Utils.io(url, 60 * 1000, this.response_type);\n            source_data.request = promise.request;\n\n            promise.then((body) => {\n                dest.debug.response_size = body.length || body.byteLength;\n                dest.debug.network = +new Date() - dest.debug.network;\n                dest.debug.parsing = +new Date();\n                this.parseSourceData(dest, source_data, body);\n                dest.debug.parsing = +new Date() - dest.debug.parsing;\n                resolve(dest);\n            }).catch((error) => {\n                source_data.error = error.toString();\n                resolve(dest); // resolve request but pass along error\n            });\n        });\n    }\n\n    // Sub-classes must implement:\n\n    formatUrl (dest) {\n        throw new MethodNotImplemented('formatUrl');\n    }\n\n    parseSourceData (dest, source, reponse) {\n        throw new MethodNotImplemented('parseSourceData');\n    }\n}\n\n\n/*** Generic network tile loading - abstract class ***/\n\nexport class NetworkTileSource extends NetworkSource {\n\n    constructor (source) {\n        super(source);\n\n        this.tiled = true;\n        this.url_hosts = null;\n        var host_match = this.url.match(/{s:\\[([^}+]+)\\]}/);\n        if (host_match != null && host_match.length > 1) {\n            this.url_hosts = host_match[1].split(',');\n            this.next_host = 0;\n        }\n    }\n\n    formatUrl(tile) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n        var url = this.url.replace('{x}', coords.x).replace('{y}', coords.y).replace('{z}', coords.z);\n\n        if (this.url_hosts != null) {\n            url = url.replace(/{s:\\[([^}+]+)\\]}/, this.url_hosts[this.next_host]);\n            this.next_host = (this.next_host + 1) % this.url_hosts.length;\n        }\n        return url;\n    }\n\n    // Checks for the x/y/z tile pattern in URL template\n    urlHasTilePattern(url) {\n        return url &&\n            url.search('{x}') > -1 &&\n            url.search('{y}') > -1 &&\n            url.search('{z}') > -1;\n    }\n\n}\n","import DataSource, {NetworkSource, NetworkTileSource} from './data_source';\nimport Geo from '../geo';\n\n// For tiling GeoJSON client-side\nimport geojsonvt from 'geojson-vt';\n\n\n/**\n Mapzen/OSM.US-style GeoJSON vector tiles\n @class GeoJSONTileSource\n*/\nexport class GeoJSONTileSource extends NetworkTileSource {\n\n    constructor(source) {\n        super(source);\n\n        // Check for URL tile pattern, if not found, treat as standalone GeoJSON/TopoJSON object\n        if (!this.urlHasTilePattern(this.url)) {\n            // Check instance type from parent class\n            if (this instanceof GeoJSONTileSource) {\n                // Replace instance type\n                return new GeoJSONSource(source);\n            }\n            else {\n                // Pass back to parent class to instantiate\n                return null;\n            }\n        }\n        return this;\n    }\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        this.prepareGeoJSON(data, tile, source);\n    }\n\n    prepareGeoJSON (data, tile, source) {\n        // Apply optional data transform\n        if (typeof this.transform === 'function') {\n            data = this.transform(data, source);\n        }\n\n        source.layers = GeoJSONSource.prototype.getLayers(data);\n\n        // A \"synthetic\" tile that adjusts the tile min anchor to account for tile longitude wrapping\n        let anchor = {\n            coords: tile.coords,\n            min: Geo.metersForTile(Geo.wrapTile(tile.coords, { x: true }))\n        };\n\n        DataSource.projectData(source); // mercator projection\n        DataSource.scaleData(source, anchor); // re-scale from meters to local tile coords\n    }\n\n}\n\n\n/**\n GeoJSON standalone (non-tiled) source\n Uses geojson-vt split into tiles client-side\n*/\n\nexport class GeoJSONSource extends NetworkSource {\n\n    constructor(source) {\n        super(source);\n        this.tiled = true;\n        this.load_data = null;\n        this.tile_indexes = {}; // geojson-vt tile indices, by layer name\n        this.max_zoom = Math.max(this.max_zoom || 0, 15); // TODO: max zoom < 15 causes artifacts/no-draw at 20, investigate\n        this.pad_scale = 0; // we don't want padding on auto-tiled sources\n        this.enforce_winding = (source.enforce_winding === false) ? false : true; // default on, can be forced off\n    }\n\n    _load(dest) {\n        if (!this.load_data) {\n            this.load_data = super._load({ source_data: { layers: {} } }).then(data => {\n                let layers = data.source_data.layers;\n                for (let layer_name in layers) {\n                    this.tile_indexes[layer_name] = geojsonvt(layers[layer_name], {\n                        maxZoom: this.max_zoom,  // max zoom to preserve detail on\n                        tolerance: 3, // simplification tolerance (higher means simpler)\n                        extent: Geo.tile_scale, // tile extent (both width and height)\n                        buffer: 0     // tile buffer on each side\n                    });\n                }\n\n                this.loaded = true;\n                return data;\n            });\n        }\n\n        return this.load_data.then(() => {\n            for (let layer_name in this.tile_indexes) {\n                dest.source_data.layers[layer_name] = this.getTileFeatures(dest, layer_name);\n            }\n            return dest;\n        });\n    }\n\n    getTileFeatures(tile, layer_name) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n\n        // request a particular tile\n        let t = this.tile_indexes[layer_name].getTile(coords.z, coords.x, coords.y);\n\n        // Convert from MVT-style JSON struct to GeoJSON\n        let collection;\n        if (t && t.features) {\n            collection = {\n                type: 'FeatureCollection',\n                features: []\n            };\n\n            for (let feature of t.features) {\n\n                // Copy geometry (don't want to modify internal geojson-vt data)\n                let geom = feature.geometry.map(ring =>\n                    ring.map(coord => [coord[0], coord[1]])\n                );\n\n                let type;\n                if (feature.type === 1) {\n                    type = 'MultiPoint';\n                }\n                else if (feature.type === 2) {\n                    type = 'MultiLineString';\n                }\n                else if (feature.type === 3) {\n                    type = 'MultiPolygon';\n                    geom = this.decodeMultiPolygon(geom); // un-flatten rings\n                }\n                else {\n                    continue;\n                }\n\n                let f = {\n                    type: 'Feature',\n                    geometry: {\n                        type,\n                        coordinates: geom\n                    },\n                    properties: feature.tags\n                };\n\n                collection.features.push(f);\n            }\n        }\n\n        return collection;\n    }\n\n    // Decode multipolygons, which are encoded as a single set of rings\n    // Outer rings are wound CCW, inner are CW\n    // A CCW ring indicates the start of a new polygon\n    decodeMultiPolygon (geom) {\n        let polys = [];\n        let poly = [];\n        for (let ring of geom) {\n            let winding = Geo.ringWinding(ring);\n            if (winding === 'CCW' && poly.length > 0) {\n                polys.push(poly);\n                poly = [];\n            }\n            poly.push(ring);\n        }\n        if (poly.length > 0) {\n            polys.push(poly);\n        }\n        return polys;\n    }\n\n    formatUrl (dest) {\n        return this.url;\n    }\n\n    parseSourceData (tile, source, response) {\n        source.layers = this.getLayers(JSON.parse(response));\n    }\n\n    // Detect single or multiple layers in returned data\n    getLayers (data) {\n        if (data.type === 'Feature' || data.type === 'FeatureCollection') {\n            return { _default: data };\n        }\n        else {\n            return data;\n        }\n    }\n\n}\n\nDataSource.register(GeoJSONTileSource, 'GeoJSON');      // prefered shorter name\nDataSource.register(GeoJSONTileSource, 'GeoJSONTiles'); // for backwards-compatibility\n","import DataSource, {NetworkTileSource} from './data_source';\n\nimport Pbf from 'pbf';\nimport {VectorTile, VectorTileFeature} from 'vector-tile';\n\n/**\n Mapbox Vector Tile format\n @class MVTSource\n*/\nexport class MVTSource extends NetworkTileSource {\n\n    constructor (source) {\n        super(source);\n        this.response_type = \"arraybuffer\"; // binary data\n    }\n\n    parseSourceData (tile, source, response) {\n        // Convert Mapbox vector tile to GeoJSON\n        var data = new Uint8Array(response);\n        var buffer = new Pbf(data);\n        source.data = new VectorTile(buffer);\n        source.layers = this.toGeoJSON(source.data);\n        delete source.data; // comment out to save raw data for debugging\n    }\n\n    // Loop through layers/features using Mapbox lib API, convert to GeoJSON features\n    // Returns an object with keys for each layer, e.g. { layer: geojson }\n    toGeoJSON (tile) {\n        var layers = {};\n        for (var l in tile.layers) {\n            var layer = tile.layers[l];\n            var layer_geojson = {\n                type: 'FeatureCollection',\n                features: []\n            };\n\n            for (var f=0; f < layer.length; f++) {\n                var feature = layer.feature(f);\n                var feature_geojson = {\n                    type: 'Feature',\n                    geometry: {},\n                    properties: feature.properties\n                };\n\n                var geometry = feature_geojson.geometry;\n                var coordinates = feature.loadGeometry();\n                for (var r=0; r < coordinates.length; r++) {\n                    var ring = coordinates[r];\n                    for (var c=0; c < ring.length; c++) {\n                        ring[c] = [\n                            ring[c].x,\n                            ring[c].y\n                        ];\n                    }\n                }\n                geometry.coordinates = coordinates;\n\n                if (VectorTileFeature.types[feature.type] === 'Point') {\n                    geometry.type = 'Point';\n                    geometry.coordinates = geometry.coordinates[0][0];\n                }\n                else if (VectorTileFeature.types[feature.type] === 'LineString') {\n                    if (coordinates.length === 1) {\n                        geometry.type = 'LineString';\n                        geometry.coordinates = geometry.coordinates[0];\n                    }\n                    else {\n                        geometry.type = 'MultiLineString';\n                    }\n                }\n                else if (VectorTileFeature.types[feature.type] === 'Polygon') {\n                    geometry.type = 'Polygon';\n                }\n\n                layer_geojson.features.push(feature_geojson);\n            }\n            layers[l] = layer_geojson;\n        }\n        return layers;\n    }\n\n}\n\nDataSource.register(MVTSource, 'MVT');\n","import DataSource from './data_source';\nimport {GeoJSONSource, GeoJSONTileSource} from './geojson';\n\nimport topojson from 'topojson';\n\n\n/**\n Mapzen/OSM.US-style TopoJSON vector tiles\n @class TopoJSONTileSource\n*/\nexport class TopoJSONTileSource extends GeoJSONTileSource {\n\n    constructor(source) {\n        let _this = super(source);\n\n        // Replace with non-tiled source if tiled source failed to instantiate\n        if (_this !== this) {\n            return new TopoJSONSource(source);\n        }\n    }\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        data = TopoJSONSource.prototype.toGeoJSON(data);\n        this.prepareGeoJSON(data, tile, source);\n    }\n\n}\n\n\n/**\n TopoJSON standalone (non-tiled) source\n Uses geojson-vt split into tiles client-side\n*/\n\nexport class TopoJSONSource extends GeoJSONSource {\n\n    parseSourceData (tile, source, response) {\n        let data = JSON.parse(response);\n        data = this.toGeoJSON(data);\n        source.layers = this.getLayers(data);\n    }\n\n    toGeoJSON (data) {\n        // Single layer\n        if (data.objects &&\n            Object.keys(data.objects).length === 1) {\n            let layer = Object.keys(data.objects)[0];\n            data = topojson.feature(data, data.objects[layer]);\n        }\n        // Multiple layers\n        else {\n            let layers = {};\n            for (let key in data.objects) {\n                layers[key] = topojson.feature(data, data.objects[key]);\n            }\n            data = layers;\n        }\n        return data;\n    }\n\n}\n\nDataSource.register(TopoJSONTileSource, 'TopoJSON');        // prefered shorter name\nDataSource.register(TopoJSONTileSource, 'TopoJSONTiles');   // for backwards-compatibility\n\n","// Geometry building functions\n\nimport Vector from '../vector';\nimport Geo from '../geo';\n\nimport earcut from 'earcut';\n\nvar Builders;\nexport default Builders = {};\n\nBuilders.debug = false;\n\nBuilders.tile_bounds = [\n    { x: 0, y: 0},\n    { x: Geo.tile_scale, y: -Geo.tile_scale } // TODO: correct for flipped y-axis?\n];\n\n// Re-scale UVs from [0, 1] range to a smaller area within the image\nBuilders.scaleTexcoordsToSprite = function (uv, area_origin, area_size, tex_size) {\n    var area_origin_y = tex_size[1] - area_origin[1] - area_size[1];\n    var suv = [];\n    suv[0] = (uv[0] * area_size[0] + area_origin[0]) / tex_size[0];\n    suv[1] = (uv[1] * area_size[1] + area_origin_y) / tex_size[1];\n    return suv;\n};\n\nBuilders.getTexcoordsForSprite = function (area_origin, area_size, tex_size) {\n    return [\n        Builders.scaleTexcoordsToSprite([0, 0], area_origin, area_size, tex_size),\n        Builders.scaleTexcoordsToSprite([1, 1], area_origin, area_size, tex_size)\n    ];\n};\n\n// Tesselate a flat 2D polygon\n// x & y coordinates will be set as first two elements of provided vertex_template\nBuilders.buildPolygons = function (\n    polygons,\n    vertex_data, vertex_template,\n    { texcoord_index, texcoord_scale, texcoord_normalize }) {\n\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n    }\n\n    var num_polygons = polygons.length;\n    for (var p=0; p < num_polygons; p++) {\n        var polygon = polygons[p];\n\n        // Find polygon extents to calculate UVs, fit them to the axis-aligned bounding box\n        if (texcoord_index) {\n            var [min_x, min_y, max_x, max_y] = Geo.findBoundingBox(polygon);\n            var span_x = max_x - min_x;\n            var span_y = max_y - min_y;\n            var scale_u = (max_u - min_u) / span_x;\n            var scale_v = (max_v - min_v) / span_y;\n        }\n\n        // Tessellate\n        var vertices = Builders.triangulatePolygon(polygon);\n\n        // Add vertex data\n        var num_vertices = vertices.length;\n        for (var v=0; v < num_vertices; v++) {\n            var vertex = vertices[v];\n            vertex_template[0] = vertex[0];\n            vertex_template[1] = vertex[1];\n\n            // Add UVs\n            if (texcoord_index) {\n                vertex_template[texcoord_index + 0] = ((vertex[0] - min_x) * scale_u + min_u) * texcoord_normalize;\n                vertex_template[texcoord_index + 1] = ((vertex[1] - min_y) * scale_v + min_v) * texcoord_normalize;\n            }\n\n            vertex_data.addVertex(vertex_template);\n        }\n    }\n};\n\n// Tesselate and extrude a flat 2D polygon into a simple 3D model with fixed height and add to GL vertex buffer\nBuilders.buildExtrudedPolygons = function (\n    polygons,\n    z, height, min_height,\n    vertex_data, vertex_template,\n    normal_index,\n    normal_normalize,\n    { texcoord_index, texcoord_scale, texcoord_normalize }) {\n\n    // Top\n    var min_z = z + (min_height || 0);\n    var max_z = z + height;\n    vertex_template[2] = max_z;\n    Builders.buildPolygons(polygons, vertex_data, vertex_template, { texcoord_index, texcoord_scale, texcoord_normalize });\n\n    // Walls\n    // Fit UVs to wall quad\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n        var texcoords = [\n            [min_u, max_v],\n            [min_u, min_v],\n            [max_u, min_v],\n\n            [max_u, min_v],\n            [max_u, max_v],\n            [min_u, max_v]\n        ];\n    }\n\n    var num_polygons = polygons.length;\n    for (var p=0; p < num_polygons; p++) {\n        var polygon = polygons[p];\n\n        for (var q=0; q < polygon.length; q++) {\n            var contour = polygon[q];\n\n            for (var w=0; w < contour.length - 1; w++) {\n                // Two triangles for the quad formed by each vertex pair, going from bottom to top height\n                var wall_vertices = [\n                    // Triangle\n                    [contour[w+1][0], contour[w+1][1], max_z],\n                    [contour[w+1][0], contour[w+1][1], min_z],\n                    [contour[w][0], contour[w][1], min_z],\n                    // Triangle\n                    [contour[w][0], contour[w][1], min_z],\n                    [contour[w][0], contour[w][1], max_z],\n                    [contour[w+1][0], contour[w+1][1], max_z]\n                ];\n\n                // Calc the normal of the wall from up vector and one segment of the wall triangles\n                var normal = Vector.cross(\n                    [0, 0, 1],\n                    Vector.normalize([contour[w+1][0] - contour[w][0], contour[w+1][1] - contour[w][1], 0])\n                );\n\n                // Update vertex template with current surface normal\n                vertex_template[normal_index + 0] = normal[0] * normal_normalize;\n                vertex_template[normal_index + 1] = normal[1] * normal_normalize;\n                vertex_template[normal_index + 2] = normal[2] * normal_normalize;\n\n                for (var wv=0; wv < wall_vertices.length; wv++) {\n                    vertex_template[0] = wall_vertices[wv][0];\n                    vertex_template[1] = wall_vertices[wv][1];\n                    vertex_template[2] = wall_vertices[wv][2];\n\n                    if (texcoord_index) {\n                        vertex_template[texcoord_index + 0] = texcoords[wv][0] * texcoord_normalize;\n                        vertex_template[texcoord_index + 1] = texcoords[wv][1] * texcoord_normalize;\n                    }\n\n                    vertex_data.addVertex(vertex_template);\n                }\n            }\n        }\n    }\n};\n\n// Build tessellated triangles for a polyline\nBuilders.buildPolylines = function (\n    lines,\n    width,\n    vertex_data, vertex_template,\n    {\n        closed_polygon,\n        remove_tile_edges,\n        tile_edge_tolerance,\n        texcoord_index,\n        texcoord_scale,\n        texcoord_normalize,\n        scaling_index,\n        scaling_normalize,\n        join, cap\n    }) {\n\n    var cornersOnCap = (cap === \"square\") ? 2 : ((cap === \"round\") ? 3 : 0);  // Butt is the implicit default\n    var trianglesOnJoin = (join === \"bevel\") ? 1 : ((join === \"round\") ? 3 : 0);  // Miter is the implicit default\n\n    // Build variables\n    texcoord_normalize = texcoord_normalize || 1;\n    var [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n\n    // Values that are constant for each line and are passed to helper functions\n    var constants = {\n        vertex_data,\n        vertex_template,\n        halfWidth: width/2,\n        vertices: [],\n        scaling_index,\n        scaling_normalize,\n        scalingVecs: scaling_index && [],\n        texcoord_index,\n        texcoords: texcoord_index && [],\n        texcoord_normalize,\n        min_u, min_v, max_u, max_v,\n        nPairs: 0\n    };\n\n    for (var ln = 0; ln < lines.length; ln++) {\n        var line = lines[ln];\n        var lineSize = line.length;\n\n        // Ignore non-lines\n        if (lineSize < 2) {\n            continue;\n        }\n\n        //  Initialize variables\n        var coordPrev = [0, 0], // Previous point coordinates\n            coordCurr = [0, 0], // Current point coordinates\n            coordNext = [0, 0]; // Next point coordinates\n\n        var normPrev = [0, 0],  // Right normal to segment between previous and current m_points\n            normCurr = [0, 0],  // Right normal at current point, scaled for miter joint\n            normNext = [0, 0];  // Right normal to segment between current and next m_points\n\n        var isPrev = false,\n            isNext = true;\n\n        // Add vertices to buffer according to their index\n        indexPairs(constants);\n\n        // Do this with the rest (except the last one)\n        for (let i = 0; i < lineSize ; i++) {\n\n            // There is a next one?\n            isNext = i+1 < lineSize;\n\n            if (isPrev) {\n                // If there is a previous one, copy the current (previous) values on *Prev\n                coordPrev = coordCurr;\n                normPrev = Vector.normalize(Vector.perp(coordPrev, line[i]));\n            } else if (i === 0 && closed_polygon === true) {\n                // If it's the first point and is a closed polygon\n\n                var needToClose = true;\n                if (remove_tile_edges) {\n                    if(Builders.isOnTileEdge(line[i], line[lineSize-2], { tolerance: tile_edge_tolerance })) {\n                        needToClose = false;\n                    }\n                }\n\n                if (needToClose) {\n                    coordPrev = line[lineSize-2];\n                    normPrev = Vector.normalize(Vector.perp(coordPrev, line[i]));\n                    isPrev = true;\n                }\n            }\n\n            // Assign current coordinate\n            coordCurr = line[i];\n\n            if (isNext) {\n                coordNext = line[i+1];\n            } else if (closed_polygon === true) {\n                // If it's the last point in a closed polygon\n                coordNext = line[1];\n                isNext = true;\n            }\n\n            if (isNext) {\n                // If it's not the last one get next coordinates and calculate the right normal\n\n                normNext = Vector.normalize(Vector.perp(coordCurr, coordNext));\n                if (remove_tile_edges) {\n                    if (Builders.isOnTileEdge(coordCurr, coordNext, { tolerance: tile_edge_tolerance })) {\n                        normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                        if (isPrev) {\n                            addVertexPair(coordCurr, normCurr, i/lineSize, constants);\n                            constants.nPairs++;\n\n                            // Add vertices to buffer acording their index\n                            indexPairs(constants);\n                        }\n                        isPrev = false;\n                        continue;\n                    }\n                }\n            }\n\n            //  Compute current normal\n            if (isPrev) {\n                //  If there is a PREVIOUS ...\n                if (isNext) {\n                    // ... and a NEXT ONE, compute previous and next normals (scaled by the angle with the last prev)\n                    normCurr = Vector.normalize(Vector.add(normPrev, normNext));\n                    var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n                    normCurr = Vector.mult(normCurr,scale*scale);\n                } else {\n                    // ... and there is NOT a NEXT ONE, copy the previous next one (which is the current one)\n                    normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                }\n            } else {\n                // If there is NO PREVIOUS ...\n                if (isNext) {\n                    // ... and a NEXT ONE,\n                    normNext = Vector.normalize(Vector.perp(coordCurr, coordNext));\n                    normCurr = normNext;\n                } else {\n                    // ... and NO NEXT ONE, nothing to do (without prev or next one this is just a point)\n                    continue;\n                }\n            }\n\n            if (isPrev || isNext) {\n                // If it's the BEGINNING of a LINE\n                if (i === 0 && !isPrev && !closed_polygon) {\n                    addCap(coordCurr, normCurr, cornersOnCap, true, constants);\n                }\n\n                // If it's a JOIN\n                if(trianglesOnJoin !== 0 && isPrev && isNext) {\n                    addJoin([coordPrev, coordCurr, coordNext],\n                            [normPrev,normCurr, normNext],\n                            i/lineSize, trianglesOnJoin,\n                            constants);\n                } else {\n                    addVertexPair(coordCurr, normCurr, i/(lineSize-1), constants);\n                }\n\n                if (isNext) {\n                   constants.nPairs++;\n                }\n\n                isPrev = true;\n            }\n        }\n\n        // Add vertices to buffer according to their index\n        indexPairs(constants);\n\n         // If it's the END of a LINE\n        if(!closed_polygon) {\n            addCap(coordCurr, normCurr, cornersOnCap , false, constants);\n        }\n    }\n};\n\n// Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertex(coord, normal, uv, { halfWidth, vertices, scalingVecs, texcoords }) {\n    if (scalingVecs) {\n        //  a. If scaling is on add the vertex (the currCoord) and the scaling Vecs (normals pointing where to extrude the vertices)\n        vertices.push(coord);\n        scalingVecs.push(normal);\n    } else {\n        //  b. Add the extruded vertices\n        vertices.push([coord[0] + normal[0] * halfWidth,\n                       coord[1] + normal[1] * halfWidth]);\n    }\n\n    // c) Add UVs if they are enabled\n    if (texcoords) {\n        texcoords.push(uv);\n    }\n}\n\n//  Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertexPair (coord, normal, v_pct, constants) {\n    addVertex(coord, normal, [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v], constants);\n    addVertex(coord, Vector.neg(normal), [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v], constants);\n}\n\n//  Tessalate a FAN geometry between points A       B\n//  using their normals from a center        \\ . . /\n//  and interpolating their UVs               \\ p /\n//                                             \\./\n//                                              C\nfunction addFan (coord, nA, nC, nB, uA, uC, uB, signed, numTriangles, constants) {\n\n    if (numTriangles < 1) {\n        return;\n    }\n\n    // Add previous vertices to buffer and clear the buffers and index pairs\n    // because we are going to add more triangles.\n    indexPairs(constants);\n\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n\n    var angle_delta = Vector.dot(nA, nB);\n    if (angle_delta < -1) {\n        angle_delta = -1;\n    }\n    angle_delta = Math.acos(angle_delta)/numTriangles;\n\n    if (!signed) {\n        angle_delta *= -1;\n    }\n\n    var uvCurr = Vector.set(uA);\n    var uv_delta = Vector.div(Vector.sub(uB,uA), numTriangles);\n\n    //  Add the FIRST and CENTER vertex\n    //  The triangles will be composed in a FAN style around it\n    addVertex(coord, nC, uC, constants);\n\n    //  Add first corner\n    addVertex(coord, normCurr, uA, constants);\n\n    // Iterate through the rest of the corners\n    for (var t = 0; t < numTriangles; t++) {\n        normPrev = Vector.normalize(normCurr);\n        normCurr = Vector.rot( Vector.normalize(normCurr), angle_delta);     //  Rotate the extrusion normal\n\n        if (numTriangles === 4 && (t === 0 || t === numTriangles - 2)) {\n            var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n            normCurr = Vector.mult(normCurr, scale*scale);\n        }\n\n        uvCurr = Vector.add(uvCurr,uv_delta);\n\n        addVertex(coord, normCurr, uvCurr, constants);      //  Add computed corner\n    }\n\n    for (var i = 0; i < numTriangles; i++) {\n        if (signed) {\n            addIndex(i+2, constants);\n            addIndex(0, constants);\n            addIndex(i+1, constants);\n        } else {\n            addIndex(i+1, constants);\n            addIndex(0, constants);\n            addIndex(i+2, constants);\n        }\n    }\n\n    // Clear the buffer\n    constants.vertices = [];\n    if (constants.scalingVecs) {\n        constants.scalingVecs = [];\n    }\n    if (constants.texcoords) {\n        constants.texcoords = [];\n    }\n}\n\n//  Add special joins (not miter) types that require FAN tessellations\n//  Using http://www.codeproject.com/Articles/226569/Drawing-polylines-by-tessellation as reference\nfunction addJoin (coords, normals, v_pct, nTriangles, constants) {\n\n    var T = [Vector.set(normals[0]), Vector.set(normals[1]), Vector.set(normals[2])];\n    var signed = Vector.signed_area(coords[0], coords[1], coords[2]) > 0;\n\n    var nA = T[0],              // normal to point A (aT)\n        nC = Vector.neg(T[1]),  // normal to center (-vP)\n        nB = T[2];              // normal to point B (bT)\n\n    var uA = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v],\n        uC = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v],\n        uB = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n\n    if (signed) {\n        addVertex(coords[1], nA, uA, constants);\n        addVertex(coords[1], nC, uC, constants);\n    } else {\n        nA = Vector.neg(T[0]);\n        nC = T[1];\n        nB = Vector.neg(T[2]);\n        uA = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        uC = [constants.max_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        uB = [constants.min_u, (1-v_pct)*constants.min_v + v_pct*constants.max_v];\n        addVertex(coords[1], nC, uC, constants);\n        addVertex(coords[1], nA, uA, constants);\n    }\n\n    addFan(coords[1], nA, nC, nB, uA, uC, uB, signed, nTriangles, constants);\n\n    if (signed) {\n        addVertex(coords[1], nB, uB, constants);\n        addVertex(coords[1], nC, uC, constants);\n    } else {\n        addVertex(coords[1], nC, uC, constants);\n        addVertex(coords[1], nB, uB, constants);\n    }\n}\n\n//  Function to add the vertex need for line caps,\n//  because re-use the buffers needs to be at the end\nfunction addCap (coord, normal, numCorners, isBeginning, constants) {\n\n    if (numCorners < 1) {\n        return;\n    }\n\n    // UVs\n    var uvA = [constants.min_u,constants.min_v],                        // Beginning angle UVs\n        uvC = [constants.min_u+(constants.max_u-constants.min_u)/2, constants.min_v],   // center point UVs\n        uvB = [constants.max_u,constants.min_v];                        // Ending angle UVs\n\n    if (!isBeginning) {\n        uvA = [constants.min_u,constants.max_v],                        // Begining angle UVs\n        uvC = [constants.min_u+(constants.max_u-constants.min_u)/2, constants.max_v],   // center point UVs\n        uvB = [constants.max_u,constants.max_v];\n    }\n\n    addFan( coord,\n            Vector.neg(normal), [0, 0], normal,\n            uvA, uvC, uvB,\n            isBeginning, numCorners*2, constants);\n}\n\n// Add a vertex based on the index position into the VBO (internal method for polyline builder)\nfunction addIndex (index, { vertex_data, vertex_template, halfWidth, vertices, scaling_index, scaling_normalize, scalingVecs, texcoord_index, texcoords, texcoord_normalize }) {\n    // Prevent access to undefined vertices\n    if (index >= vertices.length) {\n        return;\n    }\n\n    // set vertex position\n    vertex_template[0] = vertices[index][0];\n    vertex_template[1] = vertices[index][1];\n\n    // set UVs\n    if (texcoord_index) {\n        vertex_template[texcoord_index + 0] = texcoords[index][0] * texcoord_normalize;\n        vertex_template[texcoord_index + 1] = texcoords[index][1] * texcoord_normalize;\n    }\n\n    // set Scaling vertex (X, Y normal direction + Z halfwidth as attribute)\n    if (scaling_index) {\n        vertex_template[scaling_index + 0] = scalingVecs[index][0] * scaling_normalize;\n        vertex_template[scaling_index + 1] = scalingVecs[index][1] * scaling_normalize;\n        vertex_template[scaling_index + 2] = halfWidth;\n    }\n\n    //  Add vertex to VBO\n    vertex_data.addVertex(vertex_template);\n}\n\n// Add the index vertex to the VBO and clean the buffers\nfunction indexPairs (constants) {\n    // Add vertices to buffer acording their index\n    for (var i = 0; i < constants.nPairs; i++) {\n        addIndex(2*i+2, constants);\n        addIndex(2*i+1, constants);\n        addIndex(2*i+0, constants);\n\n        addIndex(2*i+2, constants);\n        addIndex(2*i+3, constants);\n        addIndex(2*i+1, constants);\n    }\n\n    constants.nPairs = 0;\n\n    // Clean the buffer\n    constants.vertices = [];\n    if (constants.scalingVecs) {\n        constants.scalingVecs = [];\n    }\n    if (constants.texcoords) {\n        constants.texcoords = [];\n    }\n}\n\n// Build a billboard sprite quad centered on a point. Sprites are intended to be drawn in screenspace, and have\n// properties for width, height, angle, and a scale factor that can be used to interpolate the screenspace size\n// of a sprite between two zoom levels.\nBuilders.buildQuadsForPoints = function (points, vertex_data, vertex_template,\n    { texcoord_index, position_index, shape_index, offset_index },\n    { quad, quad_scale, offset, angle, texcoord_scale, texcoord_normalize }) {\n    let w2 = quad[0] / 2;\n    let h2 = quad[1] / 2;\n    let scaling = [\n        [-w2, -h2],\n        [w2, -h2],\n        [w2, h2],\n\n        [-w2, -h2],\n        [w2, h2],\n        [-w2, h2]\n    ];\n\n    let texcoords;\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n\n        let [[min_u, min_v], [max_u, max_v]] = texcoord_scale || [[0, 0], [1, 1]];\n        texcoords = [\n            [min_u, min_v],\n            [max_u, min_v],\n            [max_u, max_v],\n\n            [min_u, min_v],\n            [max_u, max_v],\n            [min_u, max_v]\n        ];\n    }\n\n    let num_points = points.length;\n    for (let p=0; p < num_points; p++) {\n        let point = points[p];\n\n        for (let pos=0; pos < 6; pos++) {\n            // Add texcoords\n            if (texcoord_index) {\n                vertex_template[texcoord_index + 0] = texcoords[pos][0] * texcoord_normalize;\n                vertex_template[texcoord_index + 1] = texcoords[pos][1] * texcoord_normalize;\n            }\n\n            vertex_template[position_index + 0] = point[0];\n            vertex_template[position_index + 1] = point[1];\n\n            vertex_template[shape_index + 0] = scaling[pos][0];\n            vertex_template[shape_index + 1] = scaling[pos][1];\n            vertex_template[shape_index + 2] = angle;\n            vertex_template[shape_index + 3] = quad_scale;\n\n            vertex_template[offset_index + 0] = offset[0];\n            vertex_template[offset_index + 1] = offset[1];\n\n            vertex_data.addVertex(vertex_template);\n        }\n    }\n};\n\n\n/* Utility functions */\n\n// Triangulation using earcut\n// https://github.com/mapbox/earcut\nBuilders.triangulatePolygon = function (contours)\n{\n    return earcut(contours);\n};\n\n// Tests if a line segment (from point A to B) is nearly coincident with the edge of a tile\nBuilders.isOnTileEdge = function (pa, pb, options) {\n    options = options || {};\n\n    var tolerance_function = options.tolerance_function || Builders.valuesWithinTolerance;\n    var tolerance = options.tolerance || 1;\n    var tile_min = Builders.tile_bounds[0];\n    var tile_max = Builders.tile_bounds[1];\n    var edge = null;\n\n    if (tolerance_function(pa[0], tile_min.x, tolerance) && tolerance_function(pb[0], tile_min.x, tolerance)) {\n        edge = 'left';\n    }\n    else if (tolerance_function(pa[0], tile_max.x, tolerance) && tolerance_function(pb[0], tile_max.x, tolerance)) {\n        edge = 'right';\n    }\n    else if (tolerance_function(pa[1], tile_min.y, tolerance) && tolerance_function(pb[1], tile_min.y, tolerance)) {\n        edge = 'top';\n    }\n    else if (tolerance_function(pa[1], tile_max.y, tolerance) && tolerance_function(pb[1], tile_max.y, tolerance)) {\n        edge = 'bottom';\n    }\n    return edge;\n};\n\nBuilders.valuesWithinTolerance = function (a, b, tolerance) {\n    tolerance = tolerance || 1;\n    return (Math.abs(a - b) < tolerance);\n};\n","// Line rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport {StyleManager} from '../style_manager';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\n\nexport var Lines = Object.create(Style);\n\nObject.assign(Lines, {\n    name: 'lines',\n    built_in: true,\n    vertex_shader_key: 'styles/polygons/polygons_vertex', // re-use polygon shaders\n    fragment_shader_key: 'styles/polygons/polygons_fragment',\n    selection: true, // turn feature selection on\n\n    init() {\n        Style.init.apply(this, arguments);\n\n        // Basic attributes, others can be added (see texture UVs below)\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_extrude', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Tell the shader we want a order in vertex attributes, and to extrude lines\n        this.defines.TANGRAM_LAYER_ORDER = true;\n        this.defines.TANGRAM_EXTRUDE_LINES = true;\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // Optional texture UVs\n        if (this.texcoords) {\n            this.defines.TANGRAM_TEXTURE_COORDS = true;\n\n            // Add vertex attribute for UVs only when needed\n            attribs.push({ name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true });\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        let inner_width = rule_style.width && StyleParser.cacheDistance(rule_style.width, context);\n        if (!inner_width) {\n            return;\n        }\n        style.width = inner_width * context.units_per_meter;\n\n        // Smoothly interpolate line width between zooms: get scale factor to next zoom\n        // Adjust by factor of 2 because tile units are zoom-dependent (a given value is twice as\n        // big in world space at the next zoom than at the previous)\n        context.zoom ++;\n        context.units_per_meter *= 2;\n        let next_width = StyleParser.cacheDistance(rule_style.next_width, context);\n        style.next_width = Utils.scaleInt16(next_width * context.units_per_meter / style.width, 256);\n        context.zoom--;\n        context.units_per_meter /= 2; // reset to original scale\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return null;\n        }\n\n        // height defaults to feature height, but extrude style can dynamically adjust height by returning a number or array (instead of a boolean)\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z || 0, context)) || StyleParser.defaults.z;\n        style.height = feature.properties.height || StyleParser.defaults.height;\n        style.extrude = rule_style.extrude;\n        if (style.extrude) {\n            if (typeof style.extrude === 'function') {\n                style.extrude = style.extrude(context);\n            }\n\n            if (typeof style.extrude === 'number') {\n                style.height = style.extrude;\n            }\n            else if (Array.isArray(style.extrude)) {\n                style.height = style.extrude[1];\n            }\n        }\n\n        // Raise line height if extruded\n        if (style.extrude && style.height) {\n            style.z += style.height;\n        }\n\n        style.cap = rule_style.cap;\n        style.join = rule_style.join;\n        style.tile_edges = rule_style.tile_edges;\n\n        // Construct an outline style\n        style.outline = style.outline || {};\n        if (rule_style.outline && rule_style.outline.color && rule_style.outline.width) {\n            let outline_width = StyleParser.cacheDistance(rule_style.outline.width, context) * 2;\n\n            context.zoom ++;\n            context.units_per_meter *= 2;\n            let outline_next_width = StyleParser.cacheDistance(rule_style.outline.next_width, context) * 2;\n            context.zoom--;\n            context.units_per_meter /= 2; // reset to original scale\n\n            // Maintain consistent outline width around the inner line\n            style.outline.width = { value: outline_width + inner_width };\n            style.outline.next_width = { value: outline_next_width + next_width };\n\n            style.outline.color = rule_style.outline.color;\n            style.outline.cap = rule_style.outline.cap || rule_style.cap;\n            style.outline.join = rule_style.outline.join || rule_style.join;\n            style.outline.style = rule_style.outline.style || this.name;\n\n            // Explicitly defined outline order, or inherited from inner line\n            if (rule_style.outline.order) {\n                style.outline.order = this.parseOrder(rule_style.outline.order, context);\n            }\n            else {\n                style.outline.order = style.order;\n            }\n\n            // Don't let outline be above inner line\n            if (style.outline.order > style.order) {\n                style.outline.order = style.order;\n            }\n\n            // Outlines are always at half-layer intervals to avoid conflicting with inner lines\n            style.outline.order -= 0.5;\n\n            style.outline.preprocessed = true; // signal that we've already wrapped properties in cache objects\n        }\n        else {\n            style.outline.color = null;\n            style.outline.width = null;\n        }\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.width = draw.width && { value: draw.width };\n        draw.next_width = draw.width && { value: draw.width.value };\n        draw.z = draw.z && { value: draw.z };\n\n        if (draw.outline) {\n            draw.outline.color = draw.outline.color && { value: draw.outline.color };\n            draw.outline.width = draw.outline.width && { value: draw.outline.width };\n            draw.outline.next_width = draw.outline.width && { value: draw.outline.width.value };\n        }\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let i = 0;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = style.z || 0;\n\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.vertex_template[i++] = style.order;\n\n        // extrusion vector\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n\n        // scaling to previous and next zoom\n        this.vertex_template[i++] = style.next_width;\n\n        // color\n        this.vertex_template[i++] = style.color[0] * 255;\n        this.vertex_template[i++] = style.color[1] * 255;\n        this.vertex_template[i++] = style.color[2] * 255;\n        this.vertex_template[i++] = style.color[3] * 255;\n\n        // selection color\n        if (this.selection) {\n            this.vertex_template[i++] = style.selection_color[0] * 255;\n            this.vertex_template[i++] = style.selection_color[1] * 255;\n            this.vertex_template[i++] = style.selection_color[2] * 255;\n            this.vertex_template[i++] = style.selection_color[3] * 255;\n        }\n\n        // Add texture UVs to template only if needed\n        if (this.texcoords) {\n            this.vertex_template[i++] = 0;\n            this.vertex_template[i++] = 0;\n        }\n\n        return this.vertex_template;\n    },\n\n    buildLines(lines, style, vertex_data, context, options) {\n        var vertex_template = this.makeVertexTemplate(style);\n\n        // Main line\n        if (style.color && style.width) {\n            Builders.buildPolylines(\n                lines,\n                style.width,\n                vertex_data,\n                vertex_template,\n                {\n                    cap: style.cap,\n                    join: style.join,\n                    scaling_index: this.vertex_layout.index.a_extrude,\n                    scaling_normalize: Utils.scaleInt16(1, 256), // scale extrusion normals to signed shorts w/256 unit basis\n                    texcoord_index: this.vertex_layout.index.a_texcoord,\n                    texcoord_scale: this.texcoord_scale,\n                    texcoord_normalize: 65535, // scale UVs to unsigned shorts\n                    closed_polygon: options && options.closed_polygon,\n                    remove_tile_edges: !style.tile_edges && options && options.remove_tile_edges,\n                    tile_edge_tolerance: Geo.tile_scale * context.tile.pad_scale * 4\n                }\n            );\n        }\n\n        // Outline\n         if (style.outline && style.outline.color && style.outline.width) {\n            var outline_style = StyleManager.styles[style.outline.style];\n            if (outline_style) {\n                outline_style.addFeature(context.feature, style.outline, context);\n            }\n        }\n    },\n\n    buildPolygons(polygons, style, vertex_data, context) {\n        // Render polygons as individual lines\n        for (let p=0; p < polygons.length; p++) {\n            this.buildLines(polygons[p], style, vertex_data, context, { closed_polygon: true, remove_tile_edges: true });\n        }\n    }\n\n});\n","// Point rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\nimport Texture from '../../gl/texture';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\nimport Vector from '../../vector';\n\nimport log from 'loglevel';\n\nexport var Points = Object.create(Style);\n\nObject.assign(Points, {\n    name: 'points',\n    built_in: true,\n    selection: true, // turn feature selection on\n    blend: 'overlay', // overlays drawn on top of all other styles, with blending\n\n    init(options = {}) {\n        Style.init.apply(this, arguments);\n\n        // Base shaders\n        this.vertex_shader_key = 'styles/points/points_vertex';\n        this.fragment_shader_key = 'styles/points/points_fragment';\n\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_shape', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true },\n            { name: 'a_offset', size: 2, type: gl.SHORT, normalized: true },\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // If we're not rendering as overlay, we need a layer attribute\n        if (this.blend !== 'overlay') {\n            this.defines.TANGRAM_LAYER_ORDER = true;\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n\n        if (this.texture) {\n            this.defines.TANGRAM_POINT_TEXTURE = true;\n            this.shaders.uniforms = this.shaders.uniforms || {};\n            this.shaders.uniforms.u_texture = this.texture;\n        }\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n        let tile = context.tile.key;\n\n        style.color = this.parseColor(rule_style.color, context);\n\n        // require color or texture\n        if (!style.color && !this.texture) {\n            return null;\n        }\n\n        let sprite = style.sprite = rule_style.sprite;\n        if (typeof sprite === 'function') {\n            sprite = sprite(context);\n        }\n        style.sprite_default = rule_style.sprite_default; // optional fallback if 'sprite' not found\n\n        // if point has texture and sprites, require a valid sprite to draw\n        if (this.texture && Texture.textures[this.texture] && Texture.textures[this.texture].sprites) {\n            if (!sprite && !style.sprite_default) {\n                return;\n            }\n            else if (!Texture.textures[this.texture].sprites[sprite]) {\n                // If sprite not found, check for default sprite\n                if (style.sprite_default) {\n                    sprite = style.sprite_default;\n                    if (!Texture.textures[this.texture].sprites[sprite]) {\n                        log.warn(`Style: in style '${this.name}', could not find default sprite '${sprite}' for texture '${this.texture}'`);\n                        return;\n                    }\n                }\n                else {\n                    log.warn(`Style: in style '${this.name}', could not find sprite '${sprite}' for texture '${this.texture}'`);\n                    return;\n                }\n            }\n        }\n\n        // points can be placed off the ground\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n\n        // point style only supports sizes in pixel units, so unit conversion flag is off\n        style.size = rule_style.size || { value: [32, 32] };\n        style.size = StyleParser.cacheDistance(style.size, context, 'pixels');\n\n        // scale size to 16-bit signed int, with a max allowed width + height of 128 pixels\n        style.size = [\n            Math.min((style.size[0] || style.size), 256),\n            Math.min((style.size[1] || style.size), 256)\n        ];\n\n        style.size[0] *= Utils.device_pixel_ratio;\n        style.size[1] *= Utils.device_pixel_ratio;\n\n        style.angle = rule_style.angle || 0;\n        if (typeof style.angle === 'function') {\n            style.angle = style.angle(context);\n        }\n\n        // factor by which point scales from current zoom level to next zoom level\n        style.scale = rule_style.scale || 1;\n\n        // to store bbox by tiles\n        style.tile = tile;\n\n        // polygons rendering as points will render each individual polygon point by default, but\n        // rendering a single point at the polygon's centroid can be enabled\n        style.centroid = rule_style.centroid;\n\n        // Sets texcoord scale if needed (e.g. for sprite sub-area)\n        if (this.texture && sprite) {\n            this.texcoord_scale = Texture.getSpriteTexcoords(this.texture, sprite);\n        } else {\n            this.texcoord_scale = null;\n        }\n\n        // Offset applied to point in screen space\n        style.offset = rule_style.offset || [0, 0];\n        style.offset[0] = parseInt(style.offset[0]);\n        style.offset[1] = parseInt(style.offset[1]);\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.z = draw.z && { value: draw.z };\n        draw.size = draw.size && { value: draw.size };\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let color = style.color || StyleParser.defaults.color;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.fillVertexTemplate('a_position', 0, { size: 2 });\n        this.fillVertexTemplate('a_position', style.z || 0, { size: 1, offset: 2 });\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.fillVertexTemplate('a_position', style.order || 0, { size: 1, offset: 3 });\n\n        // scaling vector - (x, y) components per pixel, z = angle, w = scaling factor\n        this.fillVertexTemplate('a_shape', 0, { size: 4 });\n\n        // texture coords\n        this.fillVertexTemplate('a_texcoord', 0, { size: 2 });\n\n        // offsets\n        this.fillVertexTemplate('a_offset', 0, { size: 2 });\n\n        // color\n        this.fillVertexTemplate('a_color', Vector.mult(color, 255), { size: 4 });\n\n        // selection color\n        if (this.selection) {\n            this.fillVertexTemplate('a_selection_color', Vector.mult(style.selection_color, 255), { size: 4 });\n        }\n\n        return this.vertex_template;\n    },\n\n    buildQuad (points, size, angle, vertex_data, vertex_template, offset) {\n        Builders.buildQuadsForPoints(\n            points,\n            vertex_data,\n            vertex_template,\n            {\n                texcoord_index: this.vertex_layout.index.a_texcoord,\n                position_index: this.vertex_layout.index.a_position,\n                shape_index: this.vertex_layout.index.a_shape,\n                offset_index: this.vertex_layout.index.a_offset\n            },\n            {\n                quad: [ Utils.scaleInt16(size[0], 256), Utils.scaleInt16(size[1], 256) ],\n                quad_scale: Utils.scaleInt16(1, 256),\n                offset: Vector.mult(offset, Utils.device_pixel_ratio),\n                angle: Utils.scaleInt16(angle, 360),\n                texcoord_scale: this.texcoord_scale,\n                texcoord_normalize: 65535\n            }\n        );\n    },\n\n    buildPoints (points, style, vertex_data) {\n        if (!style.size) {\n            return;\n        }\n\n        this.buildQuad(points, style.size, style.angle, vertex_data, this.makeVertexTemplate(style), style.offset);\n    },\n\n    buildPolygons(polygons, style, vertex_data) {\n        // Render polygons as individual points, or centroid\n        if (!style.centroid) {\n            for (let poly=0; poly < polygons.length; poly++) {\n                let polygon = polygons[poly];\n                for (let r=0; r < polygon.length; r++) {\n                    this.buildPoints(polygon[r], style, vertex_data);\n                }\n            }\n        }\n        else {\n            let centroid = Geo.multiCentroid(polygons);\n            this.buildPoints([centroid], style, vertex_data);\n        }\n    },\n\n    buildLines(lines, style, vertex_data) {\n        // Render lines as individual points\n        for (let ln=0; ln < lines.length; ln++) {\n            this.buildPoints(lines[ln], style, vertex_data);\n        }\n    }\n\n});\n","// Polygon rendering style\n\nimport {Style} from '../style';\nimport {StyleParser} from '../style_parser';\nimport gl from '../../gl/constants'; // web workers don't have access to GL context, so import all GL constants\nimport VertexLayout from '../../gl/vertex_layout';\nimport Builders from '../builders';\n\nexport var Polygons = Object.create(Style);\n\nObject.assign(Polygons, {\n    name: 'polygons',\n    built_in: true,\n    vertex_shader_key: 'styles/polygons/polygons_vertex',\n    fragment_shader_key: 'styles/polygons/polygons_fragment',\n    selection: true, // turn feature selection on\n\n    init() {\n        Style.init.apply(this, arguments);\n\n        // Basic attributes, others can be added (see texture UVs below)\n        var attribs = [\n            { name: 'a_position', size: 4, type: gl.SHORT, normalized: true },\n            { name: 'a_normal', size: 3, type: gl.BYTE, normalized: true }, // gets padded to 4-bytes\n            { name: 'a_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true }\n        ];\n\n        // Tell the shader we have a normal and order attributes\n        this.defines.TANGRAM_NORMAL_ATTRIBUTE = true;\n        this.defines.TANGRAM_LAYER_ORDER = true;\n\n        // Optional feature selection\n        if (this.selection) {\n            attribs.push({ name: 'a_selection_color', size: 4, type: gl.UNSIGNED_BYTE, normalized: true });\n        }\n\n        // Optional texture UVs\n        if (this.texcoords) {\n            this.defines.TANGRAM_TEXTURE_COORDS = true;\n\n            // Add vertex attribute for UVs only when needed\n            attribs.push({ name: 'a_texcoord', size: 2, type: gl.UNSIGNED_SHORT, normalized: true });\n        }\n\n        this.vertex_layout = new VertexLayout(attribs);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return null;\n        }\n\n        // height defaults to feature height, but extrude style can dynamically adjust height by returning a number or array (instead of a boolean)\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n        style.height = feature.properties.height || StyleParser.defaults.height;\n        style.min_height = feature.properties.min_height || StyleParser.defaults.min_height;\n        style.extrude = rule_style.extrude;\n        if (style.extrude) {\n            if (typeof style.extrude === 'function') {\n                style.extrude = style.extrude(context);\n            }\n\n            if (typeof style.extrude === 'number') {\n                style.height = style.extrude;\n            }\n            else if (Array.isArray(style.extrude)) {\n                style.min_height = style.extrude[0];\n                style.height = style.extrude[1];\n            }\n        }\n\n        // style.outline = style.outline || {};\n        // if (rule_style.outline) {\n        //     style.outline.color = StyleParser.parseColor(rule_style.outline.color, context);\n        //     style.outline.width = StyleParser.parseDistance(rule_style.outline.width, context);\n        //     style.outline.tile_edges = rule_style.outline.tile_edges;\n        //     style.outline.cap = rule_style.outline.cap || rule_style.cap;\n        //     style.outline.join = rule_style.outline.join || rule_style.join;\n        // }\n        // else {\n        //     style.outline.color = null;\n        //     style.outline.width = null;\n        //     style.outline.tile_edges = false;\n        // }\n\n        return style;\n    },\n\n    preprocess (draw) {\n        draw.color = draw.color && { value: draw.color };\n        draw.z = draw.z && { value: draw.z };\n    },\n\n    /**\n     * A \"template\" that sets constant attibutes for each vertex, which is then modified per vertex or per feature.\n     * A plain JS array matching the order of the vertex layout.\n     */\n    makeVertexTemplate(style) {\n        let i = 0;\n\n        // position - x & y coords will be filled in per-vertex below\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = style.z || 0;\n\n        // layer order - w coord of 'position' attribute (for packing efficiency)\n        this.vertex_template[i++] = style.order;\n\n        // normal\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 0;\n        this.vertex_template[i++] = 1 * 127;\n\n        // color\n        this.vertex_template[i++] = style.color[0] * 255;\n        this.vertex_template[i++] = style.color[1] * 255;\n        this.vertex_template[i++] = style.color[2] * 255;\n        this.vertex_template[i++] = style.color[3] * 255;\n\n        // selection color\n        if (this.selection) {\n            this.vertex_template[i++] = style.selection_color[0] * 255;\n            this.vertex_template[i++] = style.selection_color[1] * 255;\n            this.vertex_template[i++] = style.selection_color[2] * 255;\n            this.vertex_template[i++] = style.selection_color[3] * 255;\n        }\n\n        // Add texture UVs to template only if needed\n        if (this.texcoords) {\n            this.vertex_template[i++] = 0;\n            this.vertex_template[i++] = 0;\n        }\n\n        return this.vertex_template;\n    },\n\n    buildPolygons(polygons, style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let texcoords = {\n            texcoord_index: this.vertex_layout.index.a_texcoord,\n            texcoord_scale: this.texcoord_scale,\n            texcoord_normalize: 65535 // scale UVs to unsigned shorts\n        };\n\n        // Extruded polygons (e.g. 3D buildings)\n        if (style.extrude && style.height) {\n            Builders.buildExtrudedPolygons(\n                polygons,\n                style.z, style.height, style.min_height,\n                vertex_data, vertex_template,\n                this.vertex_layout.index.a_normal,\n                127, // scale normals to signed bytes\n                texcoords\n            );\n        }\n        // Regular polygons\n        else {\n            Builders.buildPolygons(\n                polygons,\n                vertex_data, vertex_template,\n                texcoords\n            );\n        }\n    }\n\n});\n","import {match} from 'match-feature';\nimport log from 'loglevel';\n\nexport const whiteList = ['filter', 'draw', 'visible', 'data', 'properties'];\n\nexport let ruleCache = {};\n\nfunction cacheKey (rules) {\n    var k = rules[0].id;\n    for (var i=1; i < rules.length; i++) {\n        k += '/' + rules[i].id;\n    }\n    return k;\n}\n\nexport function mergeTrees(matchingTrees, key, context) {\n    var draw = {},\n        draws,\n        // order = [],\n        // order_draws = [],\n        treeDepth = 0,\n        x, t;\n\n    // Visible by default\n    draw.visible = true;\n\n    // Find deepest tree\n    for (t = 0; t < matchingTrees.length; t++) {\n        if (matchingTrees[t].length > treeDepth) {\n            treeDepth = matchingTrees[t].length;\n        }\n    }\n\n    // No rules to parse\n    if (treeDepth === 0) {\n        return null;\n    }\n\n    // Iterate trees in parallel\n    for (x = 0; x < treeDepth; x++) {\n        draws = matchingTrees.map(tree => tree[x] && tree[x][key]);\n        if (draws.length === 0) {\n            continue;\n        }\n\n        // Property-specific logic\n        // for (i=0; i < draws.length; i++) {\n        //     if (!draws[i]) {\n        //         continue;\n        //     }\n\n        //     // Collect unique orders (don't add the order multiple times for the smae draw rule)\n        //     if (draws[i].order !== undefined) {\n        //         if (order_draws.indexOf(draws[i]) === -1) {\n        //             order.push(draws[i].order);\n        //             order_draws.push(draws[i]);\n        //         }\n        //     }\n        // }\n\n        // Merge remaining draw objects\n        mergeObjects(draw, ...draws);\n    }\n\n    // Short-circuit if not visible\n    if (draw.visible === false) {\n        return null;\n    }\n\n    // Sum all orders\n    // Note: temporarily commenting out, will revisit with new scene file syntax\n    // if (order.length > 0) {\n    //     // Order can be cached if it is all numeric\n    //     if (order.length === 1 && typeof order[0] === 'number') {\n    //         order = order[0];\n    //     }\n    //     else if (order.every(v => typeof v === 'number')) {\n    //         order = calculateOrder(order, context); // TODO: use StyleParser.calculateOrder\n    //     }\n    //     draw.order = order;\n    // }\n\n    return draw;\n}\n\n\nclass Rule {\n\n    constructor({name, parent, draw, visible, filter, properties}) {\n        this.id = Rule.id++;\n        this.parent = parent;\n        this.name = name;\n        this.draw = draw;\n        this.filter = filter;\n        this.visible = visible !== undefined ? visible : (this.parent && this.parent.visible);\n        this.properties = properties !== undefined ? properties : (this.parent && this.parent.properties);\n\n        // Denormalize properties to draw groups\n        if (this.draw) {\n            for (let group in this.draw) {\n                if (this.properties !== undefined) {\n                    this.draw[group].properties = this.properties;\n                }\n            }\n        }\n\n        this.buildFilter();\n        this.buildDraw();\n    }\n\n    buildDraw() {\n        this.calculatedDraw = calculateDraw(this);\n    }\n\n    buildFilter() {\n        var type = typeof this.filter;\n        if (type === 'object') {\n            this.filter = match(this.filter);\n        }\n    }\n\n    toJSON() {\n        return {\n            name: this.name,\n            draw: this.draw\n        };\n    }\n\n}\n\nRule.id = 0;\n\n\nexport class RuleLeaf extends Rule {\n    constructor({name, parent, draw, visible, filter, properties}) {\n        super({name, parent, draw, visible, filter, properties});\n    }\n\n}\n\nexport class RuleTree extends Rule {\n    constructor({name, parent, draw, visible, rules, filter, properties}) {\n        super({name, parent, draw, visible, filter, properties});\n        this.rules = rules || [];\n    }\n\n    addRule(rule) {\n        this.rules.push(rule);\n    }\n\n    buildDrawGroups(context) {\n        let rules  = [];\n        //TODO, should this function take a RuleTree\n        matchFeature(context, [this], rules);\n\n        if (rules.length > 0) {\n            let cache_key = cacheKey(rules);\n\n            // Only evaluate each rule combination once (undefined means not yet evaluated,\n            // null means evaluated with no draw object)\n            if (ruleCache[cache_key] === undefined) {\n                // Visible?\n                if (rules.some(x => x.visible === false)) {\n                    ruleCache[cache_key] = null;\n                }\n                else {\n                    // Find all the unique draw blocks for this rule tree\n                    let draw_rules = rules.map(x => x && x.calculatedDraw);\n                    let draw_keys = {};\n\n                    for (let rule of draw_rules) {\n                        if (!rule) {\n                            continue;\n                        }\n                        for (let group of rule) {\n                            for (let key in group) {\n                                draw_keys[key] = true;\n                            }\n                        }\n                    }\n\n                    // Calculate each draw group\n                    for (let draw_key in draw_keys) {\n                        ruleCache[cache_key] = ruleCache[cache_key] || {};\n                        ruleCache[cache_key][draw_key] = mergeTrees(draw_rules, draw_key, context);\n\n                        // Only save the ones that weren't null\n                        if (!ruleCache[cache_key][draw_key]) {\n                            delete ruleCache[cache_key][draw_key];\n                        }\n                        else {\n                            ruleCache[cache_key][draw_key].key = cache_key + '/' + draw_key;\n                        }\n                    }\n\n                    // No rules evaluated\n                    if (ruleCache[cache_key] && Object.keys(ruleCache[cache_key]).length === 0) {\n                        ruleCache[cache_key] = null;\n                    }\n                }\n            }\n            return ruleCache[cache_key];\n        }\n    }\n\n}\n\nfunction isWhiteListed(key) {\n    return whiteList.indexOf(key) > -1;\n}\n\nfunction isEmpty(obj) {\n    return Object.keys(obj).length === 0;\n}\n\nexport function walkUp(rule, cb) {\n\n    if (rule.parent) {\n        walkUp(rule.parent, cb);\n    }\n\n    cb(rule);\n}\n\nexport function walkDown(rule, cb) {\n\n    if (rule.rules) {\n        rule.rules.forEach((r) => {\n            walkDown(r, cb);\n        });\n    }\n\n    cb(rule);\n}\n\nexport function groupProps(obj) {\n    let whiteListed = {}, nonWhiteListed = {};\n\n    for (let key in obj) {\n        if (isWhiteListed(key)) {\n            whiteListed[key] = obj[key];\n        } else {\n            nonWhiteListed[key] = obj[key];\n        }\n    }\n    return [whiteListed, nonWhiteListed];\n}\n\nexport function calculateDraw(rule) {\n\n    let draw  = [];\n\n    if (rule.parent) {\n        let cs = rule.parent.calculatedDraw || [];\n        draw.push(...cs);\n    }\n\n    draw.push(rule.draw);\n    return draw;\n}\n\nexport function mergeObjects(newObj, ...sources) {\n\n    for (let source of sources) {\n        if (!source) {\n            continue;\n        }\n        for (let key in source) {\n            let value = source[key];\n            if (typeof value === 'object' && !Array.isArray(value)) {\n                newObj[key] = mergeObjects(newObj[key] || {}, value);\n            } else {\n                newObj[key] = value;\n            }\n        }\n\n    }\n    return newObj;\n}\n\nexport function calculateOrder(orders, context = null, defaultOrder = 0) {\n    let sum = defaultOrder;\n\n    for (let order of orders) {\n        if (typeof order === 'function') {\n            order = order(context);\n        } else {\n            order = parseFloat(order);\n        }\n\n        if (!order || isNaN(order)) {\n            continue;\n        }\n        sum += order;\n    }\n    return sum;\n}\n\n\nexport function parseRuleTree(name, rule, parent) {\n\n    let properties = {name, parent};\n    let [whiteListed, nonWhiteListed] = groupProps(rule);\n    let empty = isEmpty(nonWhiteListed);\n    let Create;\n\n    if (empty && parent != null) {\n        Create = RuleLeaf;\n    } else {\n        Create = RuleTree;\n    }\n\n    let r = new Create(Object.assign(properties, whiteListed));\n\n    if (parent) {\n        parent.addRule(r);\n    }\n\n    if (!empty) {\n        for (let key in nonWhiteListed) {\n            let property = nonWhiteListed[key];\n            if (typeof property === 'object') {\n                parseRuleTree(key, property, r);\n            } else {\n                log.warn('Rule property must be an object: ', name, rule, property);\n            }\n        }\n\n    }\n\n    return r;\n}\n\n\nexport function parseRules(rules) {\n    let ruleTrees = {};\n\n    for (let key in rules) {\n        let rule = rules[key];\n        ruleTrees[key] = parseRuleTree(key, rule);\n    }\n\n    return ruleTrees;\n}\n\n\nfunction doesMatch(filter, context) {\n    return ((typeof filter === 'function' && filter(context)) || (filter == null));\n}\n\nexport function matchFeature(context, rules, collectedRules) {\n    let matched = false;\n    let childMatched = false;\n\n    if (rules.length === 0) { return; }\n\n    for (let r=0; r < rules.length; r++) {\n        let current = rules[r];\n        context.properties = current.properties;\n\n        if (current instanceof RuleLeaf) {\n\n            if (doesMatch(current.filter, context)) {\n                matched = true;\n                collectedRules.push(current);\n            }\n\n        } else if (current instanceof RuleTree) {\n            if (doesMatch(current.filter, context)) {\n                matched = true;\n\n                childMatched = matchFeature(\n                    context,\n                    current.rules,\n                    collectedRules\n                );\n\n                if (!childMatched) {\n                    collectedRules.push(current);\n                }\n            }\n        }\n\n        context.properties = null;\n    }\n\n    return matched;\n}\n","// Rendering styles\n\nimport {StyleParser} from './style_parser';\nimport FeatureSelection from '../selection';\nimport ShaderProgram from '../gl/shader_program';\nimport VBOMesh from '../gl/vbo_mesh';\nimport Material from '../material';\nimport Light from '../light';\nimport {MethodNotImplemented} from '../utils/errors';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\n\nimport log from 'loglevel';\n\n// Base class\n\nexport var Style = {\n    init ({ generation } = {}) {\n        if (!this.isBuiltIn()) {\n            this.built_in = false; // explicitly set to false to avoid any confusion\n        }\n\n        this.generation = generation;               // scene generation id this style was created for\n        this.defines = (this.hasOwnProperty('defines') && this.defines) || {}; // #defines to be injected into the shaders\n        this.shaders = (this.hasOwnProperty('shaders') && this.shaders) || {}; // shader customization (uniforms, defines, blocks, etc.)\n        this.selection = this.selection || false;   // flag indicating if this style supports feature selection\n        this.compiling = false;                     // programs are currently compiling\n        this.compiled = false;                      // programs are finished compiling\n        this.program = null;                        // GL program reference (for main render pass)\n        this.selection_program = null;              // GL program reference for feature selection render pass\n        this.feature_style = {};                    // style for feature currently being parsed, shared to lessen GC/memory thrash\n        this.vertex_template = [];                  // shared single-vertex template, filled out by each style\n        this.tile_data = {};\n        this.feature_options = {};\n\n        // Default world coords to wrap every 100,000 meters, can turn off by setting this to 'false'\n        this.defines.TANGRAM_WORLD_POSITION_WRAP = 100000;\n\n        // Blending\n        this.blend = this.blend || 'opaque';        // default: opaque styles are drawn first, without blending\n        this.defines[`TANGRAM_BLEND_${this.blend.toUpperCase()}`] = true;\n\n        // If the style defines its own material, replace the inherited material instance\n        if (!(this.material instanceof Material)) {\n            if (!Material.isValid(this.material)) {\n                this.material = StyleParser.defaults.material;\n            }\n            this.material = new Material(this.material);\n        }\n        this.material.inject(this);\n\n        // Set lighting mode: fragment, vertex, or none (specified as 'false')\n        Light.setMode(this.lighting, this);\n\n        this.initialized = true;\n    },\n\n    destroy () {\n        if (this.program) {\n            this.program.destroy();\n            this.program = null;\n        }\n\n        if (this.selection_program) {\n            this.selection_program.destroy();\n            this.selection_program = null;\n        }\n\n        this.gl = null;\n        this.initialized = false;\n    },\n\n    reset () {\n    },\n\n    isBuiltIn () {\n        return this.hasOwnProperty('built_in') && this.built_in;\n    },\n\n    fillVertexTemplate(attribute, value, { size, offset }) {\n        offset = (offset === undefined) ? 0 : offset;\n\n        let index = this.vertex_layout.index[attribute];\n        if (index === undefined) {\n            log.warn(`Style: in style '${this.name}', no index found in vertex layout for attribute '${attribute}'`);\n            return;\n        }\n\n        for (let i = 0; i < size; ++i) {\n            let v = value.length > i ? value[i] : value;\n            this.vertex_template[index + i + offset] = v;\n        }\n    },\n\n    /*** Style parsing and geometry construction ***/\n\n    // Returns an object to hold feature data (for a tile or other object)\n    startData (tile) {\n        this.tile_data[tile] = {\n            vertex_data: null,\n            uniforms: null\n        };\n        return this.tile_data[tile];\n    },\n\n    // Finalizes an object holding feature data (for a tile or other object)\n    endData (tile) {\n        var tile_data = this.tile_data[tile];\n        if (tile_data && tile_data.vertex_data) {\n            // Only keep final byte buffer\n            tile_data.vertex_data.end();\n            tile_data.vertex_data = tile_data.vertex_data.buffer;\n        }\n        this.tile_data[tile] = null;\n        return Promise.resolve(tile_data);\n    },\n\n    // Has mesh data for a given tile?\n    hasDataForTile (tile) {\n        return this.tile_data[tile] != null;\n    },\n\n    addFeature (feature, rule, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile.key);\n        }\n\n        let style = this.parseFeature(feature, rule, context);\n\n        // Skip feature?\n        if (!style) {\n            return;\n        }\n\n        // First feature in this render style?\n        if (!this.tile_data[tile.key].vertex_data) {\n            this.tile_data[tile.key].vertex_data = this.vertex_layout.createVertexData();\n        }\n\n        this.buildGeometry(feature.geometry, style, this.tile_data[tile.key].vertex_data, context);\n    },\n\n    buildGeometry (geometry, style, vertex_data, context) {\n        if (geometry.type === 'Polygon') {\n            this.buildPolygons([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiPolygon') {\n            this.buildPolygons(geometry.coordinates, style, vertex_data, context);\n        }\n        else if (geometry.type === 'LineString') {\n            this.buildLines([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiLineString') {\n            this.buildLines(geometry.coordinates, style, vertex_data, context);\n        }\n        else if (geometry.type === 'Point') {\n            this.buildPoints([geometry.coordinates], style, vertex_data, context);\n        }\n        else if (geometry.type === 'MultiPoint') {\n            this.buildPoints(geometry.coordinates, style, vertex_data, context);\n        }\n    },\n\n    parseFeature (feature, rule_style, context) {\n        try {\n            var style = this.feature_style;\n\n            // Preprocess first time\n            if (!rule_style.preprocessed) {\n                this.preprocess(rule_style);\n                rule_style.preprocessed = true;\n            }\n\n            // Calculate order if it was not cached\n            style.order = this.parseOrder(rule_style.order, context);\n\n            // Feature selection (only if style supports it)\n            var selectable = false;\n            style.interactive = rule_style.interactive;\n            if (this.selection) {\n                if (typeof style.interactive === 'function') {\n                    selectable = style.interactive(context);\n                }\n                else {\n                    selectable = style.interactive;\n                }\n            }\n\n            // If feature is marked as selectable\n            if (selectable) {\n                style.selection_color = FeatureSelection.makeColor(feature, context.tile);\n            }\n            else {\n                style.selection_color = FeatureSelection.defaultColor;\n            }\n\n            // Subclass implementation\n            style = this._parseFeature(feature, rule_style, context);\n\n            return style;\n        }\n        catch(error) {\n            log.error('Style.parseFeature: style parsing error', feature, style, error);\n        }\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        throw new MethodNotImplemented('_parseFeature');\n    },\n\n    preprocess () {},\n\n    // Parse an order value\n    parseOrder (order, context) {\n        // Calculate order if it was not cached\n        if (typeof order !== 'number') {\n            return StyleParser.calculateOrder(order, context);\n        }\n        return order;\n    },\n\n    // Parse a color of choose a default if acceptable, return undefined if color missing\n    parseColor(color, context) {\n        // Need either a color, or a shader block for 'color' or 'filter'\n        if (color) {\n            return StyleParser.cacheColor(color, context);\n        }\n        else if (this.shaders.blocks.color || this.shaders.blocks.filter) {\n            return StyleParser.defaults.color;\n        }\n    },\n\n    // Build functions are no-ops until overriden\n    buildPolygons () {},\n    buildLines () {},\n    buildPoints () {},\n\n\n    /*** GL state and rendering ***/\n\n    setGL (gl) {\n        this.gl = gl;\n    },\n\n    makeMesh (vertex_data, { uniforms } = {}) {\n        return new VBOMesh(this.gl, vertex_data, this.vertex_layout, { uniforms });\n    },\n\n    compile () {\n        if (!this.gl) {\n            throw(new Error(`style.compile(): skipping for ${this.name} because no GL context`));\n        }\n\n        if (this.compiling) {\n            throw(new Error(`style.compile(): skipping for ${this.name} because style is already compiling`));\n        }\n        this.compiling = true;\n        this.compiled = false;\n\n        // Build defines & for selection (need to create a new object since the first is stored as a reference by the program)\n        var defines = this.buildDefineList();\n        if (this.selection) {\n            var selection_defines = Object.assign({}, defines);\n            selection_defines.TANGRAM_FEATURE_SELECTION = true;\n        }\n\n        // Get any custom code blocks, uniform dependencies, etc.\n        var blocks = (this.shaders && this.shaders.blocks);\n        var block_scopes = (this.shaders && this.shaders.block_scopes);\n        var uniforms = (this.shaders && this.shaders.uniforms);\n\n        // accept a single extension, or an array of extensions\n        var extensions = (this.shaders && this.shaders.extensions);\n        if (typeof extensions === 'string') {\n            extensions = [extensions];\n        }\n\n        // Create shaders\n        try {\n            this.program = new ShaderProgram(\n                this.gl,\n                shaderSources[this.vertex_shader_key],\n                shaderSources[this.fragment_shader_key],\n                {\n                    name: this.name,\n                    defines,\n                    uniforms,\n                    blocks,\n                    block_scopes,\n                    extensions\n                }\n            );\n            this.program.compile();\n\n            if (this.selection) {\n                this.selection_program = new ShaderProgram(\n                    this.gl,\n                    shaderSources[this.vertex_shader_key],\n                    shaderSources['gl/shaders/selection_fragment'],\n                    {\n                        name: (this.name + ' (selection)'),\n                        defines: selection_defines,\n                        uniforms,\n                        blocks,\n                        block_scopes,\n                        extensions\n                    }\n                );\n                this.selection_program.compile();\n            }\n            else {\n                this.selection_program = null;\n            }\n        }\n        catch(error) {\n            this.compiling = false;\n            this.compiled = false;\n            throw(new Error(`style.compile(): style ${this.name} error:`, error));\n        }\n\n        this.compiling = false;\n        this.compiled = true;\n    },\n\n    // Add a shader block\n    addShaderBlock (key, block, scope = null) {\n        this.shaders.blocks = this.shaders.blocks || {};\n        this.shaders.blocks[key] = this.shaders.blocks[key] || [];\n        this.shaders.blocks[key].push(block);\n\n        this.shaders.block_scopes = this.shaders.block_scopes || {};\n        this.shaders.block_scopes[key] = this.shaders.block_scopes[key] || [];\n        this.shaders.block_scopes[key].push(scope);\n    },\n\n    // Remove all shader blocks for key\n    removeShaderBlock (key) {\n        if (this.shaders.blocks) {\n            this.shaders.blocks[key] = null;\n        }\n    },\n\n    replaceShaderBlock (key, block, scope = null) {\n        this.removeShaderBlock(key);\n        this.addShaderBlock(key, block, scope);\n    },\n\n    /** TODO: could probably combine and generalize this with similar method in ShaderProgram\n     * (list of define objects that inherit from each other)\n     */\n    buildDefineList () {\n        // Add any custom defines to built-in style defines\n        var defines = {}; // create a new object to avoid mutating a prototype value that may be shared with other styles\n        if (this.defines != null) {\n            for (var d in this.defines) {\n                defines[d] = this.defines[d];\n            }\n        }\n        if (this.shaders != null && this.shaders.defines != null) {\n            for (d in this.shaders.defines) {\n                defines[d] = this.shaders.defines[d];\n            }\n        }\n        return defines;\n\n    },\n\n    // Setup any GL state for rendering\n    setup () {\n        this.setUniforms();\n        this.material.setupProgram(ShaderProgram.current);\n    },\n\n    // Set style uniforms on currently bound program\n    setUniforms () {\n        var program = ShaderProgram.current;\n        if (!program) {\n            return;\n        }\n\n        program.setUniforms(this.shaders && this.shaders.uniforms, true); // reset texture unit to 0\n    },\n\n    update () {\n        // Style-specific animation\n        // if (typeof this.animation === 'function') {\n        //     this.animation();\n        // }\n    }\n};\n","// Manage rendering styles\n\nimport Utils from '../utils/utils';\nimport ShaderProgram from '../gl/shader_program';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\nimport {Style} from './style';\nimport {mergeObjects} from './rule';\n\nimport log from 'loglevel';\n\nexport var StyleManager = {};\nexport var Styles = {};\nexport var BaseStyles = {};\n\nStyleManager.styles = Styles;\n\n// Set the base object used to instantiate styles\nStyleManager.baseStyle = Style;\n\n// Global configuration for all styles\nStyleManager.init = function () {\n    if (StyleManager.initialized) {\n        return;\n    }\n\n    ShaderProgram.removeBlock('global');\n\n    // Layer re-ordering function\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/layer_order']);\n\n    // Feature selection global\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/selection_globals']);\n\n    // World position wrapping\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/world_position_wrap']);\n\n    // Feature selection vertex shader support\n    ShaderProgram.replaceBlock('feature-selection-vertex', shaderSources['gl/shaders/selection_vertex']);\n\n    // assume min 16-bit depth buffer, in practice uses 14-bits, 1 extra bit to handle virtual half-layers\n    // for outlines (inserted in between layers), another extra bit to prevent precision loss\n    ShaderProgram.defines.TANGRAM_LAYER_DELTA = 1 / (1 << 14);\n\n    StyleManager.initialized = true;\n};\n\n// Destroy all styles for a given GL context\nStyleManager.destroy = function (gl) {\n    Object.keys(Styles).forEach((_name) => {\n        var style = Styles[_name];\n        if (style.gl === gl) {\n            log.trace(`StyleManager.destroy: destroying render style ${style.name}`);\n\n            if (!style.isBuiltIn()) {\n                StyleManager.remove(style.name);\n            }\n            style.destroy();\n        }\n    });\n};\n\n// Register a style\nStyleManager.register = function (style) {\n    Styles[style.name] = style;\n    BaseStyles[style.name] = style;\n};\n\n// Remove a style\nStyleManager.remove = function (name) {\n    delete Styles[name];\n};\n\n// Load style definitions from external URLs\nStyleManager.loadRemoteStyles = function (styles, base) {\n    // Collect URLs and modes to import from them\n    // This is done as a separate step becuase it is possible to import multiple modes from a single\n    // URL, and we want to avoid duplicate calls for the same file.\n    var urls = {};\n    for (var name in styles) {\n        var style = styles[name];\n        if (style.url) {\n            let url = style.url;\n            if (base) {\n                url = Utils.addBaseURL(url, base);\n            }\n\n            if (!urls[url]) {\n                urls[url] = [];\n            }\n\n            // Make a list of the styles to import for this URL\n            urls[url].push({\n                target_name: name,\n                source_name: style.name || name\n            });\n        }\n    }\n\n    // As each URL finishes loading, replace the target style(s)\n    return Promise.all(Object.keys(urls).map(url => {\n        return new Promise((resolve, reject) => {\n            Utils.loadResource(url).then((data) => {\n                // Mixin remote styles, within each remote file\n                // TODO: may not handle multiple levels of mixins, and will not handle nested remote files\n                for (var source_name in data) {\n                    let source_import = urls[url] && urls[url].find(s => s.source_name === source_name);\n                    if (source_import) {\n                        // use imported name if different from name in source file\n                        data[source_name].name = source_import.target_name;\n                    }\n                    else {\n                        data[source_name].name = source_name;\n                    }\n\n                    data[source_name] = StyleManager.mix(data[source_name], data);\n                }\n\n                // Add remote styles to local styles\n                for (var target of urls[url]) {\n                    if (data && data[target.source_name]) {\n                        styles[target.target_name] = data[target.source_name];\n                    }\n                    else {\n                        delete styles[target.target_name];\n                        return reject(new Error(`StyleManager.loadRemoteStyles: error importing style ${target.target_name}, could not find source style ${target.source_name} in ${url}`));\n                    }\n                }\n                resolve();\n\n                this.selection = false;\n            }).catch((error) => {\n                log.error(`StyleManager.loadRemoteStyles: error importing style(s) ${JSON.stringify(urls[url])} from ${url}`, error);\n            });\n        });\n    })).then(() => Promise.resolve(styles));\n};\n\n// Preload shader blocks from external URLs\nStyleManager.loadShaderBlocks = function (styles, base) {\n    if (!styles) {\n        return Promise.resolve({});\n    }\n    var queue = [];\n    for (var style of Utils.values(styles)) {\n        if (style.shaders && style.shaders.blocks) {\n            let _blocks = style.shaders.blocks;\n\n            for (let [key, block] of Utils.entries(style.shaders.blocks)) {\n                let _key = key;\n\n                // Array of blocks\n                if (Array.isArray(block)) {\n                    for (let b=0; b < block.length; b++) {\n                        if (typeof block[b] === 'object' && block[b].url) {\n                            let _index = b;\n                            let url = block[b].url;\n                            if (base) {\n                                url = Utils.addBaseURL(url, base);\n                            }\n\n                            queue.push(Utils.io(Utils.cacheBusterForUrl(url)).then((data) => {\n                                _blocks[_key][_index] = data;\n                            }).catch((error) => {\n                                log.error(`StyleManager.loadShaderBlocks: error loading shader block`, _blocks, _key, _index, error);\n                            }));\n                        }\n                    }\n                }\n                // Single block\n                else if (typeof block === 'object' && block.url) {\n                    let url = block.url;\n                    if (base) {\n                        url = Utils.addBaseURL(url, base);\n                    }\n\n                    queue.push(Utils.io(Utils.cacheBusterForUrl(url)).then((data) => {\n                        _blocks[_key] = data;\n                    }).catch((error) => {\n                        log.error(`StyleManager.loadShaderBlocks: error loading shader block`, _blocks, _key, error);\n                    }));\n                }\n            }\n        }\n    }\n    return Promise.all(queue).then(() => Promise.resolve(styles)); // TODO: add error\n};\n\nStyleManager.mix = function (style, styles) {\n    // Exit early if we have already applied mixins to this style\n    if (style.mixed) {\n        return style;\n    }\n\n    // Mixin sources, in order\n    let sources = [];\n    if (style.mix) {\n        if (Array.isArray(style.mix)) {\n            sources.push(...style.mix);\n        }\n        else {\n            sources.push(style.mix);\n        }\n        sources = sources.map(x => styles[x]).filter(x => x);\n    }\n    sources.push(style);\n\n    // Flags - OR'd, true if any style has it set\n    style.animated = sources.some(x => x && x.animated);\n    style.texcoords = sources.some(x => x && x.texcoords);\n\n    // Overwrites - last definition wins\n    style.base = sources.map(x => x.base).filter(x => x).pop();\n    style.lighting = sources.map(x => x.lighting).filter(x => x != null).pop();\n    style.texture = sources.map(x => x.texture).filter(x => x).pop();\n    if (sources.some(x => x.blend)) {\n        // only mix blend if explicitly set, otherwise let base style choose blending mode\n        style.blend = sources.map(x => x.blend).filter(x => x).pop();\n    }\n\n    // Merges - property-specific rules for merging values\n    style.defines = Object.assign({}, ...sources.map(x => x.defines).filter(x => x));\n    style.material = Object.assign({}, ...sources.map(x => x.material).filter(x => x));\n\n    let merge = sources.map(x => x.shaders).filter(x => x);\n    let shaders = {};\n    shaders.defines = Object.assign({}, ...merge.map(x => x.defines).filter(x => x));\n    shaders.uniforms = Object.assign({}, ...merge.map(x => x.uniforms).filter(x => x));\n\n    // Build a list of unique extensions\n    shaders.extensions = Object.keys(merge\n        .map(x => x.extensions)\n        .filter(x => x)\n        .reduce((prev, cur) => {\n            // single extension\n            if (typeof cur === 'string') {\n                prev[cur] = true;\n            }\n            // array of extensions\n            else {\n                cur.forEach(x => prev[x] = true);\n            }\n            return prev;\n        }, {}) || {}\n    );\n\n    // Mark all shader blocks for the target style as originating with its own name\n    if (style.shaders && style.shaders.blocks) {\n        style.shaders.block_scopes = style.shaders.block_scopes || {};\n        for (let [k, block] of Utils.entries(style.shaders.blocks)) {\n            style.shaders.block_scopes[k] = style.shaders.block_scopes[k] || [];\n            if (Array.isArray(block)) {\n                style.shaders.block_scopes[k].push(...block.map(() => style.name));\n            }\n            else {\n                style.shaders.block_scopes[k].push(style.name);\n            }\n        }\n    }\n\n    // Merge shader blocks, keeping track of which style each block originated from\n    for (let source of merge) {\n        if (!source.blocks) {\n            continue;\n        }\n\n        shaders.blocks = shaders.blocks || {};\n        shaders.block_scopes = shaders.block_scopes || {};\n\n        for (let [t, block] of Utils.entries(source.blocks)) {\n            let block_scope = source.block_scopes[t];\n\n            shaders.blocks[t] = shaders.blocks[t] || [];\n            shaders.block_scopes[t] = shaders.block_scopes[t] || [];\n\n            if (Array.isArray(block)) {\n                shaders.blocks[t].push(...block);\n                shaders.block_scopes[t].push(...block_scope);\n            }\n            else {\n                shaders.blocks[t].push(block);\n                shaders.block_scopes[t].push(block_scope);\n            }\n        }\n    }\n\n    style.shaders = shaders;\n    style.mixed = true; // track that we already applied mixins (avoid dupe work later)\n\n    return style;\n};\n\n// Create a new style\n// name: name of new style\n// config: properties of new style\n// styles: working set of styles being built (used for mixing in existing styles)\nStyleManager.create = function (name, config, styles = {}) {\n    let style = mergeObjects({}, config); // deep copy\n    style.name = name;\n\n    // Style mixins\n    style = StyleManager.mix(style, styles);\n\n    // Has base style?\n    // Only renderable (instantiated) styles should be included for run-time use\n    // Others are intermediary/abstract, used during style composition but not execution\n    if (style.base && BaseStyles[style.base]) {\n        Styles[name] = style = Object.assign(Object.create(BaseStyles[style.base]), style);\n    }\n\n    return style;\n};\n\n// Called to create and initialize styles\nStyleManager.build = function (styles, scene = {}) {\n    // Sort styles by dependency, then build them\n    let style_deps = Object.keys(styles).sort(\n        (a, b) => StyleManager.inheritanceDepth(a, styles) - StyleManager.inheritanceDepth(b, styles)\n    );\n\n    // Only keep built-in base styles\n    for (let sname in Styles) {\n        if (!BaseStyles[sname]) {\n            delete Styles[sname];\n        }\n        else {\n            Styles[sname].reset();\n        }\n    }\n\n    // Working set of styles being built\n    let ws = {};\n    for (let sname of style_deps) {\n        ws[sname] = StyleManager.create(sname, styles[sname], ws);\n    }\n\n    StyleManager.initStyles(scene);\n    return Styles;\n};\n\n// Initialize all styles\nStyleManager.initStyles = function (scene) {\n    // Initialize all\n    for (let sname in Styles) {\n        Styles[sname].init(scene);\n    }\n};\n\n// Given a style key in a set of styles to add, count the length of the inheritance chain\n// TODO: remove current (Styles) and future (styles) duplication, confusing\nStyleManager.inheritanceDepth = function (key, styles) {\n    let parents = 0;\n\n    while(true) {\n        let style = styles[key];\n        if (!style) {\n            // this is a scene def error, trying to extend a style that doesn't exist\n            break;\n        }\n\n        // Dependency chain ends when this style isn't mixing in any others\n        if (!style.mix) {\n            break;\n        }\n\n        // Traverse next parent style\n        parents++;\n\n        if (Array.isArray(style.mix)) {\n            // If multiple mixins, find the deepest one\n            parents += Math.max(...style.mix.map(s => {\n                // Trying to mix into itself!\n                if (key === s) {\n                    return;\n                }\n\n                return StyleManager.inheritanceDepth(s, styles);\n            }));\n            break;\n        }\n        else {\n            // Trying to mix into itself!\n            if (key === style.mix) {\n                break;\n            }\n\n            // If single mixin, continue loop up the tree\n            key = style.mix;\n        }\n    }\n    return parents;\n};\n\n// Compile all styles\nStyleManager.compile = function (keys, scene) {\n    keys = keys || Object.keys(Styles);\n    for (let key of keys) {\n        let style = Styles[key];\n        try {\n            style.compile();\n            log.trace(`StyleManager.compile(): compiled style ${key}`);\n        }\n        catch(error) {\n            log.error(`StyleManager.compile(): error compiling style ${key}:`, error);\n\n            scene.trigger('warning', {\n                type: 'styles',\n                message: `Error compiling style ${key}`,\n                style,\n                shader_errors: style.program && style.program.shader_errors\n            });\n        }\n    }\n\n    log.debug(`StyleManager.compile(): compiled all styles`);\n};\n\n// Get all styles with mesh data for a given tile\nStyleManager.stylesForTile = function (tile) {\n    let styles = [];\n    for (let s in Styles) {\n        if (Styles[s].hasDataForTile(tile)) {\n            styles.push(s);\n        }\n    }\n    return styles;\n};\n","import Utils from '../utils/utils';\nimport Geo from '../geo';\n\nimport parseCSSColor from 'csscolorparser';\nimport log from 'loglevel';\n\nexport var StyleParser = {};\n\n// Style macros\n\nStyleParser.expandMacros = function expandMacros (obj) {\n    for (var p in obj) {\n        var val = obj[p];\n\n        // Loop through object properties\n        if (typeof val === 'object') {\n            obj[p] = expandMacros(val);\n        }\n        // Convert strings back into functions\n        else if (typeof val === 'string') {\n            for (var m in StyleParser.macros) {\n                if (val.match(StyleParser.macros[m])) {\n                    var f;\n                    try {\n                        /*jshint ignore:start */\n                        eval('f = ' + val);\n                        /*jshint ignore:end */\n                        obj[p] = f;\n                        log.trace(`expanded macro ${val} to ${f}`);\n                        break;\n                    }\n                    catch (e) {\n                        // fall-back to original value if parsing failed\n                        obj[p] = val;\n                        log.trace(`failed to expand macro ${val}`);\n                    }\n                }\n            }\n        }\n    }\n\n    return obj;\n};\n\n// List of macros\nStyleParser.macros = [\n    'Style.color.pseudoRandomColor',\n    'Style.color.randomColor'\n];\n\n\n\nvar Style = {};\n\nStyle.color = {\n    // pseudo-random grayscale by geometry id\n    pseudoRandomGrayscale() {\n        var func = `function() {\n            var c = Math.max((parseInt(feature.id, 16) % 100) / 100, 0.4);\n            return [0.7 * c, 0.7 * c, 0.7 * c];\n        }`;\n        return func;\n    },\n\n    // pseudo-random color by geometry id\n    pseudoRandomColor() {\n        var func = `function() {\n            return [\n                0.7 * (parseInt(feature.id, 16) / 100 % 1),\n                0.7 * (parseInt(feature.id, 16) / 10000 % 1),\n                0.7 * (parseInt(feature.id, 16) / 1000000 % 1)\n            ];\n        }`;\n        return func;\n        // return `function() { return [0.7 * (parseInt(feature.id, 16) / 100 % 1), 0.7 * (parseInt(feature.id, 16) / 10000 % 1), 0.7 * (parseInt(feature.id, 16) / 1000000 % 1)]; }`;\n    },\n\n    // random color\n    randomColor() {\n        var func = `function() {\n            return [0.7 * Math.random(), 0.7 * Math.random(), 0.7 * Math.random()];\n        }`;\n        return func;\n    }\n};\n\n// Wraps style functions and provides a scope of commonly accessible data:\n// - feature: the 'properties' of the feature, e.g. accessed as 'feature.name'\n// - $zoom: the current map zoom level\n// - $geometry: the type of geometry, 'point', 'line', or 'polygon'\n// - $meters_per_pixel: conversion for meters/pixels at current map zoom\n// - properties: user-defined properties on the style-rule object in the stylesheet\nStyleParser.wrapFunction = function (func) {\n    var f = `function(context) {\n                var feature = context.feature.properties;\n                var $zoom = context.zoom;\n                var $geometry = context.geometry;\n                var $meters_per_pixel = context.meters_per_pixel;\n                var properties = context.properties;\n                return (${func}());\n            }`;\n    return f;\n};\n\n\n// Style parsing\n\n// Style defaults\nStyleParser.defaults = {\n    color: [1, 1, 1, 1],\n    width: 1,\n    size: 1,\n    extrude: false,\n    height: 20,\n    min_height: 0,\n    order: 0,\n    z: 0,\n    material: {\n        ambient: 1,\n        diffuse: 1\n    }\n};\n\n\n// A context object that is passed to style parsing functions to provide a scope of commonly used values\nStyleParser.getFeatureParseContext = function (feature, tile) {\n    return {\n        feature,\n        tile,\n        zoom: tile.style_zoom,\n        geometry: Geo.geometryType(feature.geometry.type),\n        meters_per_pixel: Geo.metersPerPixel(tile.coords.z),\n        units_per_meter: Geo.units_per_meter[tile.coords.z]\n    };\n};\n\nStyleParser.convertUnits = function(val, context, convert = 'meters') {\n    if (typeof val === 'string') {\n        var units = val.match(/([0-9.-]+)([a-z]+)/);\n        if (units && units.length === 3) {\n            val = parseFloat(units[1]);\n            units = units[2];\n        }\n\n        // Convert to meters\n        if (convert === 'meters') {\n            // Convert from pixels\n            if (units === 'px') {\n                val *= Geo.metersPerPixel(context.zoom);\n            }\n            // Convert from kilometers\n            else if (units === 'km') {\n                val *= 1000;\n            }\n        }\n    }\n    else if (Array.isArray(val)) {\n        // Array of arrays, e.g. zoom-interpolated stops\n        if (Array.isArray(val[0])) {\n            return val.map(v => { return [v[0], StyleParser.convertUnits(v[1], context, convert)]; });\n        }\n        // Array of values\n        else {\n            return val.map(v => { return StyleParser.convertUnits(v, context, convert); });\n        }\n    }\n    return val;\n};\n\n// Takes a distance cache object and returns a distance value for this zoom\n// (caching the result for future use)\n// { value: original, zoom: { z: meters }, dynamic: function(){...} }\nStyleParser.cacheDistance = function(val, context, convert = 'meters') {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.zoom && val.zoom[convert] && val.zoom[convert][context.zoom]) {\n        return val.zoom[convert][context.zoom];\n    }\n    else {\n        // Dynamic function-based\n        if (typeof val.value === 'function') {\n            val.dynamic = val.value;\n            let v = val.dynamic(context);\n            return v;\n        }\n        // Array of zoom-interpolated stops, e.g. [zoom, value] pairs\n        else {\n            // Calculate value for current zoom\n            val.zoom = val.zoom || {};\n            let zunits = val.zoom[convert] = val.zoom[convert] || {};\n\n            zunits[context.zoom] = StyleParser.convertUnits(val.value, context,\n                convert === 'meters' && 'meters'); // convert to meters\n            zunits[context.zoom] = Utils.interpolate(context.zoom, zunits[context.zoom]);\n\n            return zunits[context.zoom];\n        }\n    }\n};\n\n// Cache previously parsed color strings\nStyleParser.string_colors = {};\nStyleParser.colorForString = function(string) {\n    // Cached\n    if (StyleParser.string_colors[string]) {\n        return StyleParser.string_colors[string];\n    }\n\n    // Calculate and cache\n    let color = parseCSSColor.parseCSSColor(string);\n    if (color && color.length === 4) {\n        color[0] /= 255;\n        color[1] /= 255;\n        color[2] /= 255;\n        color[3] = 1;\n    }\n    else {\n        color = StyleParser.defaults.color;\n    }\n    StyleParser.string_colors[string] = color;\n    return color;\n};\n\n// Takes a color cache object and returns a color value for this zoom\n// (caching the result for future use)\n// { value: original, static: [r,g,b,a], zoom: { z: [r,g,b,a] }, dynamic: function(){...} }\nStyleParser.cacheColor = function(val, context = {}) {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        v[3] = v[3] || 1; // default alpha\n        return v;\n    }\n    else if (val.static) {\n        return val.static;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) {\n        return val.zoom[context.zoom];\n    }\n    else {\n        // Dynamic function-based color\n        if (typeof val.value === 'function') {\n            val.dynamic = val.value;\n            let v = val.dynamic(context);\n            v[3] = v[3] || 1; // default alpha\n            return v;\n        }\n        // Single string color\n        else if (typeof val.value === 'string') {\n            val.static = StyleParser.colorForString(val.value);\n            return val.static;\n        }\n        // Array of zoom-interpolated stops, e.g. [zoom, color] pairs\n        else if (Array.isArray(val.value) && Array.isArray(val.value[0])) {\n            if (!val.zoom) {\n                val.zoom = {};\n                // Parse any string colors inside stops\n                for (let i=0; i < val.value.length; i++) {\n                    let v = val.value[i];\n                    if (typeof v[1] === 'string') {\n                        v[1] = StyleParser.colorForString(v[1]);\n                    }\n                }\n            }\n\n            // Calculate color for current zoom\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value);\n            val.zoom[context.zoom][3] = val.zoom[context.zoom][3] || 1; // default alpha\n            return val.zoom[context.zoom];\n        }\n        // Single array color\n        else {\n            val.static = val.value;\n            val.static[3] = val.static[3] || 1; // default alpha\n            return val.static;\n        }\n    }\n};\n\nStyleParser.parseColor = function(val, context = {}) {\n    if (typeof val === 'function') {\n        val = val(context);\n    }\n\n    // Parse CSS-style colors\n    // TODO: change all colors to use 0-255 range internally to avoid dividing and then re-multiplying in geom builder\n    if (typeof val === 'string') {\n        val = parseCSSColor.parseCSSColor(val);\n        if (val && val.length === 4) {\n            val[0] /= 255;\n            val[1] /= 255;\n            val[2] /= 255;\n        }\n        else {\n            val = null;\n        }\n    }\n    else if (Array.isArray(val) && Array.isArray(val[0])) {\n        // Array of zoom-interpolated stops, e.g. [zoom, color] pairs\n        for (let i=0; i < val.length; i++) {\n            let v = val[i];\n            if (typeof v[1] === 'string') {\n                var vc = parseCSSColor.parseCSSColor(v[1]);\n                if (vc && vc.length === 4) {\n                    vc[0] /= 255;\n                    vc[1] /= 255;\n                    vc[2] /= 255;\n                    v[1] = vc;\n                }\n            }\n        }\n    }\n\n    if (context.zoom) {\n        val = Utils.interpolate(context.zoom, val);\n    }\n\n    // Defaults\n    if (val) {\n        // alpha\n        if (!val[3]) {\n            val[3] = 1;\n        }\n    }\n    else {\n        val = [0, 0, 0, 1];\n    }\n\n    return val;\n};\n\n// Order is summed from top to bottom in the style hierarchy:\n// each child order value is added to the parent order value\nStyleParser.calculateOrder = function(order, context) {\n    if (typeof order === 'function') {\n        order = order(context);\n    }\n    else if (Array.isArray(order)) {\n        order = order.reduce((sum, order) => {\n            order = order || StyleParser.defaults.order;\n            if (typeof order === 'function') {\n                order = order(context);\n            }\n            else if (typeof order === 'string') {\n                order = context.feature.properties[order];\n            }\n            else {\n                order = parseFloat(order);\n            }\n\n            if (!order || isNaN(order)) {\n                return sum;\n            }\n            return sum + order;\n        }, 0);\n    }\n    else if (typeof order === 'string') {\n        if (context.feature.properties[order]) {\n            order = context.feature.properties[order];\n        }\n        else {\n            order = parseFloat(order);\n        }\n    }\n\n    return order;\n};\n","import Utils from '../../utils/utils';\nimport {StyleParser} from '../style_parser';\n\nexport default class FeatureLabel {\n\n    constructor (feature, rule, context, text, tile, default_font_style) {\n        this.text = text;\n        this.feature = feature;\n        this.tile_key = tile.key;\n        this.style = this.constructFontStyle(rule, context, default_font_style);\n        this.style_key = this.constructStyleKey(this.style);\n    }\n\n    getHash () {\n        let str = this.tile_key + this.style_key + this.text;\n        return Utils.hashString(str);\n    }\n\n    constructFontStyle (rule, context, default_font_style) {\n        let style = {};\n        rule.font = rule.font || default_font_style;\n\n        // Use fill if specified, or default\n        style.fill = (rule.font.fill && Utils.toCanvasColor(StyleParser.parseColor(rule.font.fill, context))) || default_font_style.fill;\n\n        // Use stroke if specified\n        if (rule.font.stroke && rule.font.stroke.color) {\n            style.stroke = Utils.toCanvasColor(StyleParser.parseColor(rule.font.stroke.color));\n            style.stroke_width = rule.font.stroke.width || default_font_style.stroke.width;\n        }\n\n        // Font properties are modeled after CSS names:\n        // - family: Helvetica, Futura, etc.\n        // - size: in pt, px, or em\n        // - style: normal, italic, oblique\n        // - weight: normal, bold, etc.\n        // - transform: capitalize, uppercase, lowercase\n        style.style = rule.font.style || default_font_style.style;\n        style.weight = rule.font.weight || default_font_style.weight;\n        style.family = rule.font.family || default_font_style.family;\n        style.transform = rule.font.transform;\n\n        let size = rule.font.size || rule.font.typeface || default_font_style.size; // TODO: 'typeface' legacy syntax, deprecate\n        let size_regex = /([0-9]*\\.)?[0-9]+(px|pt|em|%)/g;\n        let ft_size = (size.match(size_regex) || [])[0];\n        let size_kind = ft_size.replace(/([0-9]*\\.)?[0-9]+/g, '');\n\n        // TODO: improve pt/em conversion\n        style.px_logical_size = Utils.toPixelSize(ft_size.replace(/([a-z]|%)/g, ''), size_kind);\n        style.px_size = style.px_logical_size * Utils.device_pixel_ratio;\n        style.stroke_width *= Utils.device_pixel_ratio;\n        style.size = size.replace(size_regex, style.px_size + \"px\");\n\n        if (rule.font.typeface) { // 'typeface' legacy syntax, deprecate\n            style.font_css = rule.font.typeface.replace(size_regex, style.px_size + \"px\");\n        }\n        else {\n            style.font_css = this.fontCSS(style);\n        }\n\n        return style;\n    }\n\n    // Build CSS-style font string (to set Canvas draw state)\n    fontCSS ({ style, weight, size, family }) {\n        return [style, weight, size, family]\n            .filter(x => x) // remove null props\n            .join(' ');\n    }\n\n    // A key for grouping all labels of the same text style (e.g. same Canvas state, to minimize state changes)\n    constructStyleKey ({ style, weight, family, size, fill, stroke, stroke_width, transform, typeface }) {\n        return [style, weight, family, size, fill, stroke, stroke_width, transform, typeface].join('/'); // typeface for legacy\n    }\n\n    // Called before rasterization\n    static applyTextTransform (text, transform) {\n        if (transform === 'capitalize') {\n            return text.replace(/\\w\\S*/g, function (txt) {\n                return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();\n            });\n        }\n        else if (transform === 'uppercase') {\n            return text.toUpperCase();\n        }\n        else if (transform === 'lowercase') {\n            return text.toLowerCase();\n        }\n        return text;\n    }\n\n}\n","/*global Label */\n\nimport boxIntersect from 'box-intersect';\nimport Utils from '../../utils/utils';\nimport OBB from '../../utils/obb';\n\nexport default class Label {\n\n    constructor (text, size, options) {\n        Object.assign(this, {\n            text,\n            size,\n            options,\n            position: null,\n            aabb: null,\n        });\n    }\n\n    occluded (aabbs) {\n        let intersect = false;\n\n        // Broadphase\n        if (aabbs.length > 0) {\n            boxIntersect([this.aabb], aabbs, (i, j) => {\n                // Narrow phase\n                if (OBB.intersect(this.aabb.obb, aabbs[j].obb)) {\n                    intersect = true;\n                    return true;\n                }\n            });\n        }\n\n        // No collision on aabb\n        if (!intersect) {\n            aabbs.push(this.aabb);\n        }\n\n        return intersect;\n    }\n\n    // checks whether the label is within the tile boundaries\n    inTileBounds () {\n        let min = [ this.aabb[0], this.aabb[1] ];\n        let max = [ this.aabb[2], this.aabb[3] ];\n\n        if (!Utils.pointInTile(min) || !Utils.pointInTile(max)) {\n            return false;\n        }\n\n        return true;\n    }\n\n    // whether the label should be discarded\n    // 1. try to keep the label in tile if the label (to avoid collision over tile for now)\n    // 2. if 1. -> keep a minimal distance between the label\n    // 3. if 2. -> perfom occlusion\n    discard (aabbs) {\n        let discard = false;\n\n        // perform specific styling rule, should we keep the label in tile bounds?\n        if (this.options.keep_in_tile) {\n            let in_tile = this.inTileBounds();\n\n            if (!in_tile && this.options.move_in_tile) {\n                // can we move?\n                discard = this.moveInTile();\n            } else if (!in_tile) {\n                // we didn't want to move at all,\n                // just discard since we're out of tile bounds\n                return true;\n            }\n        }\n\n        // should we discard? if not, just make occlusion test\n        return discard || this.occluded(aabbs);\n    }\n}\n","import LabelPoint from './label_point';\nimport LabelLine from './label_line';\nimport Geo from '../../geo';\n\nvar LabelBuilder;\nexport default LabelBuilder = {};\n\nLabelBuilder.buildFromGeometry = function (text, size, geometry, options) {\n    let labels = [];\n\n    if (geometry.type === \"LineString\") {\n        let lines = geometry.coordinates;\n\n        labels.push(new LabelLine(text, size, lines, options));\n    } else if (geometry.type === \"MultiLineString\") {\n        let lines = geometry.coordinates;\n\n        for (let i = 0; i < lines.length; ++i) {\n            let line = lines[i];\n            labels.push(new LabelLine(text, size, line, options));\n        }\n    } else if (geometry.type === \"Point\") {\n        labels.push(new LabelPoint(text, geometry.coordinates, size, options));\n    } else if (geometry.type === \"MultiPoint\") {\n        let points = geometry.coordinates;\n\n        for (let i = 0; i < points.length; ++i) {\n            let point = points[i];\n            labels.push(new LabelPoint(text, point, size, options));\n        }\n    } else if (geometry.type === \"Polygon\") {\n        let centroid = Geo.centroid(geometry.coordinates[0]);\n        labels.push(new LabelPoint(text, centroid, size, options));\n    } else if (geometry.type === \"MultiPolygon\") {\n        let centroid = Geo.multiCentroid(geometry.coordinates);\n        labels.push(new LabelPoint(text, centroid, size, options));\n    }\n\n    return labels;\n};\n","import Vector from '../../vector';\nimport Label from './label';\nimport OBB from '../../utils/obb';\n\nexport default class LabelLine extends Label {\n\n    constructor (text, size, lines, options) {\n        super(text, size, options);\n\n        this.segment_index = 0;\n        this.lines = lines;\n        this.update();\n    }\n\n    update () {\n        let segment = this.currentSegment();\n        this.angle = this.computeAngle();\n        this.position = [(segment[0][0] + segment[1][0]) / 2, (segment[0][1] + segment[1][1]) / 2];\n        this.aabb = this.computeAABB();\n    }\n\n    moveNextSegment () {\n        if (this.segment_index + 1 >= this.lines.length - 1) {\n            return false;\n        }\n\n        this.segment_index++;\n        this.update();\n\n        return true;\n    }\n\n    computeAngle () {\n        let segment = this.currentSegment();\n        let p0p1 = Vector.sub(segment[0], segment[1]);\n\n        p0p1 = Vector.normalize(p0p1);\n\n        let PI_2 = Math.PI / 2;\n        let theta = Math.atan2(p0p1[0], p0p1[1]) + PI_2;\n\n        if (theta > PI_2 || theta < -PI_2) {\n            theta += Math.PI;\n        }\n        theta %= Math.PI * 2;\n\n        return theta;\n    }\n\n    fitToSegment (should_fit = true) {\n        if (!should_fit) {\n            return true;\n        }\n\n        let segment = this.currentSegment();\n        let p0p1 = Vector.sub(segment[0], segment[1]);\n        let length = Vector.length(p0p1);\n\n        let label_length = this.size.text_size[0] * this.options.units_per_pixel;\n\n        if (label_length > length) {\n            // an exceed heurestic of 100% would let the label fit in any cases\n            let exceed = (1 - (length / label_length)) * 100;\n            return exceed < this.options.line_exceed;\n        }\n\n        return label_length < length;\n    }\n\n    currentSegment () {\n        let p1 = this.lines[this.segment_index];\n        let p2 = this.lines[this.segment_index + 1];\n\n        return [ p1, p2 ];\n    }\n\n    computeAABB () {\n        let upp = this.options.units_per_pixel;\n        let width = (this.size.text_size[0] + this.options.buffer[0] * 2) * upp;\n        let height = (this.size.text_size[1] + this.options.buffer[1] * 2) * upp;\n\n        // apply offset, x positive, y pointing down\n        let offset = Vector.rot(this.options.offset, this.angle);\n        let p = [\n            this.position[0] + (offset[0] * upp),\n            this.position[1] - (offset[1] * upp)\n        ];\n\n        // the angle of the obb is negative since it's the tile system y axis is pointing down\n        let obb = new OBB(p[0], p[1], -this.angle, width, height);\n        let aabb = obb.getExtent();\n        aabb.obb = obb;\n\n        return aabb;\n    }\n\n    moveInTile () {\n        let in_tile = false;\n        let fits_to_segment = this.fitToSegment();\n\n        // move this label until we found a line we can fit in\n        while (!in_tile && !fits_to_segment) {\n            if (!this.moveNextSegment()) {\n                // we can't move further in this line\n                break;\n            }\n\n            in_tile = this.inTileBounds();\n            fits_to_segment = this.fitToSegment();\n        }\n\n        return !in_tile || !fits_to_segment;\n    }\n\n    discard (aabbs) {\n        if (this.lines && !this.fitToSegment()) {\n            while (!this.fitToSegment()) {\n                if (!this.moveNextSegment()) {\n                    return true;\n                }\n            }\n        }\n\n        return super.discard(aabbs);\n    }\n\n}\n","export default class LabelOptions {\n\n    constructor ({ units_per_pixel, offset, line_exceed, move_in_tile, keep_in_tile, buffer }) {\n        this.buffer = buffer|| [0, 0];\n        this.keep_in_tile = (keep_in_tile != null) ? keep_in_tile : true;\n        this.move_in_tile = (move_in_tile != null) ? move_in_tile : true;\n        this.offset = offset || [0, 0];\n        this.line_exceed = (line_exceed != null) ? line_exceed : 80;\n        this.units_per_pixel = units_per_pixel;\n    }\n\n}\n","import Label from './label';\nimport Geo from '../../geo';\nimport OBB from '../../utils/obb';\n\nexport default class LabelPoint extends Label {\n\n    constructor (text, position, size, options) {\n        super(text, size, options);\n\n        this.position = position;\n        this.update();\n    }\n\n    update() {\n        this.aabb = this.computeAABB();\n    }\n\n    computeAABB () {\n        let width = (this.size.text_size[0] + this.options.buffer[0] * 2) * this.options.units_per_pixel;\n        let height = (this.size.text_size[1] + this.options.buffer[1] * 2) * this.options.units_per_pixel;\n\n        // apply offset, x positive, y pointing down\n        let p = [\n            this.position[0] + (this.options.offset[0] * this.options.units_per_pixel),\n            this.position[1] - (this.options.offset[1] * this.options.units_per_pixel)\n        ];\n\n        let obb = new OBB(p[0], p[1], 0, width, height);\n        let aabb = obb.getExtent();\n        aabb.obb = obb;\n\n        return aabb;\n    }\n\n    moveInTile () {\n        let updated = false;\n\n        if (this.aabb[0] < 0) {\n            this.position[0] += -this.aabb[0];\n            updated = true;\n        }\n\n        if (this.aabb[2] >= Geo.tile_scale) {\n            this.position[0] -= this.aabb[2] - Geo.tile_scale + 1;\n            updated = true;\n        }\n\n        if (this.aabb[3] > 0) {\n            this.position[1] -= this.aabb[3];\n            updated = true;\n        }\n\n        if (this.aabb[1] <= -Geo.tile_scale) {\n            this.position[1] -= this.aabb[1] + Geo.tile_scale - 1;\n            updated = true;\n        }\n\n        if (updated) {\n            this.aabb = this.computeAABB();\n        }\n\n        return !this.inTileBounds();\n    }\n\n}\n","// Text rendering style\n\nimport Builders from '../builders';\nimport Texture from '../../gl/texture';\nimport WorkerBroker from '../../utils/worker_broker';\nimport Utils from '../../utils/utils';\nimport {Points} from '../points/points';\nimport LabelBuilder from './label_builder';\nimport FeatureLabel from './feature_label';\nimport LabelOptions from './label_options';\nimport {StyleParser} from '../style_parser';\n\nimport log from 'loglevel';\n\nexport let TextStyle = Object.create(Points);\n\nObject.assign(TextStyle, {\n    name: 'text',\n    super: Points,\n    built_in: true,\n    selection: false, // no feature selection for text by default\n\n    init() {\n\n        this.super.init.apply(this, arguments);\n\n        // Provide a hook for this object to be called from worker threads\n        this.main_thread_target = 'TextStyle-' + this.name;\n        if (Utils.isMainThread) {\n            WorkerBroker.addTarget(this.main_thread_target, this);\n        }\n\n        // Point style (parent class) requires texturing to be turned on\n        // (labels are always drawn with textures)\n        this.defines.TANGRAM_POINT_TEXTURE = true;\n\n        // Manually un-multiply alpha, because Canvas text rasterization is pre-multiplied\n        // See https://github.com/tangrams/tangram/issues/179\n        this.defines.TANGRAM_UNMULTIPLY_ALPHA = true;\n\n        // default font style\n        this.default_font_style = {\n            style: 'normal',\n            weight: null,\n            size: '12px',\n            family: 'Helvetica',\n            fill: 'white'\n        };\n\n        this.reset();\n    },\n\n    reset() {\n        this.super.reset.call(this);\n        this.texts = {}; // unique texts, keyed by tile\n        this.textures = {};\n        this.canvas = {};\n        this.aabbs = {};\n        this.features = {};\n        this.feature_labels = {};\n        this.feature_style_key = {};\n    },\n\n    // Called on main thread to release tile-specific resources\n    freeTile (tile) {\n        delete this.texts[tile];\n        delete this.textures[tile];\n        delete this.canvas[tile];\n        delete this.aabbs[tile];\n        // cleanup stored features for this tile\n        for (let key in this.features) {\n            let features = this.features[key];\n            for (let i = 0; i < features.length; ++i) {\n                if (features[i].tile_key === tile) {\n                    delete features[i];\n                }\n            }\n            if (Object.keys(features).length === 0) {\n                delete this.features[key];\n            }\n        }\n        delete this.feature_labels[tile];\n        delete this.feature_style_key[tile];\n    },\n\n    // Set font style params for canvas drawing\n    setFont (tile, { font_css, fill, stroke, stroke_width, px_size, px_logical_size }) {\n        this.px_size = parseInt(px_size);\n        this.px_logical_size = parseInt(px_logical_size);\n        this.text_buffer = 8; // pixel padding around text\n        let ctx = this.canvas[tile].context;\n\n        ctx.font = font_css;\n        if (stroke) {\n            ctx.strokeStyle = stroke;\n            ctx.lineWidth = stroke_width;\n        }\n        else {\n            ctx.strokeStyle = null;\n            ctx.lineWidth = 0;\n        }\n        ctx.fillStyle = fill;\n        ctx.miterLimit = 2;\n    },\n\n    // Width and height of text based on current font style\n    textSize (text, tile, transform) {\n        let str = FeatureLabel.applyTextTransform(text, transform);\n        let ctx = this.canvas[tile].context;\n        let px_size = this.px_size;\n        let px_logical_size = this.px_logical_size;\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n\n        let str_width = ctx.measureText(str).width;\n        let text_size = [\n            str_width / Utils.device_pixel_ratio,\n            this.px_size / Utils.device_pixel_ratio\n        ];\n\n        let texture_text_size = [\n            Math.ceil(str_width) + buffer * 2,\n            this.px_size + buffer * 2\n        ];\n\n        return { text_size, texture_text_size, px_size, px_logical_size };\n    },\n\n    // Draw text at specified location, adjusting for buffer and baseline\n    drawText (text, [x, y], tile, stroke, transform) {\n        let str = FeatureLabel.applyTextTransform(text, transform);\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n        if (stroke) {\n            this.canvas[tile].context.strokeText(str, x + buffer, y + buffer + this.px_size);\n        }\n        this.canvas[tile].context.fillText(str, x + buffer, y + buffer + this.px_size);\n    },\n\n    setTextureTextPositions (texts) {\n        // Find widest label and sum of all label heights\n        let widest = 0, height = 0;\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                let size = text_info.size.texture_text_size;\n\n                text_info.position = [0, height];\n\n                if (size[0] > widest) {\n                    widest = size[0];\n                }\n\n                height += size[1];\n            }\n        }\n\n        return [ widest, height ];\n    },\n\n    getTextSizes (tile, texts) {\n        // create a canvas\n        if(!this.canvas[tile]) {\n            let canvas = document.createElement('canvas');\n            this.canvas[tile] = {\n                canvas: canvas,\n                context: canvas.getContext('2d')\n            };\n        }\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_style = text_infos[text].text_style;\n                // update text sizes\n                this.setFont(tile, text_style); // TODO: only set once above\n                text_infos[text].size = this.textSize(text, tile, text_style.transform);\n            }\n        }\n\n        return Promise.resolve(texts);\n    },\n\n    rasterize (tile, texts, texture_size) {\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let info = text_infos[text];\n\n                this.setFont(tile, info.text_style); // TODO: only set once above\n                this.drawText(text, info.position, tile, info.text_style.stroke, info.text_style.transform);\n\n                info.texcoords = Builders.getTexcoordsForSprite(\n                    info.position,\n                    info.size.texture_text_size,\n                    texture_size\n                );\n            }\n        }\n    },\n\n    // Called on main thread from worker, to create atlas of labels for a tile\n    addTexts (tile, texts) {\n        if (!this.canvas[tile]) {\n            return Promise.resolve({});\n        }\n\n        let texture_size = this.setTextureTextPositions(texts);\n        let context = this.canvas[tile].context;\n\n        log.trace(`text summary for tile ${tile}: fits in ${texture_size[0]}x${texture_size[1]}px`);\n\n        // update the canvas \"context\"\n        this.canvas[tile].canvas.width = texture_size[0];\n        this.canvas[tile].canvas.height = texture_size[1];\n        context.clearRect(0, 0, texture_size[0], texture_size[1]);\n\n        // create a texture\n        let texture = 'labels-' + tile + '-' + (TextStyle.texture_id++);\n        this.textures[tile] = new Texture(this.gl, texture);\n\n        // ask for rasterization for the text set\n        this.rasterize(tile, texts, texture_size);\n\n        this.textures[tile].setCanvas(this.canvas[tile].canvas, {\n            filtering: 'linear',\n            UNPACK_PREMULTIPLY_ALPHA_WEBGL: true\n        });\n\n        // we don't need tile canvas/texture once it has been copied to to GPU\n        delete this.textures[tile];\n        delete this.canvas[tile];\n\n        return Promise.resolve({ texts, texture });\n    },\n\n    // Override\n    startData (tile) {\n        let tile_data = this.super.startData.apply(this, arguments);\n        tile_data.queue = [];\n        return tile_data;\n    },\n\n    createLabels (tile, texts) {\n        let labels_priorities = {};\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                text_info.ref = 0;\n\n                let hash = Utils.hashString(tile + style + text);\n\n                if (!this.features[hash]) {\n                    continue;\n                }\n\n                let label_features = this.features[hash];\n\n                for (let i = 0; i < label_features.length; ++i) {\n                    let label_feature = label_features[i];\n                    let feature = label_feature.feature;\n                    let options = new LabelOptions({\n                        units_per_pixel: text_info.units_per_pixel,\n                        offset: text_info.offset,\n                        buffer: text_info.buffer,\n                        line_exceed: text_info.line_exceed\n                    });\n\n                    let labels = LabelBuilder.buildFromGeometry(text, text_info.size, feature.geometry, options);\n\n                    for (let i = 0; i < labels.length; ++i) {\n                        let label = labels[i];\n                        let area = label.area;\n\n                        labels_priorities[text_info.priority] = labels_priorities[text_info.priority] || [];\n                        labels_priorities[text_info.priority].push({ style, feature, label, area });\n                    }\n                }\n            }\n        }\n\n        // sort by area size if defined\n        for (let p = 0; p < labels_priorities.length; ++p) {\n            if (!labels_priorities[p]) {\n                continue;\n            }\n\n            labels_priorities[p].sort((e1, e2) => {\n                if (e1.area && e2.area) {\n                    return e1.area < e2.area;\n                } else {\n                    return false;\n                }\n            });\n        }\n\n        return labels_priorities;\n    },\n\n    discardLabels (tile, labels, texts) {\n        this.aabbs[tile] = [];\n        this.feature_labels[tile] = new Map();\n\n        // Process labels by priority\n        let priorities = Object.keys(labels).sort((a, b) => a - b);\n        for (let priority of priorities) {\n            if (!labels[priority]) {\n                continue;\n            }\n\n            for (let i = 0; i < labels[priority].length; i++) {\n                let { style, feature, label } = labels[priority][i];\n\n                if (!label.discard(this.aabbs[tile])) {\n                    if (!this.feature_labels[tile].has(feature)) {\n                        this.feature_labels[tile].set(feature, []);\n                    }\n                    this.feature_labels[tile].get(feature).push(label);\n                    texts[style][label.text].ref++;\n                }\n            }\n        }\n\n        for (let style in texts) {\n            for (let text in texts[style]) {\n                if (texts[style][text].ref < 1) {\n                    delete texts[style][text];\n                }\n            }\n        }\n\n        for (let style in texts) {\n            let text_infos = texts[style];\n            // No labels for this style\n            if (Object.keys(text_infos).length === 0) {\n                delete texts[style];\n            }\n        }\n    },\n\n    // Override\n    endData (tile) {\n        // Count collected text\n        let count;\n        let tile_data = this.tile_data[tile];\n\n        if (tile_data.queue.length > 0) {\n            count = Object.keys(this.texts[tile]||{}).length;\n            log.trace(`# texts for tile ${tile}: ${count}`);\n        }\n        if (!count) {\n            return Promise.resolve();\n        }\n\n        // first call to main thread, ask for text pixel sizes\n        return WorkerBroker.postMessage(this.main_thread_target, 'getTextSizes', tile, this.texts[tile]).then(texts => {\n            if (!texts) {\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            }\n\n            let labels = this.createLabels(tile, texts);\n            if (!labels) {\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            }\n\n            this.discardLabels(tile, labels, texts);\n\n            // No labels for this tile\n            if (Object.keys(texts).length === 0) {\n                this.freeTile(tile);\n                WorkerBroker.postMessage(this.main_thread_target, 'freeTile', tile);\n                // early exit\n                return;\n            }\n\n            // second call to main thread, for rasterizing the set of texts\n            return WorkerBroker.postMessage(this.main_thread_target, 'addTexts', tile, texts).then(({ texts, texture }) => {\n                if (texts) {\n                    this.texts[tile] = texts;\n\n                    // Attach tile-specific label atlas to mesh as a texture uniform\n                    tile_data.uniforms = { u_texture: texture };\n                    tile_data.textures = [texture]; // assign texture ownership to tile - TODO: implement in VBOMesh\n\n                    // Build queued features\n                    tile_data.queue.forEach(q => this.super.addFeature.apply(this, q));\n                    tile_data.queue = [];\n                }\n\n                this.freeTile(tile);\n                return this.super.endData.apply(this, arguments);\n            });\n        });\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, rule, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        // Collect text\n        let text;\n        let source = rule.text_source || 'name';\n\n        if (typeof source === 'string') {\n            text = feature.properties[source];\n        } else if (typeof source === 'function') {\n            text = source(context);\n        }\n\n        if (text) {\n            feature.text = text;\n\n            if (!this.texts[tile.key]) {\n                this.texts[tile.key] = this.texts[tile.key] || {};\n            }\n\n            // features stored by hash for later use from main thread (tile / text / style)\n            let label_feature = new FeatureLabel(feature, rule, context, text, tile, this.default_font_style);\n            let feature_hash = label_feature.getHash();\n\n            if (!label_feature.style) {\n                return;\n            }\n\n            let style_key = label_feature.style_key;\n            this.feature_style_key[tile.key] = this.feature_style_key[tile.key] || new Map();\n            this.feature_style_key[tile.key].set(feature, style_key);\n\n            if (!this.texts[tile.key][style_key]) {\n                this.texts[tile.key][style_key] = {};\n            }\n\n            // label priority (lower is higher)\n            let priority = rule.priority;\n            if (priority !== undefined) {\n                // if priority is a number, use it as-is, otherwise, check type\n                // if (typeof priority === 'string') {\n                //     priority = feature.properties[priority]; // get priority from feature property\n                // }\n                // else if (typeof priority === 'function') {\n                if (typeof priority === 'function') {\n                    priority = priority(context);\n                }\n            }\n            else {\n                priority = -1 >>> 0; // default to max priority value if none set\n            }\n\n            // label offset in pixel (applied in screen space)\n            let offset = rule.offset || [0, 0];\n            offset[0] = parseFloat(offset[0]);\n            offset[1] = parseFloat(offset[1]); // y-point down\n\n            // label buffer in pixel\n            let buffer = rule.buffer;\n            if (buffer != null) {\n                if (!Array.isArray(buffer)) {\n                    buffer = [buffer, buffer]; // buffer can be 1D or 2D\n                }\n\n                buffer[0] = parseFloat(buffer[0]);\n                buffer[1] = parseFloat(buffer[1]);\n            }\n\n            // label line exceed percentage\n            let line_exceed;\n            if (rule.line_exceed && rule.line_exceed.substr(-1) === '%') {\n                line_exceed = rule.line_exceed.substr(0,rule.line_exceed.length-1);\n            }\n\n            if (!this.texts[tile.key][style_key][text]) {\n                this.texts[tile.key][style_key][text] = {\n                    text_style: label_feature.style,\n                    units_per_pixel: tile.units_per_pixel,\n                    priority,\n                    offset,\n                    buffer,\n                    line_exceed,\n                    ref: 0\n                };\n            }\n\n            // add the label feature\n            this.features = this.features || {};\n            this.features[feature_hash] = this.features[feature_hash] || [];\n            this.features[feature_hash].push(label_feature);\n\n            if (!this.tile_data[tile.key]) {\n                this.startData(tile.key);\n            }\n            this.tile_data[tile.key].queue.push([feature, rule, context]);\n        }\n    },\n\n    build (style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n\n        for (let i in style.labels) {\n            let label = style.labels[i];\n\n            this.buildQuad(\n                [label.position],\n                label.size.texture_text_size,\n                Utils.radToDeg(label.angle) || 0, vertex_data,\n                vertex_template, label.options.offset\n            );\n        }\n    },\n\n    buildLines (lines, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    buildPoints (points, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    buildPolygons (points, style, vertex_data) {\n        this.build(style, vertex_data);\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        let text = feature.text;\n\n        let style = this.feature_style;\n        let tile = context.tile.key;\n        let style_key = this.feature_style_key[tile].get(feature);\n        let text_info = this.texts[tile] && this.texts[tile][style_key] && this.texts[tile][style_key][text];\n\n        if (!text_info || !this.feature_labels[tile].has(feature)) {\n            return;\n        }\n\n        this.texcoord_scale = text_info.texcoords;\n        style.text = text;\n        style.labels = this.feature_labels[tile].get(feature);\n\n        // TODO: point style (parent class) requires a color, setting it to white for now,\n        // but could be made conditional in the vertex layout to save space\n        style.color = TextStyle.white;\n\n        // tell the point style (base class) that we want to render polygon labels at the polygon's centroid\n        style.centroid = true;\n\n        // points can be placed off the ground\n        style.z = (rule_style.z && StyleParser.cacheDistance(rule_style.z, context)) || StyleParser.defaults.z;\n\n        return style;\n    }\n\n});\n\nTextStyle.texture_id = 0;\nTextStyle.white = [1, 1, 1, 1];\n","/*global Tile */\nimport Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport WorkerBroker from './utils/worker_broker';\nimport Texture from './gl/texture';\n\nimport log from 'loglevel';\n\nexport default class Tile {\n\n    /**\n        Tile\n        @constructor\n        Required properties:\n        coords: object with {x, y, z} properties identifying tile coordinate location\n        worker: web worker to handle tile construction\n    */\n    constructor({ coords, source, worker, style_zoom }) {\n        Object.assign(this, {\n            coords: {\n                x: null,\n                y: null,\n                z: null\n            },\n            debug: {},\n            loading: false,\n            loaded: false,\n            error: null,\n            worker: null,\n            generation: null,\n            visible: false,\n            center_dist: 0\n        });\n\n        this.worker = worker;\n        this.source = source;\n        this.style_zoom = style_zoom; // zoom level to be used for styling\n\n        this.coords = coords;\n        this.coords = Tile.overZoomedCoordinate(this.coords, this.source.max_zoom);\n        this.coord_key = Tile.coordKey(this.coords);\n        this.key = Tile.key(this.coords, this.source, this.style_zoom);\n        this.min = Geo.metersForTile(this.coords);\n        this.max = Geo.metersForTile({x: this.coords.x + 1, y: this.coords.y + 1, z: this.coords.z }),\n        this.span = { x: (this.max.x - this.min.x), y: (this.max.y - this.min.y) };\n        this.bounds = { sw: { x: this.min.x, y: this.max.y }, ne: { x: this.max.x, y: this.min.y } };\n\n        // Units per pixel needs to account for over-zooming\n        this.units_per_pixel = Geo.units_per_pixel;\n        if (this.style_zoom > this.coords.z) {\n            this.units_per_pixel /= Math.pow(2, this.style_zoom - this.coords.z);\n        }\n\n        this.meshes = {}; // renderable VBO meshes keyed by style\n        this.textures = []; // textures that the tile owns (labels, etc.)\n    }\n\n    static create(spec) {\n        return new Tile(spec);\n    }\n\n    static coordKey({x, y, z}) {\n        return [x, y, z].join('/');\n    }\n\n    static key (coords, source, style_zoom) {\n        coords = Tile.overZoomedCoordinate(coords, source.max_zoom);\n        return [source.name, style_zoom, coords.x, coords.y, coords.z].join('/');\n    }\n\n    static coordinateAtZoom({x, y, z}, zoom) {\n        if (z !== zoom) {\n            let zscale = Math.pow(2, z - zoom);\n            x = Math.floor(x / zscale);\n            y = Math.floor(y / zscale);\n        }\n        return {x, y, z: zoom};\n    }\n\n    static isChild(parent, child) {\n        if (child.z > parent.z) {\n            let {x, y} = Tile.coordinateAtZoom(child, parent.z);\n            return (parent.x === x && parent.y === y);\n        }\n        return false;\n    }\n\n    static overZoomedCoordinate({x, y, z}, max_zoom) {\n        if (max_zoom !== undefined && z > max_zoom) {\n            return Tile.coordinateAtZoom({x, y, z}, max_zoom);\n        }\n        return {x, y, z};\n    }\n\n    // Sort a set of tile instances (which already have a distance from center tile computed)\n    static sort(tiles) {\n        return tiles.sort((a, b) => {\n            let ad = a.center_dist;\n            let bd = b.center_dist;\n            return (bd > ad ? -1 : (bd === ad ? 0 : 1));\n        });\n    }\n\n    freeResources() {\n        if (this.meshes) {\n            for (let m in this.meshes) {\n                this.meshes[m].destroy();\n            }\n        }\n\n        if (this.textures) {\n            for (let t of this.textures) {\n                let texture = Texture.textures[t];\n                if (texture) {\n                    texture.destroy();\n                }\n            }\n        }\n\n        this.meshes = {};\n        this.textures = [];\n    }\n\n    destroy() {\n        this.workerMessage('removeTile', this.key);\n        this.freeResources();\n        this.worker = null;\n    }\n\n    buildAsMessage() {\n        return {\n            key: this.key,\n            coord_key: this.coord_key,\n            source: this.source.name,\n            coords: this.coords,\n            min: this.min,\n            max: this.max,\n            units_per_pixel: this.units_per_pixel,\n            style_zoom: this.style_zoom,\n            generation: this.generation,\n            debug: this.debug\n        };\n    }\n\n    workerMessage (...message) {\n        return WorkerBroker.postMessage(this.worker, ...message);\n    }\n\n    build(generation) {\n        this.generation = generation;\n        if (!this.loaded) {\n            this.loading = true;\n        }\n        return this.workerMessage('buildTile', { tile: this.buildAsMessage() }).catch(e => { throw e; });\n    }\n\n    // Process geometry for tile - called by web worker\n    // Returns a set of tile keys that should be sent to the main thread (so that we can minimize data exchange between worker and main thread)\n    static buildGeometry (tile, layers, rules, styles) {\n        tile.debug.rendering = +new Date();\n        tile.debug.features = 0;\n\n        let data = tile.source_data;\n\n        // Treat top-level style rules as 'layers'\n        for (let layer_name in layers) {\n            let layer = layers[layer_name];\n            // Skip layers with no data source defined\n            if (!layer.data) {\n                log.warn(`Layer ${layer} was defined without a geometry data source and will not be rendered.`);\n                continue;\n            }\n\n            // Source names don't match\n            if (layer.data.source !== tile.source) {\n                continue;\n            }\n\n            // Get data for one or more layers from source\n            let source_layers = Tile.getDataForSource(data, layer.data, layer_name);\n            if (source_layers.length === 0) {\n                continue;\n            }\n\n            // Render features in layer\n            source_layers.forEach(source_layer => {\n                let geom = source_layer.geom;\n                if (!geom) {\n                    return;\n                }\n\n                for (let f = 0; f < geom.features.length; f++) {\n                    let feature = geom.features[f];\n                    let context = StyleParser.getFeatureParseContext(feature, tile);\n                    context.layer = source_layer.layer; // add data source layer name\n\n                    // Get draw groups for this feature\n                    let layer_rules = rules[layer_name];\n                    let draw_groups = layer_rules.buildDrawGroups(context, true);\n                    if (!draw_groups) {\n                        continue;\n                    }\n\n                    // Render draw groups\n                    for (let group_name in draw_groups) {\n                        let group = draw_groups[group_name];\n                        if (!group.visible) {\n                            continue;\n                        }\n\n                        // Add to style\n                        let style_name = group.style || group_name;\n                        let style = styles[style_name];\n\n                        if (!style) {\n                            log.warn(`Style '${style_name}' not found for rule in layer '${layer_name}':`, group, feature);\n                            continue;\n                        }\n\n                        context.properties = group.properties; // add rule-specific properties to context\n\n                        style.addFeature(feature, group, context);\n\n                        context.properties = null; // clear group-specific properties\n                    }\n\n                    tile.debug.features++;\n                }\n            });\n        }\n        tile.debug.rendering = +new Date() - tile.debug.rendering;\n\n        // Finalize array buffer for each render style\n        let tile_styles = StyleManager.stylesForTile(tile.key);\n        tile.mesh_data = {};\n        let queue = [];\n        for (let style_name of tile_styles) {\n            let style = styles[style_name];\n            queue.push(style.endData(tile.key).then((style_data) => {\n                if (style_data) {\n                    tile.mesh_data[style_name] = {\n                        vertex_data: style_data.vertex_data,\n                        uniforms: style_data.uniforms,\n                        textures: style_data.textures\n                    };\n                }\n            }));\n        }\n\n        return Promise.all(queue).then(() => {\n            // Return keys to be transfered to main thread\n            return ['mesh_data'];\n        });\n    }\n\n    /**\n        Retrieves geometry from a tile according to a data source definition\n        Returns an array of objects with:\n            layer: source layer name\n            geom: GeoJSON FeatureCollection\n    */\n    static getDataForSource (source_data, source_config, default_layer = null) {\n        var layers = [];\n\n        if (source_config != null) {\n            // If no layer specified, and a default source layer exists\n            if (!source_config.layer && source_data.layers._default) {\n                layers.push({\n                    layer: '_default',\n                    geom: source_data.layers._default\n                });\n            }\n            // If no layer specified, and a default requested layer exists\n            else if (!source_config.layer && default_layer) {\n                layers.push({\n                    layer: default_layer,\n                    geom: source_data.layers[default_layer]\n                });\n            }\n            // If a layer is specified by name, use it\n            else if (typeof source_config.layer === 'string') {\n                layers.push({\n                    layer: source_config.layer,\n                    geom: source_data.layers[source_config.layer]\n                });\n            }\n            // If multiple layers are specified by name, combine them\n            else if (Array.isArray(source_config.layer)) {\n                source_config.layer.forEach(layer => {\n                    if (source_data.layers[layer] && source_data.layers[layer].features) {\n                        layers.push({\n                            layer,\n                            geom: source_data.layers[layer]\n                        });\n                    }\n                });\n            }\n            // Assemble a custom layer via a function, which is called with all source layers\n            else if (typeof source_config.layer === 'function') {\n                layers.push({\n                    geom: source_config.layer(source_data.layers)\n                    // custom layer has no name\n                });\n            }\n        }\n\n        return layers;\n    }\n\n    /**\n       Called on main thread when a web worker completes processing\n       for a single tile.\n    */\n    buildMeshes(styles) {\n        if (this.error) {\n            return;\n        }\n\n        // Cleanup existing VBOs\n        this.freeResources();\n\n        // Debug\n        this.debug.geometries = 0;\n        this.debug.buffer_size = 0;\n\n        // Create VBOs\n        let mesh_data = this.mesh_data;\n        if (mesh_data) {\n            for (var s in mesh_data) {\n                if (mesh_data[s].vertex_data) {\n                    this.debug.buffer_size += mesh_data[s].vertex_data.byteLength;\n                    if (!styles[s]) {\n                        log.warn(`Could not create mesh because style '${s}' not found, for tile ${this.key}, aborting tile`);\n                        this.meshes = {};\n                        break;\n                    }\n                    this.meshes[s] = styles[s].makeMesh(mesh_data[s].vertex_data, mesh_data[s]);\n                    this.debug.geometries += this.meshes[s].geometry_count;\n                }\n\n                // Assign ownership to textures if needed\n                if (mesh_data[s].textures) {\n                    this.textures.push(...mesh_data[s].textures);\n                }\n            }\n        }\n\n        this.debug.geom_ratio = (this.debug.geometries / this.debug.features).toFixed(1);\n        this.mesh_data = null; // TODO: might want to preserve this for rebuilding geometries when styles/etc. change?\n        this.printDebug();\n    }\n\n    /**\n        Called on main thread when web worker completes processing, but tile has since been discarded\n        Frees resources that would have been transferred to the tile object.\n        Static method because the tile object no longer exists (the tile data returned by the worker is passed instead).\n    */\n    static abortBuild (tile) {\n        if (tile.mesh_data) {\n            for (let s in tile.mesh_data) {\n                let textures = tile.mesh_data[s].textures;\n                if (textures) {\n                    for (let t of textures) {\n                        let texture = Texture.textures[t];\n                        if (texture) {\n                            log.trace(`destroying texture ${t} for tile ${tile.key}`);\n                            texture.destroy();\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    printDebug () {\n        log.debug(`Tile: debug for ${this.key}: [  ${JSON.stringify(this.debug)} ]`);\n    }\n\n    update(scene) {\n        let coords = this.coords;\n        if (coords.z !== scene.center_tile.z) {\n            coords = Tile.coordinateAtZoom(coords, scene.center_tile.z);\n        }\n        this.center_dist = Math.abs(scene.center_tile.x - coords.x) + Math.abs(scene.center_tile.y - coords.y);\n    }\n\n    // Slice a subset of keys out of a tile\n    // Includes a minimum set of pre-defined keys for load state, debug. etc.\n    // We use this to send a subset of the tile back to the main thread, to minimize unnecessary data transfer\n    // (e.g. very large items like feature geometry are not needed on the main thread)\n    static slice (tile, keys) {\n        let keep = [\n            'key',\n            'loading',\n            'loaded',\n            'generation',\n            'error',\n            'debug'\n        ];\n        if (Array.isArray(keys)) {\n            keep.push(...keys);\n        }\n\n        // Build the tile subset\n        var tile_subset = {};\n        for (let key of keep) {\n            tile_subset[key] = tile[key];\n        }\n\n        return tile_subset;\n    }\n\n    /**\n        Called on worker to cancel loading\n        Static method because the worker only has object representations of tile data, there is no\n        tile instance created yet.\n    */\n    static cancel(tile) {\n        if (tile) {\n            if (tile.source_data && tile.source_data.request) {\n                tile.source_data.request.abort();\n            }\n            Tile.abortBuild(tile);\n        }\n    }\n\n    merge(other) {\n        for (var key in other) {\n            if (key !== 'key') {\n                this[key] = other[key];\n            }\n        }\n        return this;\n    }\n\n}\n","import Tile from './tile';\nimport Utils from './utils/utils';\n\nimport log from 'loglevel';\n\nvar TileManager;\n\nexport default TileManager = {\n\n    init(scene) {\n        this.scene = scene;\n        this.tiles = {};\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.building_tiles = null;\n    },\n\n    destroy() {\n        this.forEachTile(tile => tile.destroy());\n        this.tiles = {};\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.scene = null;\n    },\n\n    keepTile(tile) {\n        this.tiles[tile.key] = tile;\n    },\n\n    hasTile(key) {\n        return this.tiles[key] !== undefined;\n    },\n\n    forgetTile(key) {\n        delete this.tiles[key];\n        this.tileBuildStop(key);\n    },\n\n    // Remove a single tile\n    removeTile(key) {\n        log.trace(`tile unload for ${key}`);\n\n        var tile = this.tiles[key];\n\n        if (tile != null) {\n            tile.destroy();\n        }\n\n        this.forgetTile(tile.key);\n        this.scene.requestRedraw();\n    },\n\n    // Run a function on each tile\n    forEachTile(func) {\n        for (let t in this.tiles) {\n            func(this.tiles[t]);\n        }\n    },\n\n    // Remove tiles that pass a filter condition\n    removeTiles(filter) {\n        let remove_tiles = [];\n        for (let t in this.tiles) {\n            let tile = this.tiles[t];\n            if (filter(tile)) {\n                remove_tiles.push(t);\n            }\n        }\n        for (let r=0; r < remove_tiles.length; r++) {\n            let key = remove_tiles[r];\n            this.removeTile(key);\n        }\n    },\n\n    updateTilesForView() {\n        // Find visible tiles and load new ones\n        this.visible_coords = {};\n        let tile_coords = this.scene.findVisibleTileCoordinates();\n        for (let coords of tile_coords) {\n            this.queueCoordinate(coords);\n            this.visible_coords[Tile.coordKey(coords)] = coords;\n        }\n\n        // Remove tiles too far outside of view\n        this.scene.pruneTileCoordinatesForView(); // TODO: return list to prune?\n\n        this.forEachTile(tile => {\n            this.updateVisibility(tile);\n            tile.update(this.scene);\n        });\n    },\n\n    updateVisibility(tile) {\n        if (tile.style_zoom !== this.scene.tile_zoom) {\n            tile.visible = false;\n            return;\n        }\n\n        if (this.visible_coords[tile.coord_key]) {\n            tile.visible = true;\n        }\n        else {\n            // brute force\n            for (let key in this.visible_coords) {\n                if (Tile.isChild(tile.coords, this.visible_coords[key])) {\n                    tile.visible = true;\n                    return;\n                }\n            }\n\n            tile.visible = false;\n        }\n    },\n\n    getRenderableTiles() {\n        let tiles = [];\n        for (let t in this.tiles) {\n            let tile = this.tiles[t];\n            if (tile.visible && tile.loaded) {\n                tiles.push(tile);\n            }\n        }\n        return tiles;\n    },\n\n    // Queue a tile for load\n    queueCoordinate(coords) {\n        this.queued_coords[this.queued_coords.length] = coords;\n    },\n\n    // Load all queued tiles\n    loadQueuedCoordinates() {\n        if (this.queued_coords.length === 0) {\n            return;\n        }\n\n        // Sort queued tiles from center tile\n        this.queued_coords.sort((a, b) => {\n            let ad = Math.abs(this.scene.center_tile.x - a.x) + Math.abs(this.scene.center_tile.y - a.y);\n            let bd = Math.abs(this.scene.center_tile.x - b.x) + Math.abs(this.scene.center_tile.y - b.y);\n            return (bd > ad ? -1 : (bd === ad ? 0 : 1));\n        });\n        this.queued_coords.forEach(coords => this.loadCoordinate(coords));\n        this.queued_coords = [];\n    },\n\n    // Load all tiles to cover a given logical tile coordinate\n    loadCoordinate(coords) {\n        // Skip if not at current scene zoom\n        if (coords.z !== this.scene.center_tile.z) {\n            return;\n        }\n\n        // Determine necessary tiles for each source\n        for (let source of Utils.values(this.scene.sources)) {\n            if (!source.tiled) {\n                continue;\n            }\n\n            let key = Tile.key(coords, source, this.scene.tile_zoom);\n            if (!this.hasTile(key)) {\n                let tile = Tile.create({\n                    source,\n                    coords,\n                    // max_zoom: this.scene.findMaxZoom(), // TODO: replace with better max zoom handling\n                    worker: this.scene.nextWorker(),\n                    style_zoom: this.scene.styleZoom(coords.z) // TODO: replace?\n                });\n\n                this.keepTile(tile);\n                this.buildTile(tile);\n            }\n        }\n    },\n\n    // Sort and build a list of tiles\n    buildTiles(tiles) {\n        Tile.sort(tiles).forEach(tile => this.buildTile(tile));\n        this.checkBuildQueue();\n    },\n\n    buildTile(tile) {\n        this.tileBuildStart(tile.key);\n        this.updateVisibility(tile);\n        tile.update(this.scene);\n        tile.build(this.scene.generation)\n            .then(message => this.buildTileCompleted(message))\n            .catch(() => {\n                this.forgetTile(tile.key);\n                Tile.abortBuild(tile);\n            });\n    },\n\n    // Called on main thread when a web worker completes processing for a single tile (initial load, or rebuild)\n    buildTileCompleted({ tile }) {\n        // Removed this tile during load?\n        if (this.tiles[tile.key] == null) {\n            log.trace(`discarded tile ${tile.key} in TileManager.buildTileCompleted because previously removed`);\n            Tile.abortBuild(tile);\n            this.scene.updateBounds();\n        }\n        // Built with an outdated scene configuration?\n        else if (tile.generation !== this.scene.generation) {\n            log.debug(`discarded tile ${tile.key} in TileManager.buildTileCompleted because built with ` +\n                `scene config gen ${tile.generation}, current ${this.scene.generation}`);\n            this.forgetTile(tile.key);\n            Tile.abortBuild(tile);\n            this.scene.updateBounds();\n        }\n        else {\n            // Update tile with properties from worker\n            if (this.tiles[tile.key]) {\n                tile = this.tiles[tile.key].merge(tile);\n            }\n\n            this.updateVisibility(tile);\n            tile.update(this.scene);\n            tile.buildMeshes(this.scene.styles);\n            this.scene.requestRedraw();\n        }\n\n        this.tileBuildStop(tile.key);\n    },\n\n    // Track tile build state\n    tileBuildStart(key) {\n        this.building_tiles = this.building_tiles || {};\n        this.building_tiles[key] = true;\n        log.trace(`tileBuildStart for ${key}: ${Object.keys(this.building_tiles).length}`);\n    },\n\n    tileBuildStop(key) {\n        // Done building?\n        if (this.building_tiles) {\n            log.trace(`tileBuildStop for ${key}: ${Object.keys(this.building_tiles).length}`);\n            delete this.building_tiles[key];\n            this.checkBuildQueue();\n        }\n    },\n\n    // Check status of tile building queue and notify scene when we're done\n    checkBuildQueue() {\n        if (!this.building_tiles || Object.keys(this.building_tiles).length === 0) {\n            this.building_tiles = null;\n            this.scene.tileManagerBuildDone();\n        }\n    },\n\n    // Sum of a debug property across tiles\n    getDebugSum(prop, filter) {\n        var sum = 0;\n        for (var t in this.tiles) {\n            if (this.tiles[t].debug[prop] != null && (typeof filter !== 'function' || filter(this.tiles[t]) === true)) {\n                sum += this.tiles[t].debug[prop];\n            }\n        }\n        return sum;\n    },\n\n    // Average of a debug property across tiles\n    getDebugAverage(prop, filter) {\n        return this.getDebugSum(prop, filter) / Object.keys(this.tiles).length;\n    }\n\n};\n","\n\nexport class MethodNotImplemented extends Error {\n    constructor(methodName) {\n        super();\n        this.name    = 'MethodNotImplemented';\n        this.message = 'Method ' + methodName + ' must be implemented in subclass';\n    }\n}\n","import Vector from '../vector';\n\nexport default class OBB {\n\n    constructor (x, y, a, w, h) {\n        this.dimension = [w, h];\n        this.angle = a;\n        this.centroid = [x, y];\n        this.quad = [];\n        this.axes = [];\n\n        this.update();\n    }\n\n    move (px, py) {\n    \tthis.centroid = [px, py];\n\n    \tthis.update();\n    }\n\n    getExtent () {\n    \tlet inf = 1e6;\n    \tlet aabb = [inf, inf, -inf, -inf];\n\n    \tfor (let i = 0; i < 4; ++i) {\n            aabb[0] = Math.min(this.quad[i][0], aabb[0]);\n            aabb[1] = Math.min(this.quad[i][1], aabb[1]);\n            aabb[2] = Math.max(this.quad[i][0], aabb[2]);\n            aabb[3] = Math.max(this.quad[i][1], aabb[3]);\n    \t}\n\n    \treturn aabb;\n    }\n\n    perpAxes () {\n    \tthis.axes[0] = Vector.normalize(Vector.sub(this.quad[2], this.quad[3]));\n    \tthis.axes[1] = Vector.normalize(Vector.sub(this.quad[2], this.quad[1]));\n    }\n\n    update () {\n    \tlet x = [ Math.cos(this.angle), Math.sin(this.angle)];\n    \tlet y = [-Math.sin(this.angle), Math.cos(this.angle)];\n\n    \tx = Vector.mult(x, this.dimension[0] / 2.0);\n    \ty = Vector.mult(y, this.dimension[1] / 2.0);\n\n    \tthis.quad[0] = Vector.sub(Vector.sub(this.centroid, x), y); // lower-left\n    \tthis.quad[1] = Vector.sub(Vector.add(this.centroid, x), y); // lower-right\n    \tthis.quad[2] = Vector.add(Vector.add(this.centroid, x), y); // uper-right\n    \tthis.quad[3] = Vector.add(Vector.sub(this.centroid, x), y); // uper-left\n\n    \tthis.perpAxes();\n    }\n\n    static projectToAxis (obb, axis) {\n    \tlet inf = 1e6;\n    \tlet min = inf;\n    \tlet max = -inf;\n\n    \tlet quad = obb.quad;\n\n    \t// for each axis, project obb quad to it and find min and max values\n    \tfor (let i = 0; i < 4; ++i) {\n            let d =  Vector.dot(quad[i], axis);\n            min = Math.min(min, d);\n            max = Math.max(max, d);\n    \t}\n\n    \treturn [min, max];\n    }\n\n    static axisCollide (obb_a, obb_b, axes) {\n    \tfor (let i = 0; i < 2; ++i) {\n    \t\tlet a_proj = OBB.projectToAxis(obb_a, axes[i]);\n    \t\tlet b_proj = OBB.projectToAxis(obb_b, axes[i]);\n\n    \t\tif (b_proj[0] > a_proj[1] || b_proj[1] < a_proj[0]) {\n    \t\t\treturn false;\n    \t\t}\n    \t}\n    \treturn true;\n    }\n\n    static intersect(obb_a, obb_b) {\n    \treturn OBB.axisCollide(obb_a, obb_b, obb_a.axes) && OBB.axisCollide(obb_a, obb_b, obb_b.axes);\n    }\n\n}\n\n","export default function subscribeMixin (target) {\n\n    var listeners = new Set();\n    // var listeners = [];\n\n    return Object.assign(target, {\n\n        subscribe(listener) {\n            listeners.add(listener);\n            // listeners.push(listener);\n        },\n\n        unsubscribe(listener) {\n            listeners.delete(listener);\n            // var index = listeners.indexOf(listener);\n            // if (index > -1) {\n            //     listeners.splice(index, 1);\n            // }\n        },\n\n        unsubscribeAll() {\n            listeners.clear();\n            // listeners = [];\n        },\n\n        trigger(event, ...data) {\n            for (var listener of listeners) {\n                if (typeof listener[event] === 'function') {\n                    listener[event](...data);\n                }\n            }\n        }\n\n    });\n\n}\n","// Miscellaneous utilities\n/*jshint worker: true*/\n\nimport log from 'loglevel';\nimport yaml from 'js-yaml';\nimport Geo from '../geo';\n\nvar Utils;\nexport default Utils = {};\n\n// Add a base URL for schemeless or protocol-less URLs\n// Defaults to adding current window protocol and base, or adds a custom base if specified\n// Maybe use https://github.com/medialize/URI.js if more robust functionality is needed\nUtils.addBaseURL = function (url, base) {\n    if (!url) {\n        return;\n    }\n\n    // Schemeless, add protocol\n    if (url.substr(0, 2) === '//') {\n        url = window.location.protocol + url;\n    }\n    // No http(s) or data, add base\n    else if (url.search(/^(http|https|data|blob):/) < 0) {\n        var relative = (url[0] !== '/');\n        var base_info;\n        if (base) {\n            base_info = document.createElement('a'); // use a temporary element to parse URL\n            base_info.href = base;\n        }\n        else {\n            base_info = window.location;\n        }\n\n        if (relative) {\n            let path = base_info.href.match(/([^\\#]+)/); // strip hash\n            path = (path && path.length > 1) ? path[0] : '';\n            url = path + url;\n        }\n        else {\n            // Easy way\n            if (base_info.origin) {\n                url = base_info.origin + '/' + url;\n            }\n            // Hard way (IE11)\n            else {\n                var origin = url.match(/^((http|https|data|blob):\\/\\/[^\\/]*\\/)/);\n                origin = (origin && origin.length > 1) ? origin[0] : '';\n                url = origin + url;\n            }\n        }\n    }\n    return url;\n};\n\nUtils.pathForURL = function (url) {\n    if (url.search(/^(data|blob):/) === -1) {\n        return url.substr(0, url.lastIndexOf('/') + 1) || './';\n    }\n    return './';\n};\n\nUtils.cacheBusterForUrl = function (url) {\n    if (url.search(/^(data|blob):/) > -1) {\n        return url; // no cache-busting on object or data URLs\n    }\n    return url + '?' + (+new Date());\n};\n\n// Polyfill (for Safari compatibility)\nUtils._createObjectURL = undefined;\nUtils.createObjectURL = function (url) {\n    if (Utils._createObjectURL === undefined) {\n        Utils._createObjectURL = (window.URL && window.URL.createObjectURL) || (window.webkitURL && window.webkitURL.createObjectURL);\n\n        if (typeof Utils._createObjectURL !== 'function') {\n            Utils._createObjectURL = null;\n            log.warn(`window.URL.createObjectURL (or vendor prefix) not found, unable to create local blob URLs`);\n        }\n    }\n\n    if (Utils._createObjectURL) {\n        return Utils._createObjectURL(url);\n    }\n    else {\n        return url;\n    }\n};\n\nUtils.io = function (url, timeout = 60000, responseType = 'text', method = 'GET', headers = {}) {\n    var request = new XMLHttpRequest();\n    var promise = new Promise((resolve, reject) => {\n        request.open(method, url, true);\n        request.timeout = timeout;\n        request.responseType = responseType;\n        request.onload = () => {\n            if (request.status === 200) {\n                if (['text', 'json'].indexOf(request.responseType) > -1) {\n                    resolve(request.responseText);\n                }\n                else {\n                    resolve(request.response);\n                }\n            } else {\n                reject(Error('Request error with a status of ' + request.statusText));\n            }\n        };\n        request.onerror = (evt) => {\n            reject(Error('There was a network error' + evt.toString()));\n        };\n        request.ontimeout = (evt) => {\n            reject(Error('timeout '+ evt.toString()));\n        };\n        request.send();\n    });\n\n    Object.defineProperty(promise, 'request', {\n        value: request\n    });\n\n    return promise;\n};\n\nUtils.parseResource = function (body) {\n    var data;\n    try {\n        data = yaml.safeLoad(body);\n    } catch (e) {\n        throw e;\n    }\n    return data;\n};\n\nUtils.loadResource = function (source) {\n    return new Promise((resolve, reject) => {\n        if (typeof source === 'string') {\n            Utils.io(Utils.cacheBusterForUrl(source)).then((body) => {\n                try {\n                    let data = Utils.parseResource(body);\n                    resolve(data);\n                }\n                catch(e) {\n                    reject(e);\n                }\n            }, reject);\n        } else {\n            resolve(source);\n        }\n    });\n};\n\n// Needed for older browsers that still support WebGL (Safari 6 etc.)\nUtils.requestAnimationFramePolyfill = function () {\n    if (typeof window.requestAnimationFrame !== 'function') {\n        window.requestAnimationFrame =\n            window.webkitRequestAnimationFrame ||\n            window.mozRequestAnimationFrame    ||\n            window.oRequestAnimationFrame      ||\n            window.msRequestAnimationFrame     ||\n            function (cb) {\n                setTimeout(cb, 1000 /60);\n            };\n    }\n};\n\n// Stringify an object into JSON, but convert functions to strings\nUtils.serializeWithFunctions = function (obj) {\n    var serialized = JSON.stringify(obj, function(k, v) {\n        // Convert functions to strings\n        if (typeof v === 'function') {\n            return v.toString();\n        }\n        return v;\n    });\n\n    return serialized;\n};\n\n// Parse a JSON string, but convert function-like strings back into functions\nUtils.deserializeWithFunctions = function(serialized, wrap) {\n    var obj = JSON.parse(serialized);\n    obj = Utils.stringsToFunctions(obj, wrap);\n    return obj;\n};\n\n// Recursively parse an object, attempting to convert string properties that look like functions back into functions\nUtils.stringsToFunctions = function(obj, wrap) {\n    // Convert string\n    if (typeof obj === 'string') {\n        obj = Utils.stringToFunction(obj, wrap);\n    }\n    // Loop through object properties\n    else if (typeof obj === 'object') {\n        for (let p in obj) {\n            obj[p] = Utils.stringsToFunctions(obj[p], wrap);\n        }\n    }\n    return obj;\n};\n\n// Convert string back into a function\n// TODO: make function matching tolerant of whitespace and multilines\nUtils.stringToFunction = function(val, wrap) {\n    // Convert strings back into functions\n    if (val.match(/^\\s*function\\s*\\w*\\s*\\([\\s\\S]*\\)\\s*\\{[\\s\\S]*\\}/m) != null) {\n        var f;\n        try {\n            if (typeof wrap === 'function') {\n                eval('f = ' + wrap(val)); // jshint ignore:line\n            }\n            else {\n                eval('f = ' + val); // jshint ignore:line\n            }\n            return f;\n        }\n        catch (e) {\n            // fall-back to original value if parsing failed\n            return val;\n        }\n    }\n    return val;\n};\n\n// Log wrapper, sends message to main thread for display, and includes worker id #\nUtils.log = function (level, ...msg) {\n    level = level || 'info';\n    if (Utils.isWorkerThread) {\n        self.postMessage({\n            type: 'log',\n            level: level,\n            worker_id: self._worker_id,\n            msg: msg\n        });\n    }\n    else if (typeof log[level] === 'function') {\n        log[level](...msg);\n    }\n};\n\n// Default to allowing high pixel density\nUtils.use_high_density_display = true;\nUtils.updateDevicePixelRatio = function () {\n    Utils.device_pixel_ratio = (Utils.use_high_density_display && window.devicePixelRatio) || 1;\n};\n\n// Mark thread as main or worker\n(function() {\n    try {\n        if (window.document !== undefined) {\n            Utils.isWorkerThread = false;\n            Utils.isMainThread   = true;\n            Utils.updateDevicePixelRatio();\n        }\n    }\n    catch (e) {\n        if (self !== undefined) {\n            Utils.isWorkerThread = true;\n            Utils.isMainThread   = false;\n        }\n    }\n})();\n\n// Get URL that the current script was loaded from\n// If currentScript is not available, loops through <script> elements searching for a list of provided paths\n// e.g. Utils.findCurrentURL('tangram.debug.js', 'tangram.min.js');\nUtils.findCurrentURL = function (...paths) {\n    // Find currently executing script\n    var script = document.currentScript;\n    if (script) {\n        return script.src;\n    }\n    else if (Array.isArray(paths)) {\n        // Fallback on looping through <script> elements if document.currentScript is not supported\n        var scripts = document.getElementsByTagName('script');\n        for (var s=0; s < scripts.length; s++) {\n            for (var path of paths) {\n                if (scripts[s].src.indexOf(path) > -1) {\n                   return scripts[s].src;\n                }\n            }\n        }\n    }\n};\n\n// Used for differentiating between power-of-2 and non-power-of-2 textures\n// Via: http://stackoverflow.com/questions/19722247/webgl-wait-for-texture-to-load\nUtils.isPowerOf2 = function(value) {\n    return (value & (value - 1)) === 0;\n};\n\nUtils.nextPowerOf2 = function(value) {\n    return Math.pow(2, Math.ceil(Math.log2(value)));\n};\n\n// Interpolate 'x' along a series of control points\n// 'points' is an array of control points in the form [x, y]\n//\n// Example:\n//     Control points:\n//         [0, 5]:  when x=0, y=5\n//         [4, 10]: when x=4, y=10\n//\n//     Utils.interpolate(2, [[0, 5], [4, 10]]);\n//     -> computes x=2, halfway between x=0 and x=4: (10 - 5) / 2 +5\n//     -> returns 7.5\n//\n// TODO: add other interpolation methods besides linear\n//\nUtils.interpolate = function(x, points) {\n    // If this doesn't resemble a list of control points, just return the original value\n    if (!Array.isArray(points) || !Array.isArray(points[0])) {\n        return points;\n    }\n    else if (points.length < 1) {\n        return points;\n    }\n\n    var x1, x2, d, y;\n\n    // Min bounds\n    if (x <= points[0][0]) {\n        y = points[0][1];\n    }\n    // Max bounds\n    else if (x >= points[points.length-1][0]) {\n        y = points[points.length-1][1];\n    }\n    // Find which control points x is between\n    else {\n        for (var i=0; i < points.length - 1; i++) {\n            if (x >= points[i][0] && x < points[i+1][0]) {\n                // Linear interpolation\n                x1 = points[i][0];\n                x2 = points[i+1][0];\n\n                // Multiple values\n                if (Array.isArray(points[i][1])) {\n                    y = [];\n                    for (var c=0; c < points[i][1].length; c++) {\n                        d = points[i+1][1][c] - points[i][1][c];\n                        y[c] = d * (x - x1) / (x2 - x1) + points[i][1][c];\n                    }\n                }\n                // Single value\n                else {\n                    d = points[i+1][1] - points[i][1];\n                    y = d * (x - x1) / (x2 - x1) + points[i][1];\n                }\n                break;\n            }\n        }\n    }\n    return y;\n};\n\n// Iterators (ES6 generators)\n\n// Iterator for key/value pairs of an object\nUtils.entries = function* (obj) {\n    for (var key of Object.keys(obj)) {\n        yield [key, obj[key]];\n    }\n};\n\n// Iterator for values of an object\nUtils.values = function* (obj) {\n    for (var key of Object.keys(obj)) {\n        yield obj[key];\n    }\n};\n\n// Recursive iterators for all properties of an object, no matter how deeply nested\n// TODO: fix for circular structures\nUtils.recurseEntries = function* (obj) {\n    if (!obj) {\n        return;\n    }\n    for (var key of Object.keys(obj)) {\n        if (obj[key]) {\n            yield [key, obj[key], obj];\n            if (typeof obj[key] === 'object') {\n                yield* Utils.recurseEntries(obj[key]);\n            }\n        }\n    }\n};\n\nUtils.recurseValues = function* (obj) {\n    if (!obj) {\n        return;\n    }\n    for (var key of Object.keys(obj)) {\n        if (obj[key]) {\n            yield obj[key];\n            if (typeof obj[key] === 'object') {\n                yield* Utils.recurseValues(obj[key]);\n            }\n        }\n    }\n};\n\n// Scale a *signed* short for use in a GL VBO\n// `unit` is an optional scaling factor to mimic fixed point, since these values will be\n// normalized to 0-1, e.g. divide input by unit on the way in, multiply it back in the shader\nUtils.scaleInt16 = function (val, unit) {\n    return (val / unit) * 32767;\n};\n\nUtils.degToRad = function (degrees) {\n    return degrees * Math.PI / 180;\n};\n\nUtils.radToDeg = function (radians) {\n    return radians * 180 / Math.PI;\n};\n\nUtils.toCanvasColor = function (color) {\n    return 'rgb(' +  Math.round(color[0] * 255) + ',' + Math.round(color[1]  * 255) + ',' + Math.round(color[2] * 255) + ')';\n};\n\nUtils.toPixelSize = function (size, kind) {\n    if (kind === \"px\") {\n        return size;\n    } else if (kind === \"em\") {\n        return 16 * size;\n    } else if (kind === \"pt\") {\n        return size / 0.75;\n    } else if (kind === \"%\") {\n        return size / 6.25;\n    }\n};\n\nUtils.pointInTile = function (point) {\n    return point[0] >= 0 && point[1] > -Geo.tile_scale && point[0] < Geo.tile_scale && point[1] <= 0;\n};\n\n// http://stackoverflow.com/questions/7616461/generate-a-hash-from-string-in-javascript-jquery\nUtils.hashString = function(str) {\n    if (str.length === 0) {\n        return 0;\n    }\n    let hash = 0;\n    \n    for (let i = 0, len = str.length; i < len; i++) {\n        let chr = str.charCodeAt(i);\n        hash = ((hash << 5) - hash) + chr;\n        hash |= 0; \n    }\n    return hash;\n};\n\n","var version;\nexport default version = {\n    string: 'v0.3.1',\n    major: 0,\n    minor: 3,\n    patch: 1,\n    pre: false\n};\n","/*jshint worker: true*/\n\n// WorkerBroker routes messages between web workers and the main thread, allowing for simpler\n// async code via promises. Example usage:\n//\n// In web worker, define a method:\n//\n//     self.square = function (x) {\n//         return x * x;\n//     };\n//\n// In main thread, invoke that method and receive the result (if any) as a promise:\n//\n//     worker = new Worker(...);\n//     WorkerBroker.addWorker(worker);\n//\n//     WorkerBroker.postMessage(worker, 'square', 5).then(function(y) {\n//         console.log(y);\n//     });\n//\n//     -> prints 25\n//\n// Async code:\n//\n// For synchronous code that must pass a return value to the main thread, the function can simply\n// return an immediate value (see example above). For cases where the worker method needs to run\n// asynchronous code, the function can return a promise, and the resolved or rejected value will\n// be sent back to the main thread when the promise is fulfilled.\n//\n// Error handling:\n//\n// If the worker method either throws an error, or returns a promise that is rejected, it will be\n// sent back to the main thread as a promise rejection. These two examples are equivalent:\n//\n//     In worker, throwing an error:\n//\n//         self.broken = function () {\n//             throw new Error('error in worker!');\n//         };\n//\n//     In worker, returning a rejected promise:\n//\n//         self.broken = function () {\n//             return Promise.reject(new Error('error in worker!'));\n//         };\n//\n//     In main thread, both errors are received as a promise rejection:\n//\n//         WorkerBroker.postMessage(worker, 'broken').then(\n//             // Promise resolved\n//             function() {\n//                 console.log('success!');\n//             },\n//             // Promise rejected\n//             function(error) {\n//                 console.log('error!', error);\n//             });\n//\n//         -> prints 'error! error in worker'\n//\n// TODO: add documentation for invoking main thread methods from a worker (basically same API, but in reverse)\nimport Utils from './utils';\n\nvar WorkerBroker;\nexport default WorkerBroker = {};\n\n// Global list of all worker messages\n// Uniquely tracks every call made between main thread and a worker\nvar message_id = 0;\nvar messages = {};\n\n// Main thread:\n// - Send messages to workers, and optionally receive an async response as a promise\n// - Receive messages from workers, and optionally send an async response back as a promise\nfunction setupMainThread () {\n\n    // Send a message to a worker, and optionally get an async response\n    // Arguments:\n    //   - worker: the web worker instance\n    //   - method: the method with this name will be invoked in the worker\n    //   - message: will be passed to the method call in the worker\n    // Returns:\n    //   - a promise that will be fulfilled if the worker method returns a value (could be immediately, or async)\n    //\n    WorkerBroker.postMessage = function (worker, method, ...message) {\n        // Track state of this message\n        var promise = new Promise((resolve, reject) => {\n            messages[message_id] = { method, message, resolve, reject };\n        });\n\n        worker.postMessage({\n            type: 'main_send',      // mark message as method invocation from main thread\n            message_id,             // unique id for this message, for life of program\n            method,                 // will dispatch to a function of this name within the worker\n            message                 // message payload\n        });\n\n        message_id++;\n        return promise;\n    };\n\n    // Add a worker to communicate with - each worker must be registered from the main thread\n    var worker_id = 0;\n    var workers = {};\n\n    WorkerBroker.addWorker = function (worker) {\n\n        // Keep track of all registered workers\n        // TODO: adding a property directly to the worker, would be better to track non-instrusively,\n        // maybe with an ES6 Map\n        worker._worker_broker_id = worker_id++;\n        workers[worker._worker_broker_id] = worker;\n\n        // Listen for messages coming back from the worker, and fulfill that message's promise\n        worker.addEventListener('message', (event) => {\n            if (event.data.type !== 'worker_reply') {\n                return;\n            }\n\n            // Pass the result to the promise\n            var id = event.data.message_id;\n            if (messages[id]) {\n                if (event.data.error) {\n                    messages[id].reject(event.data.error);\n                }\n                else {\n                    messages[id].resolve(event.data.message);\n                }\n                delete messages[id];\n            }\n        });\n\n        // Listen for messages initiating a call from the worker, dispatch them,\n        // and send any return value back to the worker\n        worker.addEventListener('message', (event) => {\n            // Unique id for this message & return call to main thread\n            var id = event.data.message_id;\n            if (event.data.type !== 'worker_send' || id == null) {\n                return;\n            }\n\n            // Call the requested method and save the return value\n            var target = targets[event.data.target];\n            if (!target) {\n                throw Error(`Worker broker could not dispatch message type ${event.data.method} on target ${event.data.target} because no object with that name is registered on main thread`);\n            }\n\n            var method = (typeof target[event.data.method] === 'function') && target[event.data.method];\n            if (!method) {\n                throw Error(`Worker broker could not dispatch message type ${event.data.method} on target ${event.data.target} because object has no method with that name`);\n            }\n\n            var result, error;\n            try {\n                result = method.apply(target, event.data.message);\n            }\n            catch(e) {\n                // Thrown errors will be passed back (in string form) to worker\n                error = e;\n            }\n\n            // Send return value to worker\n            // Async result\n            if (result instanceof Promise) {\n                result.then((value) => {\n                    worker.postMessage({\n                        type: 'main_reply',\n                        message_id: id,\n                        message: value\n                    });\n                }, (error) => {\n                    worker.postMessage({\n                        type: 'main_reply',\n                        message_id: id,\n                        error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                    });\n                });\n            }\n            // Immediate result\n            else {\n                worker.postMessage({\n                    type: 'main_reply',\n                    message_id: id,\n                    message: result,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                });\n            }\n        });\n\n    };\n\n    // Register an object to receive calls from the worker\n    var targets = {};\n    WorkerBroker.addTarget = function (name, target) {\n        targets[name] = target;\n    };\n\n    // Expose for debugging\n    WorkerBroker.getMessages = function () {\n        return messages;\n    };\n\n    WorkerBroker.getMessageId = function () {\n        return message_id;\n    };\n\n}\n\n// Worker threads:\n// - Receive messages from main thread, and optionally send an async response back as a promise\n// - Send messages to main thread, and optionally receive an async response as a promise\nfunction setupWorkerThread () {\n\n    // Send a message to the main thread, and optionally get an async response as a promise\n    // Arguments:\n    //   - target: the name of the object in the main thread to be called\n    //   - method: the method with this name will be invoked on the main thread target object\n    //   - message: will be passed to the method call in the main thread\n    // Returns:\n    //   - a promise that will be fulfilled if the main thread method returns a value (could be immediately, or async)\n    //\n    WorkerBroker.postMessage = function (target, method, ...message) {\n        // Track state of this message\n        var promise = new Promise((resolve, reject) => {\n            messages[message_id] = { target, method, message, resolve, reject };\n        });\n\n        self.postMessage({\n            type: 'worker_send',    // mark message as method invocation from worker\n            message_id,             // unique id for this message, for life of program\n            target,                 // name of the object to be called on main thread\n            method,                 // will dispatch to a method of this name on the main thread\n            message                 // message payload\n        });\n\n        message_id++;\n        return promise;\n    };\n\n    // Listen for messages coming back from the main thread, and fulfill that message's promise\n    self.addEventListener('message', (event) => {\n        if (event.data.type !== 'main_reply') {\n            return;\n        }\n\n        // Pass the result to the promise\n        var id = event.data.message_id;\n        if (messages[id]) {\n            if (event.data.error) {\n                messages[id].reject(event.data.error);\n            }\n            else {\n                messages[id].resolve(event.data.message);\n            }\n            delete messages[id];\n        }\n    });\n\n    // Receive messages from main thread, dispatch them, and send back a reply\n    self.addEventListener('message', (event) => {\n        // Unique id for this message & return call to main thread\n        var id = event.data.message_id;\n        if (event.data.type !== 'main_send' || id == null) {\n            return;\n        }\n\n        // Call the requested worker method and save the return value\n        var method_name = event.data.method;\n        var method = (typeof self[method_name] === 'function') && self[method_name];\n        if (!method) {\n            throw Error(`Worker broker could not dispatch message type ${method_name} because worker has no method with that name`);\n        }\n\n        var result, error;\n        try {\n            result = method.apply(self, event.data.message);\n        }\n        catch(e) {\n            // Thrown errors will be passed back (in string form) to main thread\n            error = e;\n        }\n\n        // Send return value to main thread\n        let transferables;\n        // Async result\n        if (result instanceof Promise) {\n            result.then((value) => {\n                transferables = findTransferables(value);\n\n                self.postMessage({\n                    type: 'worker_reply',\n                    message_id: id,\n                    message: value\n                }, transferables);\n\n                if (transferables.length > 0) {\n                    Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to main thread`);\n                }\n            }, (error) => {\n                self.postMessage({\n                    type: 'worker_reply',\n                    message_id: id,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                });\n            });\n        }\n        // Immediate result\n        else {\n            transferables = findTransferables(result);\n\n            self.postMessage({\n                type: 'worker_reply',\n                message_id: id,\n                message: result,\n                error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n            }, transferables);\n\n            if (transferables.length > 0) {\n                Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to main thread`);\n            }\n        }\n    });\n\n}\n\n// Build a list of transferable objects from a source object\n// TODO: add option in case you DON'T want to transfer objects\nfunction findTransferables(source, list = []) {\n    if (!source) {\n         return list;\n    }\n\n    if (Array.isArray(source)) {\n        // Check each array element\n        source.forEach(x => findTransferables(x, list));\n    }\n    else if (typeof source === 'object') {\n        // Is the object a transferable array buffer?\n        if (source instanceof ArrayBuffer) {\n            list.push(source);\n        }\n        // Or looks like a typed array (has an array buffer property)?\n        else if (source.buffer instanceof ArrayBuffer) {\n            list.push(source.buffer);\n        }\n        // Otherwise check each property\n        else {\n            for (let p in source) {\n                findTransferables(source[p], list);\n            }\n        }\n    }\n    return list;\n}\n\n// Setup this thread as appropriate\nif (Utils.isMainThread) {\n    setupMainThread();\n}\n\nif (Utils.isWorkerThread) {\n    setupWorkerThread();\n}\n","/*** Vector functions - vectors provided as [x, y, z] arrays ***/\n\nvar Vector;\nexport default Vector = {};\n\nVector.set = function (v) {\n    var V = [];\n    var lim = v.length;\n    for (var i = 0; i < lim; i++) {\n        V[i] = v[i];\n    }\n    return V;\n};\n\nVector.neg = function (v) {\n    var V = [];\n    var lim = v.length;\n    for (var i = 0; i < lim; i++) {\n        V[i] = v[i] * -1;\n    }\n    return V;\n};\n\n// Addition of two vectors\nVector.add = function (v1, v2) {\n    var v = [];\n    var lim = Math.min(v1.length,v2.length);\n    for (var i = 0; i < lim; i++) {\n        v[i] = v1[i] + v2[i];\n    }\n    return v;\n};\n\n// Substraction of two vectors\nVector.sub = function (v1, v2) {\n    var v = [];\n    var lim = Math.min(v1.length,v2.length);\n\n    for (var i = 0; i < lim; i++) {\n        v[i] = v1[i] - v2[i];\n    }\n    return v;\n};\n\nVector.signed_area = function (v1, v2, v3) {\n    return (v2[0]-v1[0])*(v3[1]-v1[1]) - (v3[0]-v1[0])*(v2[1]-v1[1]);\n};\n\n// Multiplication of two vectors\nVector.mult = function (v1, v2) {\n    var v = [],\n        len = v1.length,\n        i;\n\n    if (typeof v2 === 'number') {\n        // Mulitply by scalar\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] * v2;\n        }\n    }\n    else {\n        // Multiply two vectors\n        len = Math.min(v1.length,v2.length);\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] * v2[i];\n        }\n    }\n    return v;\n};\n\n// Division of two vectors\nVector.div = function (v1, v2) {\n    var v = [],\n        i;\n    if(typeof v2 === 'number'){\n        // Divide by scalar\n        for (i = 0; i < v1.length; i++){\n            v[i] = v1[i] / v2;\n        }\n    } else {\n        // Divide to vectors\n        var len = Math.min(v1.length,v2.length);\n        for (i = 0; i < len; i++) {\n            v[i] = v1[i] / v2[i];\n        }\n    }\n    return v;\n};\n\n// Get 2D perpendicular\nVector.perp = function (v1, v2) {\n    return [ v2[1] - v1[1],\n             v1[0] - v2[0] ];\n};\n\n// Get 2D vector rotated\nVector.rot = function (v, a) {\n    var vr = Vector.length(v);\n    var va = Vector.angle(v);\n    return [vr * Math.cos(va+a),\n            vr * Math.sin(va+a)];\n};\n\n// Get 2D heading angle\nVector.angle = function ([x, y]) {\n    return Math.atan2(y,x);\n};\n\n// Compare two points\nVector.isEqual = function (v1, v2) {\n    var len = v1.length;\n    for (var i = 0; i < len; i++) {\n        if (v1[i] !== v2[i]){\n            return false;\n        }\n    }\n    return true;\n};\n\n// Vector length squared\nVector.lengthSq = function (v)\n{\n    if (v.length === 2) {\n        return (v[0]*v[0] + v[1]*v[1]);\n    }\n    else {\n        return (v[0]*v[0] + v[1]*v[1] + v[2]*v[2]);\n    }\n};\n\n// Vector length\nVector.length = function (v)\n{\n    return Math.sqrt(Vector.lengthSq(v));\n};\n\n// Normalize a vector\nVector.normalize = function (v)\n{\n    var d;\n    if (v.length === 2) {\n        d = v[0]*v[0] + v[1]*v[1];\n        d = Math.sqrt(d);\n\n        if (d !== 0) {\n            return [v[0] / d, v[1] / d];\n        }\n        return [0, 0];\n    } else {\n        d = v[0]*v[0] + v[1]*v[1] + v[2]*v[2];\n        d = Math.sqrt(d);\n\n        if (d !== 0) {\n            return [v[0] / d, v[1] / d, v[2] / d];\n        }\n        return [0, 0, 0];\n    }\n};\n\n// Cross product of two vectors\nVector.cross  = function (v1, v2) {\n    return [\n        (v1[1] * v2[2]) - (v1[2] * v2[1]),\n        (v1[2] * v2[0]) - (v1[0] * v2[2]),\n        (v1[0] * v2[1]) - (v1[1] * v2[0])\n    ];\n};\n\n// Dot product of two vectors\nVector.dot = function (v1, v2) {\n    var n = 0;\n    var lim = Math.min(v1.length, v2.length);\n    for (var i = 0; i < lim; i++) {\n        n += v1[i] * v2[i];\n    }\n    return n;\n};\n\n// Find the intersection of two lines specified as segments from points (p1, p2) and (p3, p4)\n// http://en.wikipedia.org/wiki/Line-line_intersection\n// http://en.wikipedia.org/wiki/Cramer's_rule\nVector.lineIntersection = function (p1, p2, p3, p4, parallel_tolerance) {\n    parallel_tolerance = parallel_tolerance || 0.01;\n\n    // a1*x + b1*y = c1 for line (x1, y1) to (x2, y2)\n    // a2*x + b2*y = c2 for line (x3, y3) to (x4, y4)\n    var a1 = p1[1] - p2[1]; // y1 - y2\n    var b1 = p1[0] - p2[0]; // x1 - x2\n    var a2 = p3[1] - p4[1]; // y3 - y4\n    var b2 = p3[0] - p4[0]; // x3 - x4\n    var c1 = (p1[0] * p2[1]) - (p1[1] * p2[0]); // x1*y2 - y1*x2\n    var c2 = (p3[0] * p4[1]) - (p3[1] * p4[0]); // x3*y4 - y3*x4\n    var denom = (b1 * a2) - (a1 * b2);\n\n    if (Math.abs(denom) > parallel_tolerance) {\n        return [\n            ((c1 * b2) - (b1 * c2)) / denom,\n            ((c1 * a2) - (a1 * c2)) / denom\n        ];\n    }\n    return null; // return null if lines are (close to) parallel\n};\n","module.exports = require(\"./lib/babel/polyfill\");\n"]} diff --git a/dist/tangram.min.js b/dist/tangram.min.js index 4c1eebc99..1a386362c 100644 --- a/dist/tangram.min.js +++ b/dist/tangram.min.js @@ -8,8 +8,8 @@ DuplicateProtoProperty:"Duplicate __proto__ fields are not allowed in object lit if(!(0>=i)){var e,r=n[0];return--i>0&&(e=n[i],t(n[e._=0]=e,0)),r}},r.remove=function(r){var o,a=r._;if(n[a]===r)return a!==--i&&(o=n[i],(d(o,r)<0?e:t)(n[o._=a]=o,a)),a},r}function v(e){if(!e)return y;var t,r,n=e.scale[0],i=e.scale[1],o=e.translate[0],a=e.translate[1];return function(e,s){s||(t=r=0),e[0]=(t+=e[0])*n+o,e[1]=(r+=e[1])*i+a}}function g(e){if(!e)return y;var t,r,n=e.scale[0],i=e.scale[1],o=e.translate[0],a=e.translate[1];return function(e,s){s||(t=r=0);var u=(e[0]-o)/n|0,l=(e[1]-a)/i|0;e[0]=u-t,e[1]=l-r,t=u,r=l}}function y(){}var _={version:"1.6.19",mesh:function(e){return s(e,r.apply(this,arguments))},meshArcs:r,merge:function(e){return s(e,i.apply(this,arguments))},mergeArcs:i,feature:o,neighbors:c,presimplify:f};"function"==typeof define&&define.amd?define(_):"object"==typeof t&&t.exports?t.exports=_:this.topojson=_}()},{}],67:[function(e,t,r){t.exports.VectorTile=e("./lib/vectortile.js"),t.exports.VectorTileFeature=e("./lib/vectortilefeature.js"),t.exports.VectorTileLayer=e("./lib/vectortilelayer.js")},{"./lib/vectortile.js":68,"./lib/vectortilefeature.js":69,"./lib/vectortilelayer.js":70}],68:[function(e,t,r){"use strict";function n(e,t){this.layers=e.readFields(i,{},t)}function i(e,t,r){if(3===e){var n=new o(r,r.readVarint()+r.pos);n.length&&(t[n.name]=n)}}var o=e("./vectortilelayer");t.exports=n},{"./vectortilelayer":70}],69:[function(e,t,r){"use strict";function n(e,t,r,n,o){this.properties={},this.extent=r,this.type=0,this._pbf=e,this._geometry=-1,this._keys=n,this._values=o,e.readFields(i,this,t)}function i(e,t,r){1==e?t._id=r.readVarint():2==e?o(r,t):3==e?t.type=r.readVarint():4==e&&(t._geometry=r.pos)}function o(e,t){for(var r=e.readVarint()+e.pos;e.pos>3}if(i--,1===n||2===n)o+=e.readSVarint(),s+=e.readSVarint(),1===n&&(t&&u.push(t),t=[]),t.push(new a(o,s));else{if(7!==n)throw new Error("unknown command "+n);t.push(t[0].clone())}}return t&&u.push(t),u},n.prototype.bbox=function(){var e=this._pbf;e.pos=this._geometry;for(var t=e.readVarint()+e.pos,r=1,n=0,i=0,o=0,a=1/0,s=-(1/0),u=1/0,l=-(1/0);e.pos>3}if(n--,1===r||2===r)i+=e.readSVarint(),o+=e.readSVarint(),a>i&&(a=i),i>s&&(s=i),u>o&&(u=o),o>l&&(l=o);else if(7!==r)throw new Error("unknown command "+r)}return[a,u,s,l]},n.prototype.toGeoJSON=function(e,t,r){for(var i=this.extent*Math.pow(2,r),o=this.extent*e,a=this.extent*t,s=this.loadGeometry(),u=n.types[this.type],l=0;l>3;t=1===n?e.readString():2===n?e.readFloat():3===n?e.readDouble():4===n?e.readVarint64():5===n?e.readVarint():6===n?e.readSVarint():7===n?e.readBoolean():null}return t}var a=e("./vectortilefeature.js");t.exports=n,n.prototype.feature=function(e){if(0>e||e>=this._features.length)throw new Error("feature index out of bounds");this._pbf.pos=this._features[e];var t=this._pbf.readVarint()+this._pbf.pos;return new a(this._pbf,t,this.extent,this._keys,this._values)}},{"./vectortilefeature.js":69}],71:[function(e,t,r){"use strict";function n(e,t){this.x=e,this.y=t}t.exports=n,n.prototype={clone:function(){return new n(this.x,this.y)},add:function(e){return this.clone()._add(e)},sub:function(e){return this.clone()._sub(e)},mult:function(e){return this.clone()._mult(e)},div:function(e){return this.clone()._div(e)},rotate:function(e){return this.clone()._rotate(e)},matMult:function(e){return this.clone()._matMult(e)},unit:function(){return this.clone()._unit()},perp:function(){return this.clone()._perp()},round:function(){return this.clone()._round()},mag:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},equals:function(e){return this.x===e.x&&this.y===e.y},dist:function(e){return Math.sqrt(this.distSqr(e))},distSqr:function(e){var t=e.x-this.x,r=e.y-this.y;return t*t+r*r},angle:function(){return Math.atan2(this.y,this.x)},angleTo:function(e){return Math.atan2(this.y-e.y,this.x-e.x)},angleWith:function(e){return this.angleWithSep(e.x,e.y)},angleWithSep:function(e,t){return Math.atan2(this.x*t-this.y*e,this.x*e+this.y*t)},_matMult:function(e){var t=e[0]*this.x+e[1]*this.y,r=e[2]*this.x+e[3]*this.y;return this.x=t,this.y=r,this},_add:function(e){return this.x+=e.x,this.y+=e.y,this},_sub:function(e){return this.x-=e.x,this.y-=e.y,this},_mult:function(e){return this.x*=e,this.y*=e,this},_div:function(e){return this.x/=e,this.y/=e,this},_unit:function(){return this._div(this.mag()),this},_perp:function(){var e=this.y;return this.y=this.x,this.x=-e,this},_rotate:function(e){var t=Math.cos(e),r=Math.sin(e),n=t*this.x-r*this.y,i=r*this.x+t*this.y;return this.x=n,this.y=i,this},_round:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}},n.convert=function(e){return e instanceof n?e:Array.isArray(e)?new n(e[0],e[1]):e}},{}],72:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function y(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:y(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},o=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},a=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),s=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},u=n(e("./geo")),l=n(e("./utils/utils")),c=n(e("./gl/shader_program")),f=n(e("gl-matrix")),h=f.mat4,p=f.vec3,d=function(){function e(t,r){var n=void 0===arguments[2]?{}:arguments[2];s(this,e),this.scene=r,this.position=n.position,this.zoom=n.zoom}return a(e,{update:{value:function(){}},setupProgram:{value:function(e){}},updateScene:{value:function(){if(this.position||this.zoom){var e={};this.position&&(e={lng:this.position[0],lat:this.position[1],zoom:this.position[2]}),this.zoom&&(e.zoom=this.zoom),this.scene.setView(e)}}}},{create:{value:function(e,t,r){switch(r.type){case"isometric":return new v(e,t,r);case"flat":return new g(e,t,r);case"perspective":default:return new m(e,t,r)}}}}),e}();t.exports=d;var m=function(e){function t(e,r){var n=void 0===arguments[2]?{}:arguments[2];s(this,t),i(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r,n),this.type="perspective",this.focal_length=n.focal_length,this.fov=n.fov,this.focal_length||this.fov||(this.focal_length=[[16,2],[17,2.5],[18,3],[19,4],[20,6]]),this.vanishing_point=n.vanishing_point||[0,0],this.vanishing_point=this.vanishing_point.map(parseFloat),this.vanishing_point_skew=[],this.position_meters=null,this.viewMatrix=new Float64Array(16),this.projectionMatrix=new Float32Array(16),c.replaceBlock("camera","\n uniform mat4 u_projection;\n uniform vec3 u_eye;\n uniform vec2 u_vanishing_point;\n\n void cameraProjection (inout vec4 position) {\n position = u_projection * position;\n }")}return o(t,e),a(t,{constrainCamera:{value:function(e){var t=e.view_height,r=e.height,n=e.focal_length,i=e.fov;return r?(n=2*r/t,i=2*Math.atan(1/n)):(n?i=2*Math.atan(1/n):i&&(i=i*Math.PI/180,n=1/Math.tan(i/2)),r=t/2*n),{view_height:t,height:r,focal_length:n,fov:i}}},updateMatrices:{value:function(){var e=this.scene.css_size.height*u.metersPerPixel(this.scene.zoom),t=this.constrainCamera({view_height:e,focal_length:l.interpolate(this.scene.zoom,this.focal_length),fov:l.interpolate(this.scene.zoom,this.fov)}),r=t.height,n=t.fov,i=[this.scene.center_meters.x,this.scene.center_meters.y,r];this.position_meters=i,h.lookAt(this.viewMatrix,p.fromValues(i[0],i[1],0),p.fromValues(i[0],i[1],-1),p.fromValues(0,1,0)),h.perspective(this.projectionMatrix,n,this.scene.view_aspect,1,2*r),this.vanishing_point_skew[0]=this.vanishing_point[0]/this.scene.css_size.width,this.vanishing_point_skew[1]=this.vanishing_point[1]/this.scene.css_size.height,this.projectionMatrix[8]=-this.vanishing_point_skew[0],this.projectionMatrix[9]=-this.vanishing_point_skew[1],h.translate(this.projectionMatrix,this.projectionMatrix,p.fromValues(e/2*this.scene.view_aspect*-this.vanishing_point_skew[0],e/2*-this.vanishing_point_skew[1],0)),h.translate(this.projectionMatrix,this.projectionMatrix,p.fromValues(0,0,-r))}},update:{value:function(){i(Object.getPrototypeOf(t.prototype),"update",this).call(this),this.updateMatrices()}},setupProgram:{value:function(e){e.uniform("Matrix4fv","u_projection",!1,this.projectionMatrix),e.uniform("3f","u_eye",0,0,this.position_meters[2]),e.uniform("2fv","u_vanishing_point",this.vanishing_point_skew)}}}),t}(d),v=function(e){function t(e,r){var n=void 0===arguments[2]?{}:arguments[2];s(this,t),i(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r,n),this.type="isometric",this.axis=n.axis||{x:0,y:1},2===this.axis.length&&(this.axis={x:this.axis[0],y:this.axis[1]}),this.position_meters=null,this.viewport_height=null,this.viewMatrix=new Float64Array(16),this.projectionMatrix=new Float32Array(16),c.replaceBlock("camera","\n uniform mat4 u_projection;\n uniform vec3 u_eye;\n uniform vec2 u_vanishing_point;\n\n void cameraProjection (inout vec4 position) {\n position = u_projection * position;\n // position.xy += position.z * u_isometric_axis;\n\n // Reverse z for depth buffer so up is negative,\n // and scale down values so objects higher than one screen height will not get clipped\n // pull forward slightly to avoid going past far clipping plane\n position.z = -position.z / 100. + 1. - 0.001;\n }")}return o(t,e),a(t,{update:{value:function(){i(Object.getPrototypeOf(t.prototype),"update",this).call(this),this.viewport_height=this.scene.css_size.height*u.metersPerPixel(this.scene.zoom);var e=[this.scene.center_meters.x,this.scene.center_meters.y,this.viewport_height];this.position_meters=e,h.identity(this.viewMatrix),h.translate(this.viewMatrix,this.viewMatrix,p.fromValues(-e[0],-e[1],0)),h.identity(this.projectionMatrix),this.projectionMatrix[8]=this.axis.x/this.scene.view_aspect,this.projectionMatrix[9]=this.axis.y,h.scale(this.projectionMatrix,this.projectionMatrix,p.fromValues(2/this.scene.viewport_meters.x,2/this.scene.viewport_meters.y,2/this.scene.viewport_meters.y))}},setupProgram:{value:function(e){e.uniform("Matrix4fv","u_projection",!1,this.projectionMatrix),e.uniform("3f","u_eye",0,0,this.viewport_height),e.uniform("2f","u_vanishing_point",0,0)}}}),t}(d),g=function(e){function t(e,r){var n=void 0===arguments[2]?{}:arguments[2];s(this,t),i(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r,n),this.type="flat"}return o(t,e),a(t,{update:{value:function(){this.axis.x=0,this.axis.y=0,i(Object.getPrototypeOf(t.prototype),"update",this).call(this)}}}),t}(v)},{"./geo":73,"./gl/shader_program":79,"./utils/utils":118,"gl-matrix":27}],73:[function(e,t,r){"use strict";var n,i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")};t.exports=n={},n.tile_size=256,n.half_circumference_meters=20037508.342789244,n.circumference_meters=2*n.half_circumference_meters,n.min_zoom_meters_per_pixel=n.circumference_meters/n.tile_size,n.meters_per_pixel=[],n.meters_per_tile=[],n.max_zoom=18;for(var o=0;o<=n.max_zoom;o++)n.meters_per_pixel[o]=n.min_zoom_meters_per_pixel/Math.pow(2,o),n.meters_per_tile[o]=n.circumference_meters/Math.pow(2,o);n.metersPerPixel=function(e){return n.min_zoom_meters_per_pixel/Math.pow(2,e)},n.units_per_meter=[],n.tile_scale=4096,n.units_per_pixel=n.tile_scale/n.tile_size;for(var a=0;a<=n.max_zoom;a++)n.units_per_meter[a]=n.tile_scale/(n.tile_size*n.meters_per_pixel[a]);n.metersForTile=function(e){return{x:e.x*n.circumference_meters/Math.pow(2,e.z)-n.half_circumference_meters,y:-(e.y*n.circumference_meters/Math.pow(2,e.z)-n.half_circumference_meters)}},n.tileForMeters=function(e,t){var r=i(e,2),o=r[0],a=r[1];return{x:Math.floor((o+n.half_circumference_meters)/(n.circumference_meters/Math.pow(2,t))),y:Math.floor((-a+n.half_circumference_meters)/(n.circumference_meters/Math.pow(2,t))),z:t}},n.wrapTile=function(e){var t=e.x,r=e.y,n=e.z,i=void 0===arguments[1]?{x:!0,y:!1}:arguments[1],o=(1<180||-180>e)&&(e=((e+180)%360+360)%360-180),e},n.transformGeometry=function(e,t){"Point"===e.type?t(e.coordinates):"LineString"===e.type||"MultiPoint"===e.type?e.coordinates.forEach(t):"Polygon"===e.type||"MultiLineString"===e.type?e.coordinates.forEach(function(e){return e.forEach(t)}):"MultiPolygon"===e.type&&e.coordinates.forEach(function(e){e.forEach(function(e){return e.forEach(t)})})},n.boxIntersect=function(e,t){return!(t.sw.x>e.ne.x||t.ne.xe.ne.y||t.ne.ya;a++){var s=e[0][a];s[0]r&&(r=s[0]),s[1]>i&&(i=s[1])}return[t,n,r,i]},n.geometryType=function(e){return"Polygon"===e||"MultiPolygon"===e?"polygon":"LineString"===e||"MultiLineString"===e?"line":"Point"===e||"MultiPoint"===e?"point":void 0},n.centroid=function(e){for(var t=e.length,r=[0,0],n=0;nn;n++){var i=e[n],o=e[n+1];t+=i[0]*o[1]-o[0]*i[1]}return t+=e[r-1][0]*e[0][1]-e[0][0]*e[r-1][1]},n.polygonArea=function(e){return Math.abs(n.signedPolygonAreaSum(e))/2},n.multiPolygonArea=function(e){for(var t=0,r=0;r0?"CW":"CCW"},n.enforceWinding=function(e,t){var r=void 0;if("Polygon"===e.type)r=[e.coordinates];else{if("MultiPolygon"!==e.type)return e;r=e.coordinates}for(var i=0;i=2&&u.length<=4?r.push({type:"vec"+u.length,method:u.length+"fv",name:o,value:u,key:s,uniforms:e}):u.length>4&&r.push({type:"float[]",method:"1fv",name:o+"[0]",value:u,key:s,uniforms:e});else if("string"==typeof u[0])for(a=0;a=2&&u[0].length<=4)for(a=0;a=2&&t.length<=4?r="vec"+t.length:(r="float",n=t.length):"string"==typeof t[0]?(r="sampler2D",n=t.length):Array.isArray(t[0])&&"number"==typeof t[0][0]?(t[0].length>=2&&t[0].length<=4&&(r="vec"+t[0].length),n=t[0].length):"object"==typeof t[0]&&(r="_type_"+o,n=t.length,a+=i.defineStruct(r,t[0],o)+"\n"):"boolean"==typeof t?r="bool":"string"==typeof t?r="sampler2D":"object"==typeof t&&(r="_type_"+o,a+=i.defineStruct(r,t,o)+"\n");var s="";return s+=""+r+" "+e,n&&(s+="["+n+"]"),s+=";\n",{variable:s,structs:a}},i.defineStruct=function(e,t){var r=void 0===arguments[2]?null:arguments[2],n="struct "+e+" {\n",o="";for(var a in t){var s=i.defineVariable(a,t[a],r);n+=" "+s.variable,o+=s.structs}return n+="};\n",n=o+n},i.defineUniform=function(e,t){var r=i.defineVariable(e,t);return r=r.structs+"uniform "+r.variable},i.isUniformDefined=function(e,t){var r=new RegExp("uniform[^;]+(?:{[\\s\\S]*})?[^;]*\\b"+e+"\\b","g");return t.match(r)?!0:!1},i.isSymbolReferenced=function(e,t){var r=new RegExp("\\b"+e+"\\b","g");return t.search(r)>=0?!0:!1},i.expandVec3=function(e){var t=void 0===arguments[1]?1:arguments[1],r=void 0;return r=Array.isArray(e)&&2===e.length?[].concat(n(e),[t]).map(parseFloat):[e,e,e].map(parseFloat),r&&r.every(function(e){return"number"==typeof e&&!isNaN(e)})?r:void 0},i.expandVec4=function(e){var t=void 0===arguments[1]?1:arguments[1],r=void 0;return r=Array.isArray(e)&&3===e.length?[].concat(n(e),[t]).map(parseFloat):[e,e,e,t].map(parseFloat),r&&r.every(function(e){return"number"==typeof e&&!isNaN(e)})?r:void 0}},{}],78:[function(e,t,r){"use strict";var n=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),i=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},o=function(){function e(t,r){i(this,e),r(t),this.value=t,this.setup=r}return n(e,{set:{value:function(e){JSON.stringify(this.value)!==JSON.stringify(e)&&(this.setup(e),this.value=e)}}},{initialize:{value:function(t){e.culling=new e({cull:!0,face:t.BACK},function(e){e.cull?(t.enable(t.CULL_FACE),t.cullFace(e.face)):t.disable(t.CULL_FACE)}),e.blending=new e({blend:!1,src:t.SRC_ALPHA,dst:t.ONE_MINUS_SRC_ALPHA},function(e){e.blend?(t.enable(t.BLEND),t.blendFunc(e.src,e.dst)):t.disable(t.BLEND)}),e.depth_write=new e({depth_write:!0},function(e){t.depthMask(e.depth_write)}),e.depth_test=new e({depth_test:!0,depth_func:t.LEQUAL},function(e){e.depth_test?(t.enable(t.DEPTH_TEST),t.depthFunc(e.depth_func)):t.disable(t.DEPTH_TEST)})}}}),e}();t.exports=o},{}],79:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);t0&&(this.computed_vertex_source=i.join("\n")+this.computed_vertex_source),o.length>0&&(this.computed_fragment_source=o.join("\n")+this.computed_fragment_source)}}},setUniforms:{value:function(e){var t=void 0===arguments[1]?!0:arguments[1];if(this.compiled){t&&(this.texture_unit=0);var r=s.parseUniforms(e),n=!0,i=!1,o=void 0;try{for(var a,u=r[Symbol.iterator]();!(n=(a=u.next()).done);n=!0){var l=a.value;"sampler2D"===l.type?this.setTextureUniform(l.name,l.value):this.uniform(l.method,l.name,l.value)}}catch(c){i=!0,o=c}finally{try{!n&&u["return"]&&u["return"]()}finally{if(i)throw o}}}}},saveUniforms:{value:function(e){var t=e||this.uniforms;for(var r in t){var n=this.uniforms[r];n&&(n.saved_value=n.value)}this.saved_texture_unit=this.texture_unit||0}},restoreUniforms:{value:function(e){var t=e||this.uniforms;for(var r in t){var n=this.uniforms[r];n&&n.saved_value&&(n.value=n.saved_value,this.updateUniform(r))}this.texture_unit=this.saved_texture_unit||0}},setTextureUniform:{value:function(e,t){var r=u.textures[t];null==r&&(r=new u(this.gl,t),r.load(t)),r.bind(this.texture_unit),this.uniform("1i",e,this.texture_unit),this.texture_unit++}},uniform:{value:function t(e,r){for(var n=arguments.length,i=Array(n>2?n-2:0),o=2;n>o;o++)i[o-2]=arguments[o];if(this.compiled){this.uniforms[r]=this.uniforms[r]||{};var t=this.uniforms[r];t.name=r,void 0===t.location&&(t.location=this.gl.getUniformLocation(this.program,r)),t.method="uniform"+e,t.value=i,this.updateUniform(r)}}},updateUniform:{value:function(e){if(this.compiled){var t=this.uniforms[e];t&&null!=t.location&&(this.use(),this.gl[t.method].apply(this.gl,[t.location].concat(t.value)))}}},refreshUniforms:{value:function(){if(this.compiled)for(var e in this.uniforms)this.uniforms[e].location=this.gl.getUniformLocation(this.program,e),this.updateUniform(e)}},refreshAttributes:{value:function(){this.attribs={}}},attribute:{value:function(e){if(this.compiled){var t=this.attribs[e]=this.attribs[e]||{};return null!=t.location?t:(t.name=e,t.location=this.gl.getAttribLocation(this.program,e),t)}}},source:{value:function(e){return"vertex"===e?this.computed_vertex_source:"fragment"===e?this.computed_fragment_source:void 0}},lines:{value:function(e){var t=this.source(e);return t?t.split("\n"):[]}},line:{value:function(e,t){var r=this.lines(e);return r?r[t]:void 0}},block:{value:function r(e,t){for(var n=this.lines(e),r=void 0,i=0;t>i&&i1?r={scope:a[1],name:a[2],num:a[3]}:(a=o.match(/\/\/ tangram-block-end: (\w+), (\w+), (\d+)/),a&&a.length>1&&(r=null)),r&&(r.line=null==r.line?-1:r.line+1,r.source=o)}return r}},checkExtensions:{value:function(){var e=[],t=!0,r=!1,n=void 0;try{for(var i,o=this.extensions[Symbol.iterator]();!(t=(i=o.next()).done);t=!0){var a=i.value,s=l(this.gl,a),u="TANGRAM_EXTENSION_"+a;this.defines[u]=null!=s,s?e.push(a):c.debug("Could not enable extension '"+a+"'")}}catch(f){r=!0,n=f}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}return e}}}),e}();t.exports=p,p.id=0,p.programs={},p.current=null,p.defines={},p.blocks={},p.buildDefineString=function(e){var t="";for(var r in e)e[r]!==!1&&(t+="boolean"==typeof e[r]&&e[r]===!0?"#define "+r+"\n":"number"==typeof e[r]&&Math.floor(e[r])===e[r]?"#define "+r+" "+e[r].toFixed(1)+"\n":"#define "+r+" "+e[r]+"\n");return t},p.buildExtensionString=function(e){e=e||[];var t="",r=!0,n=!1,i=void 0;try{for(var o,a=e[Symbol.iterator]();!(r=(o=a.next()).done);r=!0){var s=o.value;t+="#extension GL_"+s+" : enable\n"}}catch(u){n=!0,i=u}finally{try{!r&&a["return"]&&a["return"]()}finally{if(n)throw i}}return t},p.addBlock=function(e){for(var t,r=arguments.length,n=Array(r>1?r-1:0),i=1;r>i;i++)n[i-1]=arguments[i];p.blocks[e]=p.blocks[e]||[],(t=p.blocks[e]).push.apply(t,n)},p.removeBlock=function(e){p.blocks[e]=[]},p.replaceBlock=function(e){for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];p.removeBlock(e),p.addBlock.apply(p,[e].concat(r))},p.updateProgram=function(e,t,r,n){try{var i=p.createShader(e,r,e.VERTEX_SHADER),o=p.createShader(e,n,e.FRAGMENT_SHADER)}catch(a){throw c.error(a.message),a}if(e.useProgram(null),null!=t)for(var s=e.getAttachedShaders(t),u=0;u0?(this.buffer=e.array_pool.pop(),this.buffer_length=this.buffer.byteLength,this.buffer_size=Math.floor(this.buffer_length/this.vertex_layout.stride),l("trace","VertexData: reused buffer of bytes "+this.buffer_length+", "+this.buffer_size+" vertices")):(this.buffer_size=n||500,this.buffer_length=this.vertex_layout.stride*this.buffer_size,this.buffer=new Uint8Array(this.buffer_length)),this.buffer_offset=0,this.components=[];var o=!0,a=!1,u=void 0;try{for(var c,f=this.vertex_layout.components[Symbol.iterator]();!(o=(c=f.next()).done);o=!0){var h=c.value;this.components.push([].concat(i(h)))}}catch(p){a=!0,u=p}finally{try{!o&&f["return"]&&f["return"]()}finally{if(a)throw u}}this.vertex_count=0,this.realloc_count=0,this.setBufferViews()}return a(e,{setBufferViews:{value:function(){this.buffer_views={},this.buffer_views[u.UNSIGNED_BYTE]=this.buffer;var e=!0,t=!1,r=void 0;try{for(var n,i=this.vertex_layout.attribs[Symbol.iterator]();!(e=(n=i.next()).done);e=!0){var o=n.value;if(null==this.buffer_views[o.type]){var a=c[o.type];this.buffer_views[o.type]=new a(this.buffer.buffer)}}}catch(s){t=!0,r=s}finally{try{!e&&i["return"]&&i["return"]()}finally{if(t)throw r}}var l=!0,f=!1,h=void 0;try{for(var p,d=this.components[Symbol.iterator]();!(l=(p=d.next()).done);l=!0){var m=p.value;m[1]=this.buffer_views[m[0]]}}catch(s){f=!0,h=s}finally{try{!l&&d["return"]&&d["return"]()}finally{if(f)throw h}}}},checkBufferSize:{value:function(){if(this.buffer_offset+this.vertex_layout.stride>this.buffer_length){this.buffer_size=Math.floor(1.5*this.buffer_size),this.buffer_size-=this.buffer_size%4,this.buffer_length=this.vertex_layout.stride*this.buffer_size;var t=new Uint8Array(this.buffer_length);t.set(this.buffer),e.array_pool.push(this.buffer),this.buffer=t,this.setBufferViews(),this.realloc_count++}}},addVertex:{value:function(e){this.checkBufferSize();for(var t=0,r=this.components.length,n=0;r>n;n++){var i=this.components[n];i[1][(this.buffer_offset>>i[2])+i[3]]=e[t++]}this.buffer_offset+=this.vertex_layout.stride,this.vertex_count++}},end:{value:function(){return this.buffer=this.buffer.subarray(0,this.buffer_offset),l("trace","VertexData: "+this.buffer_size+" vertices total, realloc count "+this.realloc_count),this}}}),e}();t.exports=f,f.array_pool=[]},{"../utils/utils":118,"./constants":74}],85:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("./constants")),s=n(e("./vertex_data")),u=function(){function e(t){o(this,e),this.attribs=t,this.components=[],this.index={},this.stride=0;var r=0,n=!0,i=!1,s=void 0;try{for(var u,l=this.attribs[Symbol.iterator]();!(n=(u=l.next()).done);n=!0){var c=u.value;c.offset=this.stride,c.byte_size=c.size;var f=0;switch(c.type){case a.FLOAT:case a.INT:case a.UNSIGNED_INT:c.byte_size*=4,f=2;break;case a.SHORT:case a.UNSIGNED_SHORT:c.byte_size*=2,f=1}this.stride+=c.byte_size,3&this.stride&&(this.stride+=4-(3&this.stride));var h=c.offset>>f;if(c.size>1)for(var p=0;p0){var n={};for(var i in t)n[t[i].type]=!0;for(var o in n)e.types[o].inject();for(var i in t)t[i].inject(),r+="calculateLight("+i+", _eyeToPoint, _normal);\n"}else r="\n #ifdef TANGRAM_MATERIAL_DIFFUSE\n light_accumulator_diffuse = vec4(1.);\n #endif\n ";var a="\n vec4 calculateLighting(in vec3 _eyeToPoint, in vec3 _normal, in vec4 _color) {\n\n // Do initial material calculations over normal, emission, ambient, diffuse and specular values\n calculateMaterial(_eyeToPoint,_normal);\n\n // Un roll the loop of individual ligths to calculate\n "+r+"\n\n // Final light intensity calculation\n vec4 color = vec4(0.0);\n\n #ifdef TANGRAM_MATERIAL_EMISSION\n color = material.emission;\n #endif\n\n #ifdef TANGRAM_MATERIAL_AMBIENT\n color += light_accumulator_ambient * _color * material.ambient;\n #else\n #ifdef TANGRAM_MATERIAL_DIFFUSE\n color += light_accumulator_ambient * _color * material.diffuse;\n #endif\n #endif\n\n #ifdef TANGRAM_MATERIAL_DIFFUSE\n color += light_accumulator_diffuse * _color * material.diffuse;\n #endif\n\n #ifdef TANGRAM_MATERIAL_SPECULAR\n color += light_accumulator_specular * material.specular;\n #endif\n\n // Clamp final color\n color = clamp(color, 0.0, 1.0);\n\n return color;\n }";l.addBlock(e.block,a)}}}}),e}();t.exports=d,d.types={},d.block="lighting",d.enabled=!0;var m=function(e){function t(e,r){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r),this.type="ambient",this.struct_name="AmbientLight"}return a(t,e),s(t,{setupProgram:{value:function(e){e.uniform("4fv","u_"+this.name+".ambient",this.ambient)}}},{inject:{value:function(){l.addBlock(d.block,c["gl/shaders/ambientLight"])}}}),t}(d);d.types.ambient=m;var v=function(e){function t(e,r){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r),this.type="directional",this.struct_name="DirectionalLight",this.direction=(r.direction||[.2,.7,-.5]).map(parseFloat)}return a(t,e),s(t,{setupProgram:{value:function(e){o(Object.getPrototypeOf(t.prototype),"setupProgram",this).call(this,e),e.uniform("3fv","u_"+this.name+".direction",this.direction)}}},{inject:{value:function(){l.addBlock(d.block,c["gl/shaders/directionalLight"])}}}),t}(d);d.types.directional=v;var g=function(e){function t(e,r){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r),this.type="point",this.struct_name="PointLight",this.position=r.position||[0,0,0],this.position_eye=[],this.origin=r.origin||"world",this.attenuation=isNaN(parseFloat(r.attenuation))?0:parseFloat(r.attenuation),r.radius?Array.isArray(r.radius)&&2===r.radius.length?this.radius=r.radius:this.radius=[null,r.radius]:this.radius=null}return a(t,e),s(t,{inject:{value:function(){o(Object.getPrototypeOf(t.prototype),"inject",this).call(this),l.defines.TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT=0!==this.attenuation,l.defines.TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS=null!=this.radius&&null!=this.radius[0],l.defines.TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS=null!=this.radius}},update:{value:function(){this.updateEyePosition()}},updateEyePosition:{value:function(){if("world"===this.origin){var e=h.latLngToMeters(this.position),t=i(e,2),r=t[0],n=t[1];this.position_eye[0]=r-this.scene.camera.position_meters[0],this.position_eye[1]=n-this.scene.camera.position_meters[1],this.position_eye[2]=p.convertUnits(this.position[2],{zoom:this.scene.zoom}),this.position_eye[2]=this.position_eye[2]-this.scene.camera.position_meters[2]}("ground"===this.origin||"camera"===this.origin)&&(this.position_eye=p.convertUnits(this.position,{zoom:this.scene.zoom}),"ground"===this.origin&&(this.position_eye[2]=this.position_eye[2]-this.scene.camera.position_meters[2]))}},setupProgram:{value:function(e){o(Object.getPrototypeOf(t.prototype),"setupProgram",this).call(this,e),e.uniform("4f","u_"+this.name+".position",this.position_eye[0],this.position_eye[1],this.position_eye[2],1),l.defines.TANGRAM_POINTLIGHT_ATTENUATION_EXPONENT&&e.uniform("1f","u_"+this.name+".attenuationExponent",this.attenuation),l.defines.TANGRAM_POINTLIGHT_ATTENUATION_INNER_RADIUS&&e.uniform("1f","u_"+this.name+".innerRadius",p.convertUnits(this.radius[0],{zoom:this.scene.zoom})),l.defines.TANGRAM_POINTLIGHT_ATTENUATION_OUTER_RADIUS&&e.uniform("1f","u_"+this.name+".outerRadius",p.convertUnits(this.radius[1],{zoom:this.scene.zoom}))}}},{inject:{value:function(){l.addBlock(d.block,c["gl/shaders/pointLight"])}}}),t}(d);d.types.point=g;var y=function(e){function t(e,r){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,r),this.type="spotlight",this.struct_name="SpotLight",this.direction=(r.direction||[0,0,-1]).map(parseFloat),this.exponent=r.exponent?parseFloat(r.exponent):.2,this.angle=r.angle?parseFloat(r.angle):20}return a(t,e),s(t,{setupProgram:{value:function(e){o(Object.getPrototypeOf(t.prototype),"setupProgram",this).call(this,e),e.uniform("3fv","u_"+this.name+".direction",this.direction),e.uniform("1f","u_"+this.name+".spotCosCutoff",Math.cos(3.14159*this.angle/180)),e.uniform("1f","u_"+this.name+".spotExponent",this.exponent)}}},{inject:{value:function(){l.addBlock(d.block,c["gl/shaders/spotLight"])}}}),t}(g);d.types.spotlight=y},{"./geo":73,"./gl/glsl":77,"./gl/shader_program":79,"./gl/shader_sources":80,"./styles/style_parser":105}],88:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("./gl/shader_sources")),s=n(e("./gl/glsl")),u=e("./styles/style_parser").StyleParser,l=function(){function e(t){o(this,e),t=t||{};var r=!0,n=!1,i=void 0;try{for(var a,l=["emission","ambient","diffuse","specular"][Symbol.iterator]();!(r=(a=l.next()).done);r=!0){var c=a.value;null!=t[c]&&(t[c].texture?this[c]={texture:t[c].texture,mapping:t[c].mapping||"spheremap",scale:s.expandVec3(null!=t[c].scale?t[c].scale:1),amount:s.expandVec4(null!=t[c].amount?t[c].amount:1)}:"number"==typeof t[c]?this[c]={amount:s.expandVec4(t[c])}:"string"==typeof t[c]?this[c]={amount:u.parseColor(t[c])}:this[c]=t[c])}}catch(f){n=!0,i=f}finally{try{!r&&l["return"]&&l["return"]()}finally{if(n)throw i}}this.specular&&(this.specular.shininess=t.shininess?parseFloat(t.shininess):.2),null!=t.normal&&(this.normal={texture:t.normal.texture,mapping:t.normal.mapping||"triplanar",scale:s.expandVec3(null!=t.normal.scale?t.normal.scale:1),amount:null!=t.normal.amount?t.normal.amount:1})}return i(e,{inject:{value:function(t){var r=!0,n=!1,i=void 0;try{for(var o,s=["emission","ambient","diffuse","specular"][Symbol.iterator]();!(r=(o=s.next()).done);r=!0){var u=o.value,l="TANGRAM_MATERIAL_"+u.toUpperCase(),c=l+"_TEXTURE";t.defines[l]=null!=this[u],this[u]&&this[u].texture&&(t.defines[c]=!0,t.defines[c+"_"+this[u].mapping.toUpperCase()]=!0,t.defines["TANGRAM_MATERIAL_TEXTURE_"+this[u].mapping.toUpperCase()]=!0,t.texcoords=t.texcoords||"uv"===this[u].mapping)}}catch(f){n=!0,i=f}finally{try{!r&&s["return"]&&s["return"]()}finally{if(n)throw i}}this.normal&&this.normal.texture&&(t.defines.TANGRAM_MATERIAL_NORMAL_TEXTURE=!0,t.defines["TANGRAM_MATERIAL_NORMAL_TEXTURE_"+this.normal.mapping.toUpperCase()]=!0,t.defines["TANGRAM_MATERIAL_TEXTURE_"+this.normal.mapping.toUpperCase()]=!0,t.texcoords=t.texcoords||"uv"===this.normal.mapping),t.replaceShaderBlock(e.block,a["gl/shaders/material"],"Material")}},setupProgram:{value:function(e){var t=!0,r=!1,n=void 0;try{for(var i,o=["emission","ambient","diffuse","specular"][Symbol.iterator]();!(t=(i=o.next()).done);t=!0){var a=i.value;this[a]&&(this[a].texture?(e.setTextureUniform("u_material_"+a+"_texture",this[a].texture),e.uniform("3fv","u_material."+a+"Scale",this[a].scale),e.uniform("4fv","u_material."+a,this[a].amount)):this[a].amount&&e.uniform("4fv","u_material."+a,this[a].amount))}}catch(s){r=!0,n=s}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}this.specular&&e.uniform("1f","u_material.shininess",this.specular.shininess),this.normal&&this.normal.texture&&(e.setTextureUniform("u_material_normal_texture",this.normal.texture),e.uniform("3fv","u_material.normalScale",this.normal.scale),e.uniform("1f","u_material.normalAmount",this.normal.amount))}}},{isValid:{value:function(e){return null==e?!1:null==e.emission&&null==e.ambient&&null==e.diffuse&&null==e.specular?!1:!0}}}),e}();t.exports=l,l.block="material"},{"./gl/glsl":77,"./gl/shader_sources":80,"./styles/style_parser":105}],89:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=n(e("./utils/utils")),o=e("./leaflet_layer"),a=o.LeafletLayer,s=o.leafletLayer,u=e("../src/scene_worker").SceneWorker,l=n(e("./utils/version")),c=n(e("loglevel")),f=n(e("./geo")),h=n(e("./sources/data_source"));e("./sources/geojson"),e("./sources/topojson"),e("./sources/mvt");var p=n(e("./tile_manager")),d=n(e("./gl/glsl")),m=n(e("./gl/shader_program")),v=n(e("./gl/vertex_data")),g=n(e("./gl/texture")),y=n(e("./material")),_=n(e("./light")),b=n(e("./utils/worker_broker")),x=e("./styles/rule").ruleCache,w=e("./styles/style_manager").StyleManager,A=e("./styles/style_parser").StyleParser,E=n(e("./selection")),T=n(e("js-yaml")),S=n(e("gl-matrix"));S.glMatrix.setMatrixArrayType(Float64Array);var M={log:c,yaml:T,Utils:i,Geo:f,DataSource:h,TileManager:p,GLSL:d,ShaderProgram:m,VertexData:v,Texture:g,Material:y,Light:_,SceneWorker:u,WorkerBroker:b,ruleCache:x,StyleManager:w,StyleParser:A,FeatureSelection:E};i.isMainThread&&(b.addTarget("Texture",g),window.Tangram=t.exports={LeafletLayer:a,leafletLayer:s,debug:M,version:l.string}),i.isWorkerThread&&(self.Tangram={debug:M,version:l.string}),i.isMainThread&&i.requestAnimationFramePolyfill();var k=c.methodFactory;c.methodFactory=function(e,t){var r=k(e,t);return function(){for(var e=arguments.length,t=Array(e),n=0;e>n;n++)t[n]=arguments[n];r.apply(void 0,["Tangram "+l.string+":"].concat(t))}}},{"../src/scene_worker":92,"./geo":73,"./gl/glsl":77,"./gl/shader_program":79,"./gl/texture":81,"./gl/vertex_data":84,"./leaflet_layer":86,"./light":87,"./material":88,"./selection":93,"./sources/data_source":94,"./sources/geojson":95,"./sources/mvt":96,"./sources/topojson":97,"./styles/rule":102,"./styles/style_manager":104,"./styles/style_parser":105,"./tile_manager":114,"./utils/utils":118,"./utils/version":119,"./utils/worker_broker":120,"gl-matrix":27,"js-yaml":29,loglevel:60}],90:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")},o=function(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);te.preserve_tiles_within_zoom)return!0;var a=Math.pow(2,o),s={x:Math.floor(i.coords.x/a),y:Math.floor(i.coords.y/a)};return Math.abs(s.x-e.center_tile.x)-r[0]>t?(k.trace("Scene: remove tile "+i.key+" (as "+s.x+"/"+s.y+"/"+n+") for being too far out of visible area ***"),!0):Math.abs(s.y-e.center_tile.y)-r[1]>t?(k.trace("Scene: remove tile "+i.key+" (as "+s.x+"/"+s.y+"/"+n+") for being too far out of visible area ***"),!0):!1})}}},resizeMap:{value:function(e,t){this.dirty=!0,this.css_size={width:e,height:t},this.device_size={width:Math.round(this.css_size.width*l.device_pixel_ratio),height:Math.round(this.css_size.height*l.device_pixel_ratio)},this.view_aspect=this.css_size.width/this.css_size.height,this.updateBounds(),this.canvas&&(this.canvas.style.width=this.css_size.width+"px",this.canvas.style.height=this.css_size.height+"px",this.canvas.width=this.device_size.width,this.canvas.height=this.device_size.height,this.gl&&(this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null),this.gl.viewport(0,0,this.canvas.width,this.canvas.height)))}},requestRedraw:{value:function(){this.dirty=!0}},immediateRedraw:{value:function(){this.dirty=!0,this.update()}},renderLoop:{value:function(){this.render_loop_active=!0,this.initialized&&this.update(),this.render_loop_stop?(this.render_loop_stop=!1,this.render_loop_active=!1):window.requestAnimationFrame(this.renderLoop.bind(this))}},setupRenderLoop:{value:function(){var e=this;this.render_loop_active||setTimeout(function(){e.renderLoop()},0)}},update:{value:function(){this.tile_manager.loadQueuedCoordinates();var e=!(this.dirty===!1||this.initialized===!1||this.updating>0||this.viewReady()===!1);return"function"==typeof this.preUpdate&&this.preUpdate(e),e?(this.dirty=!1,this.render(),"function"==typeof this.postUpdate&&this.postUpdate(e),this.animated===!0&&(this.dirty=!0),this.frame++,k.trace("Scene.render()"),!0):!1}},render:{value:function(){var e=this,t=this.gl;if(this.center_meters){if(this.camera.update(),Object.keys(this.active_styles).forEach(function(t){return e.styles[t].update()}),Object.keys(this.lights).forEach(function(t){return e.lights[t].update()}),this.renderable_tiles=this.tile_manager.getRenderableTiles(),this.renderable_tiles_count=this.renderable_tiles.length,this.render_count=this.renderPass(),this.selection.pendingRequests()){if(this.panning)return;this.selection.bind(),this.renderPass("selection_program",{allow_alpha_blend:!1}),this.selection.read(),t.bindFramebuffer(t.FRAMEBUFFER,null),t.viewport(0,0,this.canvas.width,this.canvas.height)}return this.render_count!==this.last_render_count&&this.getFeatureSelectionMapSize().then(function(t){k.info("Scene: rendered "+e.render_count+" primitives ("+t+" features in selection map)")},function(){}),this.last_render_count=this.render_count,!0}}},renderPass:{value:function(){var e=this,t=void 0===arguments[0]?"program":arguments[0],r=void 0===arguments[1]?{}:arguments[1],n=r.allow_alpha_blend,i=void 0,o=0;return n=null==n?!0:n,this.clearFrame({clear_color:!0,clear_depth:!0}),i=Object.keys(this.active_styles).filter(function(t){return"opaque"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!0,alpha_blend:!1}),o+=this.renderStyles(i,t)),i=Object.keys(this.active_styles).filter(function(t){return"add"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n&&"add"}),o+=this.renderStyles(i,t)),i=Object.keys(this.active_styles).filter(function(t){return"multiply"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n&&"multiply"}),o+=this.renderStyles(i,t)),i=Object.keys(this.styles).filter(function(t){return"inlay"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n}),o+=this.renderStyles(i,t)),i=Object.keys(this.styles).filter(function(t){return"overlay"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!1,depth_write:!1,alpha_blend:n}),o+=this.renderStyles(i,t)),o}},renderStyles:{value:function(e,t){var r=0,n=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(n=(a=s.next()).done);n=!0){var u=a.value,l=this.styles[u][t];l&&l.compiled&&(r+=this.renderStyle(u,l))}}catch(c){i=!0,o=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(i)throw o}}return r}},renderStyle:{value:function(e,t){var r=!0,n=0;for(var i in this.renderable_tiles){var o=this.renderable_tiles[i];if(null!=o.meshes[e]){if(r===!0){r=!1,t.use(),this.styles[e].setup(),t.uniform("2f","u_resolution",this.device_size.width,this.device_size.height),t.uniform("1f","u_time",(+new Date-this.start_time)/1e3),t.uniform("3f","u_map_position",this.center_meters.x,this.center_meters.y,this.zoom),t.uniform("1f","u_meters_per_pixel",this.meters_per_pixel),t.uniform("1f","u_device_pixel_ratio",l.device_pixel_ratio),P.normalFromMat4(this.normalMatrix32,this.modelViewMatrix32),t.uniform("Matrix3fv","u_normalMatrix",!1,this.normalMatrix32),this.camera.setupProgram(t);for(var a in this.lights)this.lights[a].setupProgram(t)}t.uniform("3f","u_tile_origin",o.min.x,o.min.y,o.style_zoom),I.identity(this.modelMatrix),I.translate(this.modelMatrix,this.modelMatrix,L.fromValues(o.min.x,o.min.y,0)),I.scale(this.modelMatrix,this.modelMatrix,L.fromValues(o.span.x/u.tile_scale,-1*o.span.y/u.tile_scale,1)),I.copy(this.modelMatrix32,this.modelMatrix),t.uniform("Matrix4fv","u_model",!1,this.modelMatrix32),I.multiply(this.modelViewMatrix32,this.camera.viewMatrix,this.modelMatrix),t.uniform("Matrix4fv","u_modelView",!1,this.modelViewMatrix32),o.meshes[e].render(),n+=o.meshes[e].geometry_count}}return n}},clearFrame:{value:function(){var e=void 0===arguments[0]?{}:arguments[0],t=e.clear_color,r=e.clear_depth;if(this.initialized){t=t===!1?!1:!0,r=r===!1?!1:!0;var n=this.gl;if(t&&n.clearColor.apply(n,o(this.background.color)),r&&n.depthMask(!0),t||r){var i=(t&&n.COLOR_BUFFER_BIT)|(r&&n.DEPTH_BUFFER_BIT);n.clear(i)}}}},setRenderState:{value:function(){var e=void 0===arguments[0]?{}:arguments[0],t=e.depth_test,r=e.depth_write,n=e.cull_face,i=e.alpha_blend;if(this.initialized){t=t===!1?!1:!0,r=r===!1?!1:!0,n=n===!1?!1:!0,i=null!=i?i:!1;var o=this.gl;A.depth_test.set({depth_test:t,depth_func:o.LEQUAL}),A.depth_write.set({depth_write:r}),A.culling.set({cull:n,face:o.BACK}),i?i===!0?A.blending.set({blend:!0,src:o.SRC_ALPHA,dst:o.ONE_MINUS_SRC_ALPHA}):"add"===i?A.blending.set({blend:!0,src:o.ONE,dst:o.ONE}):"multiply"===i&&A.blending.set({blend:!0,src:o.ZERO,dst:o.SRC_COLOR}):A.blending.set({blend:!1,src:null,dst:null})}}},getFeatureAt:{value:function(e){if(!this.initialized)return k.debug("Scene.getFeatureAt() called before scene was initialized"),Promise.resolve();var t={x:e.x*l.device_pixel_ratio/this.device_size.width,y:e.y*l.device_pixel_ratio/this.device_size.height};return this.dirty=!0,this.selection.getFeatureAt(t)}},rebuild:{value:function(){return this.rebuildGeometry()}},rebuildGeometry:{value:function(){var e=this;return new Promise(function(t,r){if(e.building)return e.building.queued&&e.building.queued.reject&&(k.debug("Scene.rebuildGeometry: request superceded by a newer call"),e.building.queued.resolve(!1)),e.building.queued={resolve:t,reject:r},void k.trace("Scene.rebuildGeometry(): queuing request");e.building={resolve:t,reject:r},e.debug.profile.geometry_build&&e._profile("rebuildGeometry"),e.syncConfigToWorker(),m.compile(e.updateActiveStyles(),e),e.resetFeatureSelection(),e.resetTime();var n=[];e.tile_manager.forEachTile(function(t){t.visible?n.push(t):e.tile_manager.removeTile(t.key)}),e.tile_manager.buildTiles(n)}).then(function(){e.debug.profile.geometry_build&&e._profileEnd("rebuildGeometry")})}},tileManagerBuildDone:{value:function(){if(this.building){k.info("Scene: build geometry finished"),this.building.resolve&&this.building.resolve(!0);var e=this.building.queued;this.building=null,e&&(k.debug("Scene: starting queued rebuildGeometry() request"),this.rebuildGeometry().then(e.resolve,e.reject))}}},loadScene:{value:function(){var e=this,t=void 0===arguments[0]?null:arguments[0],r=void 0===arguments[1]?null:arguments[1];return this.config_source=t||this.config_source,"string"==typeof this.config_source?this.config_path=r||l.pathForURL(this.config_source):this.config_path=null,g.loadScene(this.config_source,this.config_path).then(function(t){return e.config=t,e.trigger("load",{config:e.config}),e.config})}},loadDataSources:{value:function(){for(var e in this.config.sources){var t=this.config.sources[e];this.sources[e]=x.create(Object.assign({},t,{name:e})),this.sources[e]||(delete this.sources[e],k.warn("Scene: could not create data source",t),this.trigger("warning",{type:"sources",source:t,message:"Could not create data source"}))}}},loadTextures:{value:function(){return p.createFromObject(this.gl,this.config.textures)}},updateStyles:{value:function(){if(!this.initialized&&!this.initializing)throw new Error("Scene.updateStyles() called before scene was initialized");m.init(),this.styles=m.build(this.config.styles,this);var e=!0,t=!1,r=void 0;try{for(var n,i=l.values(this.styles)[Symbol.iterator]();!(e=(n=i.next()).done);e=!0){var o=n.value;o.setGL(this.gl)}}catch(a){t=!0,r=a}finally{try{!e&&i["return"]&&i["return"]()}finally{if(t)throw r}}this.updateActiveStyles(),m.compile(Object.keys(this.active_styles),this),this.dirty=!0}},updateActiveStyles:{value:function(){var e=this,t=Object.keys(this.active_styles||{});this.active_styles={};var r=!1,n=!0,o=!1,a=void 0;try{for(var s,u=l.recurseValues(this.config.layers)[Symbol.iterator]();!(n=(s=u.next()).done);n=!0){var c=s.value;if(c.draw){var f=!0,h=!1,p=void 0;try{for(var d,m=l.entries(c.draw)[Symbol.iterator]();!(f=(d=m.next()).done);f=!0){var v=i(d.value,2),g=v[0],y=v[1];"object"==typeof y&&y.visible!==!1&&!function(){var t=y.style||g,n=[t];y.outline&&y.outline.style&&n.push(y.outline.style),n=n.filter(function(t){return e.styles[t]}).forEach(function(t){var n=e.styles[t];n&&(e.active_styles[t]=!0,n.animated&&(r=!0))})}()}}catch(_){h=!0,p=_}finally{try{!f&&m["return"]&&m["return"]()}finally{if(h)throw p}}}}}catch(_){o=!0,a=_}finally{try{!n&&u["return"]&&u["return"]()}finally{if(o)throw a}}return this.animated=void 0!==this.config.scene.animated?this.config.scene.animated:r,Object.keys(this.active_styles).filter(function(e){return-1===t.indexOf(e)})}},createCamera:{value:function(){var e=this._active_camera;e&&(this.camera=y.create(e,this,this.config.cameras[this._active_camera]),this.camera.updateScene())}},getActiveCamera:{value:function(){return this._active_camera}},setActiveCamera:{value:function(e){return this._active_camera=e,this.updateConfig(),this._active_camera}},_active_camera:{get:function(){if(this.config&&this.config.cameras)for(var e in this.config.cameras)if(this.config.cameras[e].active)return e},set:function(e){var t=this._active_camera;this.config.cameras[e]&&(this.config.cameras[e].active=!0,t&&t!==e&&this.config.cameras[t]&&delete this.config.cameras[t].active)}},createLights:{value:function(){this.lights={};for(var e in this.config.lights)if(this.config.lights[e]&&"object"==typeof this.config.lights[e]){var t=this.config.lights[e];t.name=e.replace("-","_"),t.visible=t.visible===!1?!1:!0,t.visible&&(this.lights[t.name]=_.create(this,t))}_.inject(this.lights)}},setBackground:{value:function(){var e=this.config.scene.background;this.background={},e&&e.color&&(this.background.color=v.parseColor(e.color)),this.background.color||(this.background.color=[0,0,0,1])}},updateConfig:{value:function(){var e=this,t=void 0===arguments[0]?{}:arguments[0],r=t.rebuild;return this.generation++,this.updating++,this.config.scene=this.config.scene||{},this.createCamera(),this.createLights(),this.loadDataSources(),this.loadTextures(),this.setBackground(),this.updateBounds(),this.updateStyles(),this.syncConfigToWorker(),r?this.rebuildGeometry().then(function(){return e.updating--}):(this.updating--,Promise.resolve())}},syncConfigToWorker:{value:function(){var e=this;this.config_serialized=l.serializeWithFunctions(this.config),this.workers.forEach(function(t){c.postMessage(t,"updateConfig",{config:e.config_serialized,generation:e.generation})})}},resetFeatureSelection:{value:function(){this.selection?this.workers&&this.workers.forEach(function(e){return c.postMessage(e,"resetFeatureSelection")}):this.selection=new w(this.gl,this.workers)}},getFeatureSelectionMapSize:{value:function(){var e=this;return this.fetching_selection_map?Promise.reject():(this.fetching_selection_map=!0,Promise.all(this.workers.map(function(e){return c.postMessage(e,"getFeatureSelectionMapSize")})).then(function(t){return e.fetching_selection_map=!1,t.reduce(function(e,t){return e+t})}))}},resetTime:{value:function(){this.start_time=+new Date}},workerLogMessage:{value:function(e){if("log"===e.data.type){var t=e.data,r=t.worker_id,n=t.level,i=t.msg;k[n]?k[n].apply(k,["worker "+r+":"].concat(o(i))):k.error("Scene.workerLogMessage: unrecognized log level "+n)}}},_profile:{value:function(e){console.profile("main thread: "+e),this.workers.forEach(function(t){return c.postMessage(t,"profile",e)})}},_profileEnd:{value:function(e){console.profileEnd("main thread: "+e),this.workers.forEach(function(t){return c.postMessage(t,"profileEnd",e)})}},_timeRebuild:{value:function(){var e=this,t=void 0===arguments[0]?1:arguments[0],r=[],n=function(){var i=+new Date;e.rebuild().then(function(){if(r.push(+new Date-i),r.length0?h.syncTexturesToWorker(e):Promise.resolve()},profile:function(e){console.profile("worker "+self._worker_id+": "+e)},profileEnd:function(e){console.profileEnd("worker "+self._worker_id+": "+e)}})},{"./gl/texture":81,"./selection":93,"./sources/data_source":94,"./styles/rule":102,"./styles/style_manager":104,"./styles/style_parser":105,"./tile":113,"./utils/utils":118,"./utils/worker_broker":120}],93:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("./gl/texture")),s=n(e("./utils/worker_broker")),u=function(){function e(t,r){o(this,e),this.gl=t,this.workers=r,this.init()}return i(e,{init:{value:function(){this.requests={},this.feature=null,this.read_delay=5,this.read_delay_timer=null,this.pixel=new Uint8Array(4),this.pixel32=new Float32Array(this.pixel.buffer),this.fbo=this.gl.createFramebuffer(),this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,this.fbo),this.fbo_size={width:256,height:256},this.fbo_size.aspect=this.fbo_size.width/this.fbo_size.height;var e=new a(this.gl,"selection_fbo");e.setData(this.fbo_size.width,this.fbo_size.height,null,{filtering:"nearest"}),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,this.gl.COLOR_ATTACHMENT0,this.gl.TEXTURE_2D,e.texture,0);var t=this.gl.createRenderbuffer();this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,t),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_COMPONENT16,this.fbo_size.width,this.fbo_size.height),this.gl.framebufferRenderbuffer(this.gl.FRAMEBUFFER,this.gl.DEPTH_ATTACHMENT,this.gl.RENDERBUFFER,t),this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null)}},destroy:{value:function(){this.gl&&this.fbo&&(this.gl.deleteFramebuffer(this.fbo),this.fbo=null,this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null))}},bind:{value:function(){this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,this.fbo),this.gl.viewport(0,0,this.fbo_size.width,this.fbo_size.height)}},getFeatureAt:{value:function(e){var t=this;return new Promise(function(r,n){t.selection_request_id=t.selection_request_id+1||0,t.requests[t.selection_request_id]={type:"point",id:t.selection_request_id,point:e,resolve:r}})}},pendingRequests:{value:function(){return this.requests}},read:{value:function(){var e=this;null!=this.read_delay_timer&&clearTimeout(this.read_delay_timer),this.read_delay_timer=setTimeout(function(){var t=e.gl;t.bindFramebuffer(t.FRAMEBUFFER,e.fbo);for(var r in e.requests){var n=e.requests[r];if(!n.sent&&"point"===n.type){t.readPixels(Math.floor(n.point.x*e.fbo_size.width),Math.floor((1-n.point.y)*e.fbo_size.height),1,1,t.RGBA,t.UNSIGNED_BYTE,e.pixel);var i=e.pixel[0]+(e.pixel[1]<<8)+(e.pixel[2]<<16)+(e.pixel[3]<<24)>>>0,o=e.pixel[3];255!==o?null!=e.workers[o]&&s.postMessage(e.workers[o],"getFeatureSelection",{id:n.id,key:i}).then(function(t){e.finishRead(t)}):e.finishRead({id:n.id,feature:null}),n.sent=!0}}t.bindFramebuffer(t.FRAMEBUFFER,null)},this.read_delay)}},finishRead:{value:function(e){var t=this.requests[e.id];if(!t)throw new Error("FeatureSelection.finishRead() called without any message");var r=e.feature,n=!1;(null!=r&&null==this.feature||null==r&&null!=this.feature||null!=r&&null!=this.feature&&r.id!==this.feature.id)&&(n=!0),this.feature=r,t.resolve({feature:r,changed:n,request:t}),delete this.requests[e.id]}}},{makeEntry:{value:function(e){this.map_entry++;var t=255&this.map_entry,r=this.map_entry>>8&255,n=this.map_entry>>16&255,i=this.map_prefix,o=t/255,a=r/255,s=n/255,u=i/255,l=t+(r<<8)+(n<<16)+(i<<24)>>>0;return this.map[l]={color:[o,a,s,u]},this.map_size++,this.tiles[e.key]=this.tiles[e.key]||[],this.tiles[e.key].push(l),this.map[l]}},makeColor:{value:function(e,t){var r=this.makeEntry(t);return r.feature={id:e.id,properties:e.properties,tile:t.key},r.color}},reset:{value:function(){this.tiles={},this.map={},this.map_size=0,this.map_entry=0}},clearTile:{value:function(e){var t=this;Array.isArray(this.tiles[e])&&(this.tiles[e].forEach(function(e){return delete t.map[e]}),this.map_size-=this.tiles[e].length,delete this.tiles[e])}},getMapSize:{value:function(){return this.map_size}},setPrefix:{value:function(e){this.map_prefix=e}}}),e}();t.exports=u,u.map={},u.tiles={},u.map_size=0,u.map_entry=0,u.map_prefix=0,u.defaultColor=[0,0,0,1]},{"./gl/texture":81,"./utils/worker_broker":120}],94:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")},o=function d(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:d(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},a=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},s=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),u=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});var l=n(e("../geo")),c=e("../utils/errors").MethodNotImplemented,f=n(e("../utils/utils")),h=function(){function e(t){u(this,e),this.id=t.id,this.name=t.name,this.url=t.url,this.pad_scale=t.pad_scale||5e-4,this.enforce_winding=t.enforce_winding||!1,this.transform=t.transform,"function"==typeof this.transform&&this.transform.bind(this),this.extra_data=t.extra_data,"function"==typeof importScripts&&t.scripts&&t.scripts.forEach(function(e,t){try{importScripts(e), +this.gl=null),this.sources={},Array.isArray(this.workers)&&(this.workers.forEach(function(e){e.terminate()}),this.workers=null),this.tile_manager.destroy()}},createCanvas:{value:function(){if(!this.canvas){this.container=this.container||document.body,this.canvas=document.createElement("canvas"),this.canvas.style.position="absolute",this.canvas.style.top=0,this.canvas.style.left=0,this.canvas.style.zIndex=-1,this.container.style.cssText+="background: transparent;",this.container.appendChild(this.canvas);try{this.gl=h.getContext(this.canvas,{alpha:!1,device_pixel_ratio:l.device_pixel_ratio})}catch(e){throw new Error("Couldn't create WebGL context. Your browser may not support WebGL, or it's turned off? Visit http://webglreport.com/ for more info.")}this.resizeMap(this.container.clientWidth,this.container.clientHeight),d.init(this.gl),A.initialize(this.gl)}}},getWorkerUrl:{value:function(){var e=this.worker_url||l.findCurrentURL("tangram.debug.js","tangram.min.js");if(!e)throw new Error("Can't load worker because couldn't find base URL that library was loaded from");if(this.allow_cross_domain_workers){var t="importScripts('"+e+"');";return l.createObjectURL(new Blob([t],{type:"application/javascript"}))}return e}},createWorkers:{value:function(){return this.workers?Promise.resolve():this.makeWorkers(this.getWorkerUrl())}},makeWorkers:{value:function(e){var t=this,r=[];this.workers=[];for(var n=0;ne.preserve_tiles_within_zoom)return!0;var a=Math.pow(2,o),s={x:Math.floor(i.coords.x/a),y:Math.floor(i.coords.y/a)};return Math.abs(s.x-e.center_tile.x)-r[0]>t?(k.trace("Scene: remove tile "+i.key+" (as "+s.x+"/"+s.y+"/"+n+") for being too far out of visible area ***"),!0):Math.abs(s.y-e.center_tile.y)-r[1]>t?(k.trace("Scene: remove tile "+i.key+" (as "+s.x+"/"+s.y+"/"+n+") for being too far out of visible area ***"),!0):!1})}}},resizeMap:{value:function(e,t){this.dirty=!0,this.css_size={width:e,height:t},this.device_size={width:Math.round(this.css_size.width*l.device_pixel_ratio),height:Math.round(this.css_size.height*l.device_pixel_ratio)},this.view_aspect=this.css_size.width/this.css_size.height,this.updateBounds(),this.canvas&&(this.canvas.style.width=this.css_size.width+"px",this.canvas.style.height=this.css_size.height+"px",this.canvas.width=this.device_size.width,this.canvas.height=this.device_size.height,this.gl&&(this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null),this.gl.viewport(0,0,this.canvas.width,this.canvas.height)))}},requestRedraw:{value:function(){this.dirty=!0}},immediateRedraw:{value:function(){this.dirty=!0,this.update()}},renderLoop:{value:function(){this.render_loop_active=!0,this.initialized&&this.update(),this.render_loop_stop?(this.render_loop_stop=!1,this.render_loop_active=!1):window.requestAnimationFrame(this.renderLoop.bind(this))}},setupRenderLoop:{value:function(){var e=this;this.render_loop_active||setTimeout(function(){e.renderLoop()},0)}},update:{value:function(){this.tile_manager.loadQueuedCoordinates();var e=!(this.dirty===!1||this.initialized===!1||this.updating>0||this.viewReady()===!1);return"function"==typeof this.preUpdate&&this.preUpdate(e),e?(this.dirty=!1,this.render(),"function"==typeof this.postUpdate&&this.postUpdate(e),this.animated===!0&&(this.dirty=!0),this.frame++,k.trace("Scene.render()"),!0):!1}},render:{value:function(){var e=this,t=this.gl;if(this.center_meters){if(this.camera.update(),Object.keys(this.active_styles).forEach(function(t){return e.styles[t].update()}),Object.keys(this.lights).forEach(function(t){return e.lights[t].update()}),this.renderable_tiles=this.tile_manager.getRenderableTiles(),this.renderable_tiles_count=this.renderable_tiles.length,this.render_count=this.renderPass(),this.selection.pendingRequests()){if(this.panning)return;this.selection.bind(),this.renderPass("selection_program",{allow_alpha_blend:!1}),this.selection.read(),t.bindFramebuffer(t.FRAMEBUFFER,null),t.viewport(0,0,this.canvas.width,this.canvas.height)}return this.render_count!==this.last_render_count&&this.getFeatureSelectionMapSize().then(function(t){k.info("Scene: rendered "+e.render_count+" primitives ("+t+" features in selection map)")},function(){}),this.last_render_count=this.render_count,!0}}},renderPass:{value:function(){var e=this,t=void 0===arguments[0]?"program":arguments[0],r=void 0===arguments[1]?{}:arguments[1],n=r.allow_alpha_blend,i=void 0,o=0;return n=null==n?!0:n,this.clearFrame({clear_color:!0,clear_depth:!0}),i=Object.keys(this.active_styles).filter(function(t){return"opaque"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!0,alpha_blend:!1}),o+=this.renderStyles(i,t)),i=Object.keys(this.active_styles).filter(function(t){return"add"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n&&"add"}),o+=this.renderStyles(i,t)),i=Object.keys(this.active_styles).filter(function(t){return"multiply"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n&&"multiply"}),o+=this.renderStyles(i,t)),i=Object.keys(this.styles).filter(function(t){return"inlay"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!0,depth_write:!1,alpha_blend:n}),o+=this.renderStyles(i,t)),i=Object.keys(this.styles).filter(function(t){return"overlay"===e.styles[t].blend}),i.length>0&&(this.setRenderState({depth_test:!1,depth_write:!1,alpha_blend:n}),o+=this.renderStyles(i,t)),o}},renderStyles:{value:function(e,t){var r=0,n=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(n=(a=s.next()).done);n=!0){var u=a.value,l=this.styles[u][t];l&&l.compiled&&(r+=this.renderStyle(u,l))}}catch(c){i=!0,o=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(i)throw o}}return r}},renderStyle:{value:function(e,t){var r=!0,n=0;for(var i in this.renderable_tiles){var o=this.renderable_tiles[i];if(null!=o.meshes[e]){if(r===!0){r=!1,t.use(),this.styles[e].setup(),t.uniform("2f","u_resolution",this.device_size.width,this.device_size.height),t.uniform("1f","u_time",(+new Date-this.start_time)/1e3),t.uniform("3f","u_map_position",this.center_meters.x,this.center_meters.y,this.zoom),t.uniform("1f","u_meters_per_pixel",this.meters_per_pixel),t.uniform("1f","u_device_pixel_ratio",l.device_pixel_ratio),P.normalFromMat4(this.normalMatrix32,this.modelViewMatrix32),t.uniform("Matrix3fv","u_normalMatrix",!1,this.normalMatrix32),this.camera.setupProgram(t);for(var a in this.lights)this.lights[a].setupProgram(t)}t.uniform("3f","u_tile_origin",o.min.x,o.min.y,o.style_zoom),I.identity(this.modelMatrix),I.translate(this.modelMatrix,this.modelMatrix,L.fromValues(o.min.x,o.min.y,0)),I.scale(this.modelMatrix,this.modelMatrix,L.fromValues(o.span.x/u.tile_scale,-1*o.span.y/u.tile_scale,1)),I.copy(this.modelMatrix32,this.modelMatrix),t.uniform("Matrix4fv","u_model",!1,this.modelMatrix32),I.multiply(this.modelViewMatrix32,this.camera.viewMatrix,this.modelMatrix),t.uniform("Matrix4fv","u_modelView",!1,this.modelViewMatrix32),o.meshes[e].render(),n+=o.meshes[e].geometry_count}}return n}},clearFrame:{value:function(){var e=void 0===arguments[0]?{}:arguments[0],t=e.clear_color,r=e.clear_depth;if(this.initialized){t=t===!1?!1:!0,r=r===!1?!1:!0;var n=this.gl;if(t&&n.clearColor.apply(n,o(this.background.color)),r&&n.depthMask(!0),t||r){var i=(t&&n.COLOR_BUFFER_BIT)|(r&&n.DEPTH_BUFFER_BIT);n.clear(i)}}}},setRenderState:{value:function(){var e=void 0===arguments[0]?{}:arguments[0],t=e.depth_test,r=e.depth_write,n=e.cull_face,i=e.alpha_blend;if(this.initialized){t=t===!1?!1:!0,r=r===!1?!1:!0,n=n===!1?!1:!0,i=null!=i?i:!1;var o=this.gl;A.depth_test.set({depth_test:t,depth_func:o.LEQUAL}),A.depth_write.set({depth_write:r}),A.culling.set({cull:n,face:o.BACK}),i?i===!0?A.blending.set({blend:!0,src:o.SRC_ALPHA,dst:o.ONE_MINUS_SRC_ALPHA}):"add"===i?A.blending.set({blend:!0,src:o.ONE,dst:o.ONE}):"multiply"===i&&A.blending.set({blend:!0,src:o.ZERO,dst:o.SRC_COLOR}):A.blending.set({blend:!1,src:null,dst:null})}}},getFeatureAt:{value:function(e){if(!this.initialized)return k.debug("Scene.getFeatureAt() called before scene was initialized"),Promise.resolve();var t={x:e.x*l.device_pixel_ratio/this.device_size.width,y:e.y*l.device_pixel_ratio/this.device_size.height};return this.dirty=!0,this.selection.getFeatureAt(t)}},rebuild:{value:function(){return this.rebuildGeometry()}},rebuildGeometry:{value:function(){var e=this;return new Promise(function(t,r){if(e.building)return e.building.queued&&e.building.queued.reject&&(k.debug("Scene.rebuildGeometry: request superceded by a newer call"),e.building.queued.resolve(!1)),e.building.queued={resolve:t,reject:r},void k.trace("Scene.rebuildGeometry(): queuing request");e.building={resolve:t,reject:r},e.debug.profile.geometry_build&&e._profile("rebuildGeometry"),e.syncConfigToWorker(),m.compile(e.updateActiveStyles(),e),e.resetFeatureSelection(),e.resetTime();var n=[];e.tile_manager.forEachTile(function(t){t.visible?n.push(t):e.tile_manager.removeTile(t.key)}),e.tile_manager.buildTiles(n)}).then(function(){e.debug.profile.geometry_build&&e._profileEnd("rebuildGeometry")})}},tileManagerBuildDone:{value:function(){if(this.building){k.info("Scene: build geometry finished"),this.building.resolve&&this.building.resolve(!0);var e=this.building.queued;this.building=null,e&&(k.debug("Scene: starting queued rebuildGeometry() request"),this.rebuildGeometry().then(e.resolve,e.reject))}}},loadScene:{value:function(){var e=this,t=void 0===arguments[0]?null:arguments[0],r=void 0===arguments[1]?null:arguments[1];return this.config_source=t||this.config_source,"string"==typeof this.config_source?this.config_path=r||l.pathForURL(this.config_source):this.config_path=r,g.loadScene(this.config_source,this.config_path).then(function(t){return e.config=t,e.trigger("load",{config:e.config}),e.config})}},loadDataSources:{value:function(){for(var e in this.config.sources){var t=this.config.sources[e];this.sources[e]=x.create(Object.assign({},t,{name:e})),this.sources[e]||(delete this.sources[e],k.warn("Scene: could not create data source",t),this.trigger("warning",{type:"sources",source:t,message:"Could not create data source"}))}}},loadTextures:{value:function(){return p.createFromObject(this.gl,this.config.textures)}},updateStyles:{value:function(){if(!this.initialized&&!this.initializing)throw new Error("Scene.updateStyles() called before scene was initialized");m.init(),this.styles=m.build(this.config.styles,this);var e=!0,t=!1,r=void 0;try{for(var n,i=l.values(this.styles)[Symbol.iterator]();!(e=(n=i.next()).done);e=!0){var o=n.value;o.setGL(this.gl)}}catch(a){t=!0,r=a}finally{try{!e&&i["return"]&&i["return"]()}finally{if(t)throw r}}this.updateActiveStyles(),m.compile(Object.keys(this.active_styles),this),this.dirty=!0}},updateActiveStyles:{value:function(){var e=this,t=Object.keys(this.active_styles||{});this.active_styles={};var r=!1,n=!0,o=!1,a=void 0;try{for(var s,u=l.recurseValues(this.config.layers)[Symbol.iterator]();!(n=(s=u.next()).done);n=!0){var c=s.value;if(c.draw){var f=!0,h=!1,p=void 0;try{for(var d,m=l.entries(c.draw)[Symbol.iterator]();!(f=(d=m.next()).done);f=!0){var v=i(d.value,2),g=v[0],y=v[1];"object"==typeof y&&y.visible!==!1&&!function(){var t=y.style||g,n=[t];y.outline&&y.outline.style&&n.push(y.outline.style),n=n.filter(function(t){return e.styles[t]}).forEach(function(t){var n=e.styles[t];n&&(e.active_styles[t]=!0,n.animated&&(r=!0))})}()}}catch(_){h=!0,p=_}finally{try{!f&&m["return"]&&m["return"]()}finally{if(h)throw p}}}}}catch(_){o=!0,a=_}finally{try{!n&&u["return"]&&u["return"]()}finally{if(o)throw a}}return this.animated=void 0!==this.config.scene.animated?this.config.scene.animated:r,Object.keys(this.active_styles).filter(function(e){return-1===t.indexOf(e)})}},createCamera:{value:function(){var e=this._active_camera;e&&(this.camera=y.create(e,this,this.config.cameras[this._active_camera]),this.camera.updateScene())}},getActiveCamera:{value:function(){return this._active_camera}},setActiveCamera:{value:function(e){return this._active_camera=e,this.updateConfig(),this._active_camera}},_active_camera:{get:function(){if(this.config&&this.config.cameras)for(var e in this.config.cameras)if(this.config.cameras[e].active)return e},set:function(e){var t=this._active_camera;this.config.cameras[e]&&(this.config.cameras[e].active=!0,t&&t!==e&&this.config.cameras[t]&&delete this.config.cameras[t].active)}},createLights:{value:function(){this.lights={};for(var e in this.config.lights)if(this.config.lights[e]&&"object"==typeof this.config.lights[e]){var t=this.config.lights[e];t.name=e.replace("-","_"),t.visible=t.visible===!1?!1:!0,t.visible&&(this.lights[t.name]=_.create(this,t))}_.inject(this.lights)}},setBackground:{value:function(){var e=this.config.scene.background;this.background={},e&&e.color&&(this.background.color=v.parseColor(e.color)),this.background.color||(this.background.color=[0,0,0,1])}},updateConfig:{value:function(){var e=this,t=void 0===arguments[0]?{}:arguments[0],r=t.rebuild;return this.generation++,this.updating++,this.config.scene=this.config.scene||{},this.createCamera(),this.createLights(),this.loadDataSources(),this.loadTextures(),this.setBackground(),this.updateBounds(),this.updateStyles(),this.syncConfigToWorker(),r?this.rebuildGeometry().then(function(){return e.updating--}):(this.updating--,Promise.resolve())}},syncConfigToWorker:{value:function(){var e=this;this.config_serialized=l.serializeWithFunctions(this.config),this.workers.forEach(function(t){c.postMessage(t,"updateConfig",{config:e.config_serialized,generation:e.generation})})}},resetFeatureSelection:{value:function(){this.selection?this.workers&&this.workers.forEach(function(e){return c.postMessage(e,"resetFeatureSelection")}):this.selection=new w(this.gl,this.workers)}},getFeatureSelectionMapSize:{value:function(){var e=this;return this.fetching_selection_map?Promise.reject():(this.fetching_selection_map=!0,Promise.all(this.workers.map(function(e){return c.postMessage(e,"getFeatureSelectionMapSize")})).then(function(t){return e.fetching_selection_map=!1,t.reduce(function(e,t){return e+t})}))}},resetTime:{value:function(){this.start_time=+new Date}},workerLogMessage:{value:function(e){if("log"===e.data.type){var t=e.data,r=t.worker_id,n=t.level,i=t.msg;k[n]?k[n].apply(k,["worker "+r+":"].concat(o(i))):k.error("Scene.workerLogMessage: unrecognized log level "+n)}}},_profile:{value:function(e){console.profile("main thread: "+e),this.workers.forEach(function(t){return c.postMessage(t,"profile",e)})}},_profileEnd:{value:function(e){console.profileEnd("main thread: "+e),this.workers.forEach(function(t){return c.postMessage(t,"profileEnd",e)})}},_timeRebuild:{value:function(){var e=this,t=void 0===arguments[0]?1:arguments[0],r=[],n=function(){var i=+new Date;e.rebuild().then(function(){if(r.push(+new Date-i),r.length0?h.syncTexturesToWorker(e):Promise.resolve()},profile:function(e){console.profile("worker "+self._worker_id+": "+e)},profileEnd:function(e){console.profileEnd("worker "+self._worker_id+": "+e)}})},{"./gl/texture":81,"./selection":93,"./sources/data_source":94,"./styles/rule":102,"./styles/style_manager":104,"./styles/style_parser":105,"./tile":113,"./utils/utils":118,"./utils/worker_broker":120}],93:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("./gl/texture")),s=n(e("./utils/worker_broker")),u=function(){function e(t,r){o(this,e),this.gl=t,this.workers=r,this.init()}return i(e,{init:{value:function(){this.requests={},this.feature=null,this.read_delay=5,this.read_delay_timer=null,this.pixel=new Uint8Array(4),this.pixel32=new Float32Array(this.pixel.buffer),this.fbo=this.gl.createFramebuffer(),this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,this.fbo),this.fbo_size={width:256,height:256},this.fbo_size.aspect=this.fbo_size.width/this.fbo_size.height;var e=new a(this.gl,"selection_fbo");e.setData(this.fbo_size.width,this.fbo_size.height,null,{filtering:"nearest"}),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,this.gl.COLOR_ATTACHMENT0,this.gl.TEXTURE_2D,e.texture,0);var t=this.gl.createRenderbuffer();this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,t),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_COMPONENT16,this.fbo_size.width,this.fbo_size.height),this.gl.framebufferRenderbuffer(this.gl.FRAMEBUFFER,this.gl.DEPTH_ATTACHMENT,this.gl.RENDERBUFFER,t),this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null)}},destroy:{value:function(){this.gl&&this.fbo&&(this.gl.deleteFramebuffer(this.fbo),this.fbo=null,this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,null))}},bind:{value:function(){this.gl.bindFramebuffer(this.gl.FRAMEBUFFER,this.fbo),this.gl.viewport(0,0,this.fbo_size.width,this.fbo_size.height)}},getFeatureAt:{value:function(e){var t=this;return new Promise(function(r,n){t.selection_request_id=t.selection_request_id+1||0,t.requests[t.selection_request_id]={type:"point",id:t.selection_request_id,point:e,resolve:r}})}},pendingRequests:{value:function(){return this.requests}},read:{value:function(){var e=this;null!=this.read_delay_timer&&clearTimeout(this.read_delay_timer),this.read_delay_timer=setTimeout(function(){var t=e.gl;t.bindFramebuffer(t.FRAMEBUFFER,e.fbo);for(var r in e.requests){var n=e.requests[r];if(!n.sent&&"point"===n.type){t.readPixels(Math.floor(n.point.x*e.fbo_size.width),Math.floor((1-n.point.y)*e.fbo_size.height),1,1,t.RGBA,t.UNSIGNED_BYTE,e.pixel);var i=e.pixel[0]+(e.pixel[1]<<8)+(e.pixel[2]<<16)+(e.pixel[3]<<24)>>>0,o=e.pixel[3];255!==o?null!=e.workers[o]&&s.postMessage(e.workers[o],"getFeatureSelection",{id:n.id,key:i}).then(function(t){e.finishRead(t)}):e.finishRead({id:n.id,feature:null}),n.sent=!0}}t.bindFramebuffer(t.FRAMEBUFFER,null)},this.read_delay)}},finishRead:{value:function(e){var t=this.requests[e.id];if(!t)throw new Error("FeatureSelection.finishRead() called without any message");var r=e.feature,n=!1;(null!=r&&null==this.feature||null==r&&null!=this.feature||null!=r&&null!=this.feature&&r.id!==this.feature.id)&&(n=!0),this.feature=r,t.resolve({feature:r,changed:n,request:t}),delete this.requests[e.id]}}},{makeEntry:{value:function(e){this.map_entry++;var t=255&this.map_entry,r=this.map_entry>>8&255,n=this.map_entry>>16&255,i=this.map_prefix,o=t/255,a=r/255,s=n/255,u=i/255,l=t+(r<<8)+(n<<16)+(i<<24)>>>0;return this.map[l]={color:[o,a,s,u]},this.map_size++,this.tiles[e.key]=this.tiles[e.key]||[],this.tiles[e.key].push(l),this.map[l]}},makeColor:{value:function(e,t){var r=this.makeEntry(t);return r.feature={id:e.id,properties:e.properties,tile:t.key},r.color}},reset:{value:function(){this.tiles={},this.map={},this.map_size=0,this.map_entry=0}},clearTile:{value:function(e){var t=this;Array.isArray(this.tiles[e])&&(this.tiles[e].forEach(function(e){return delete t.map[e]}),this.map_size-=this.tiles[e].length,delete this.tiles[e])}},getMapSize:{value:function(){return this.map_size}},setPrefix:{value:function(e){this.map_prefix=e}}}),e}();t.exports=u,u.map={},u.tiles={},u.map_size=0,u.map_entry=0,u.map_prefix=0,u.defaultColor=[0,0,0,1]},{"./gl/texture":81,"./utils/worker_broker":120}],94:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")},o=function d(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:d(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},a=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},s=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),u=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});var l=n(e("../geo")),c=e("../utils/errors").MethodNotImplemented,f=n(e("../utils/utils")),h=function(){function e(t){u(this,e),this.id=t.id,this.name=t.name,this.url=t.url,this.pad_scale=t.pad_scale||5e-4,this.enforce_winding=t.enforce_winding||!1,this.transform=t.transform,"function"==typeof this.transform&&this.transform.bind(this),this.extra_data=t.extra_data,"function"==typeof importScripts&&t.scripts&&t.scripts.forEach(function(e,t){try{importScripts(e), f.log("info","DataSource: loaded library: "+e)}catch(r){f.log("error","DataSource: failed to load library: "+e),f.log("error",r)}}),this.max_zoom=Math.min(t.max_zoom||l.max_zoom,l.max_zoom)}return s(e,{load:{value:function(e){var t=this;return e.source_data={},e.source_data.layers={},e.pad_scale=this.pad_scale,this._load(e).then(function(e){for(var r in e.source_data.layers){var n=e.source_data.layers[r];n&&n.features&&n.features.forEach(function(e){l.transformGeometry(e.geometry,function(e){e[1]=-e[1],t.pad_scale&&(e[0]=Math.round(e[0]*(1+t.pad_scale)-l.tile_scale*t.pad_scale/2),e[1]=Math.round(e[1]*(1+t.pad_scale)-l.tile_scale*t.pad_scale/2))}),t.enforce_winding&&l.enforceWinding(e.geometry,"CCW")})}})}},_load:{value:function(e){throw new c("_load")}}},{create:{value:function(t){return e.types[t.type]?new e.types[t.type](t):void 0}},projectData:{value:function(e){var t=+new Date;for(var r in e.layers)for(var n=e.layers[r].features.length,o=0;n>o;o++){var a=e.layers[r].features[o];l.transformGeometry(a.geometry,function(e){var t=l.latLngToMeters(e),r=i(t,2),n=r[0],o=r[1];e[0]=n,e[1]=o})}void 0!==e.debug&&(e.debug.projection=+new Date-t)}},scaleData:{value:function(e,t){var r=t.coords.z,n=t.min;t.max;for(var i in e.layers)for(var o=e.layers[i].features.length,a=0;o>a;a++){var s=e.layers[i].features[a];l.transformGeometry(s.geometry,function(e){e[0]=(e[0]-n.x)*l.units_per_meter[r],e[1]=(e[1]-n.y)*l.units_per_meter[r]*-1})}}},register:{value:function(t,r){t&&r&&(e.types[r]=t)}}}),e}();r["default"]=h,h.types={};var p=r.NetworkSource=function(e){function t(e){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e),this.response_type=""}return a(t,e),s(t,{_load:{value:function(e){var t=this,r=this.formatUrl(e),n=e.source_data;return n.url=r,e.debug=e.debug||{},e.debug.network=+new Date,new Promise(function(i,o){n.error=null;var a=f.io(r,6e4,t.response_type);n.request=a.request,a.then(function(r){e.debug.response_size=r.length||r.byteLength,e.debug.network=+new Date-e.debug.network,e.debug.parsing=+new Date,t.parseSourceData(e,n,r),e.debug.parsing=+new Date-e.debug.parsing,i(e)})["catch"](function(t){n.error=t.toString(),i(e)})})}},formatUrl:{value:function(e){throw new c("formatUrl")}},parseSourceData:{value:function(e,t,r){throw new c("parseSourceData")}}}),t}(h);r.NetworkTileSource=function(e){function t(e){u(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e),this.tiled=!0,this.url_hosts=null;var r=this.url.match(/{s:\[([^}+]+)\]}/);null!=r&&r.length>1&&(this.url_hosts=r[1].split(","),this.next_host=0)}return a(t,e),s(t,{formatUrl:{value:function(e){var t=l.wrapTile(e.coords,{x:!0}),r=this.url.replace("{x}",t.x).replace("{y}",t.y).replace("{z}",t.z);return null!=this.url_hosts&&(r=r.replace(/{s:\[([^}+]+)\]}/,this.url_hosts[this.next_host]),this.next_host=(this.next_host+1)%this.url_hosts.length),r}},urlHasTilePattern:{value:function(e){return e&&e.search("{x}")>-1&&e.search("{y}")>-1&&e.search("{z}")>-1}}}),t}(p)},{"../geo":73,"../utils/errors":115,"../utils/utils":118}],95:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function v(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:v(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},a=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},s=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});var u=e("./data_source"),l=n(u),c=u.NetworkSource,f=u.NetworkTileSource,h=n(e("../geo")),p=n(e("geojson-vt")),d=r.GeoJSONTileSource=function(e){function t(e){return s(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e),this.urlHasTilePattern(this.url)?this:this instanceof t?new m(e):null}return a(t,e),i(t,{parseSourceData:{value:function(e,t,r){var n=JSON.parse(r);this.prepareGeoJSON(n,e,t)}},prepareGeoJSON:{value:function(e,t,r){"function"==typeof this.transform&&(e=this.transform(e,r)),r.layers=m.prototype.getLayers(e);var n={coords:t.coords,min:h.metersForTile(h.wrapTile(t.coords,{x:!0}))};l.projectData(r),l.scaleData(r,n)}}}),t}(f),m=r.GeoJSONSource=function(e){function t(e){s(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e),this.tiled=!0,this.load_data=null,this.tile_indexes={},this.max_zoom=Math.max(this.max_zoom||0,15),this.pad_scale=0,this.enforce_winding=e.enforce_winding===!1?!1:!0}return a(t,e),i(t,{_load:{value:function(e){var r=this;return this.load_data||(this.load_data=o(Object.getPrototypeOf(t.prototype),"_load",this).call(this,{source_data:{layers:{}}}).then(function(e){var t=e.source_data.layers;for(var n in t)r.tile_indexes[n]=p(t[n],{maxZoom:r.max_zoom,tolerance:3,extent:h.tile_scale,buffer:0});return r.loaded=!0,e})),this.load_data.then(function(){for(var t in r.tile_indexes)e.source_data.layers[t]=r.getTileFeatures(e,t);return e})}},getTileFeatures:{value:function(e,t){var r=h.wrapTile(e.coords,{x:!0}),n=this.tile_indexes[t].getTile(r.z,r.x,r.y),i=void 0;if(n&&n.features){i={type:"FeatureCollection",features:[]};var o=!0,a=!1,s=void 0;try{for(var u,l=n.features[Symbol.iterator]();!(o=(u=l.next()).done);o=!0){var c=u.value,f=c.geometry.map(function(e){return e.map(function(e){return[e[0],e[1]]})}),p=void 0;if(1===c.type)p="MultiPoint";else if(2===c.type)p="MultiLineString";else{if(3!==c.type)continue;p="MultiPolygon",f=this.decodeMultiPolygon(f)}var d={type:"Feature",geometry:{type:p,coordinates:f},properties:c.tags};i.features.push(d)}}catch(m){a=!0,s=m}finally{try{!o&&l["return"]&&l["return"]()}finally{if(a)throw s}}}return i}},decodeMultiPolygon:{value:function(e){var t=[],r=[],n=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(n=(a=s.next()).done);n=!0){var u=a.value,l=h.ringWinding(u);"CCW"===l&&r.length>0&&(t.push(r),r=[]),r.push(u)}}catch(c){i=!0,o=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(i)throw o}}return r.length>0&&t.push(r),t}},formatUrl:{value:function(e){return this.url}},parseSourceData:{value:function(e,t,r){t.layers=this.getLayers(JSON.parse(r))}},getLayers:{value:function(e){return"Feature"===e.type||"FeatureCollection"===e.type?{_default:e}:e}}}),t}(c);l.register(d,"GeoJSON"),l.register(d,"GeoJSONTiles")},{"../geo":73,"./data_source":94,"geojson-vt":23}],96:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function v(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:v(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},a=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},s=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});var u=e("./data_source"),l=n(u),c=u.NetworkTileSource,f=n(e("pbf")),h=e("vector-tile"),p=h.VectorTile,d=h.VectorTileFeature,m=r.MVTSource=function(e){function t(e){s(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e),this.response_type="arraybuffer"}return a(t,e),i(t,{parseSourceData:{value:function(e,t,r){var n=new Uint8Array(r),i=new f(n);t.data=new p(i),t.layers=this.toGeoJSON(t.data),delete t.data}},toGeoJSON:{value:function(e){var t={};for(var r in e.layers){for(var n=e.layers[r],i={type:"FeatureCollection",features:[]},o=0;of)){l(h);var d=p.set(t),m=[0,0],v=p.dot(t,i);-1>v&&(v=-1),v=Math.acos(v)/f,c||(v*=-1);var g=p.set(o),y=p.div(p.sub(s,o),f);n(e,r,a,h),n(e,d,o,h);for(var _=0;f>_;_++){if(m=p.normalize(d),d=p.rot(p.normalize(d),v),4===f&&(0===_||_===f-2)){var b=2/(1+Math.abs(p.dot(m,d)));d=p.mult(d,b*b)}g=p.add(g,y),n(e,d,g,h)}for(var x=0;f>x;x++)c?(u(x+2,h),u(0,h),u(x+1,h)):(u(x+1,h),u(0,h),u(x+2,h));h.vertices=[],h.scalingVecs&&(h.scalingVecs=[]),h.texcoords&&(h.texcoords=[])}}function a(e,t,r,i,a){var s=[p.set(t[0]),p.set(t[1]),p.set(t[2])],u=p.signed_area(e[0],e[1],e[2])>0,l=s[0],c=p.neg(s[1]),f=s[2],h=[a.max_u,(1-r)*a.min_v+r*a.max_v],d=[a.min_u,(1-r)*a.min_v+r*a.max_v],m=[a.max_u,(1-r)*a.min_v+r*a.max_v];u?(n(e[1],l,h,a),n(e[1],c,d,a)):(l=p.neg(s[0]),c=s[1],f=p.neg(s[2]),h=[a.min_u,(1-r)*a.min_v+r*a.max_v],d=[a.max_u,(1-r)*a.min_v+r*a.max_v],m=[a.min_u,(1-r)*a.min_v+r*a.max_v],n(e[1],c,d,a),n(e[1],l,h,a)),o(e[1],l,c,f,h,d,m,u,i,a),u?(n(e[1],f,m,a),n(e[1],c,d,a)):(n(e[1],c,d,a),n(e[1],f,m,a))}function s(e,t,r,n,i){if(!(1>r)){var a=[i.min_u,i.min_v],s=[i.min_u+(i.max_u-i.min_u)/2,i.min_v],u=[i.max_u,i.min_v];n||(a=[i.min_u,i.max_v],s=[i.min_u+(i.max_u-i.min_u)/2,i.max_v],u=[i.max_u,i.max_v]),o(e,p.neg(t),[0,0],t,a,s,u,n,2*r,i)}}function u(e,t){var r=t.vertex_data,n=t.vertex_template,i=t.halfWidth,o=t.vertices,a=t.scaling_index,s=t.scaling_normalize,u=t.scalingVecs,l=t.texcoord_index,c=t.texcoords,f=t.texcoord_normalize;e>=o.length||(n[0]=o[e][0],n[1]=o[e][1],l&&(n[l+0]=c[e][0]*f,n[l+1]=c[e][1]*f),a&&(n[a+0]=u[e][0]*s,n[a+1]=u[e][1]*s,n[a+2]=i),r.addVertex(n))}function l(e){for(var t=0;t_;_++){var b=e[_];if(i)var x=d.findBoundingBox(b),w=h(x,4),A=w[0],E=w[1],T=w[2],S=w[3],M=T-A,k=S-E,R=(v-f)/M,I=(g-p)/k;for(var P=c.triangulatePolygon(b),L=P.length,N=0;L>N;N++){var O=P[N];r[0]=O[0],r[1]=O[1],i&&(r[i+0]=((O[0]-A)*R+f)*a,r[i+1]=((O[1]-E)*I+p)*a),t.addVertex(r)}}},c.buildExtrudedPolygons=function(e,t,r,n,i,o,a,s,u){var l=u.texcoord_index,f=u.texcoord_scale,d=u.texcoord_normalize,m=t+(n||0),v=t+r;if(o[2]=v,c.buildPolygons(e,i,o,{texcoord_index:l,texcoord_scale:f,texcoord_normalize:d}),l){d=d||1;var g=f||[[0,0],[1,1]],y=h(g,2),_=h(y[0],2),b=_[0],x=_[1],w=h(y[1],2),A=w[0],E=w[1],T=[[b,E],[b,x],[A,x],[A,x],[A,E],[b,E]]}for(var S=e.length,M=0;S>M;M++)for(var k=e[M],R=0;RU)){var C=[0,0],z=[0,0],F=[0,0],D=[0,0],j=[0,0],B=[0,0],G=!1,V=!0;l(L);for(var q=0;U>q;q++){if(V=U>q+1,G)C=z,D=p.normalize(p.perp(C,O[q]));else if(0===q&&u===!0){var W=!0;f&&c.isOnTileEdge(O[q],O[U-2],{tolerance:d})&&(W=!1),W&&(C=O[U-2],D=p.normalize(p.perp(C,O[q])),G=!0)}if(z=O[q],V?F=O[q+1]:u===!0&&(F=O[1],V=!0),V&&(B=p.normalize(p.perp(z,F)),f&&c.isOnTileEdge(z,F,{tolerance:d})))j=p.normalize(p.perp(C,z)),G&&(i(z,j,q/U,L),L.nPairs++,l(L)),G=!1;else{if(G)if(V){j=p.normalize(p.add(D,B));var X=2/(1+Math.abs(p.dot(D,j)));j=p.mult(j,X*X)}else j=p.normalize(p.perp(C,z));else{if(!V)continue;B=p.normalize(p.perp(z,F)),j=B}(G||V)&&(0!==q||G||u||s(z,j,w,!0,L),0!==A&&G&&V?a([C,z,F],[D,j,B],q/U,A,L):i(z,j,q/(U-1),L),V&&L.nPairs++,G=!0)}}l(L),u||s(z,j,w,!1,L)}}},c.buildQuadsForPoints=function(e,t,r,n,i){var o=n.texcoord_index,a=n.position_index,s=n.shape_index,u=n.offset_index,l=i.quad,c=i.quad_scale,f=i.offset,p=i.angle,d=i.texcoord_scale,m=i.texcoord_normalize,v=l[0]/2,g=l[1]/2,y=[[-v,-g],[v,-g],[v,g],[-v,-g],[v,g],[-v,g]],_=void 0;if(o){m=m||1;var b=d||[[0,0],[1,1]],x=h(b,2),w=h(x[0],2),A=w[0],E=w[1],T=h(x[1],2),S=T[0],M=T[1];_=[[A,E],[S,E],[S,M],[A,E],[S,M],[A,M]]}for(var k=e.length,R=0;k>R;R++)for(var I=e[R],P=0;6>P;P++)o&&(r[o+0]=_[P][0]*m,r[o+1]=_[P][1]*m),r[a+0]=I[0],r[a+1]=I[1],r[s+0]=y[P][0],r[s+1]=y[P][1],r[s+2]=p,r[s+3]=c,r[u+0]=f[0],r[u+1]=f[1],t.addVertex(r)},c.triangulatePolygon=function(e){return m(e)},c.isOnTileEdge=function(e,t,r){r=r||{};var n=r.tolerance_function||c.valuesWithinTolerance,i=r.tolerance||1,o=c.tile_bounds[0],a=c.tile_bounds[1],s=null;return n(e[0],o.x,i)&&n(t[0],o.x,i)?s="left":n(e[0],a.x,i)&&n(t[0],a.x,i)?s="right":n(e[1],o.y,i)&&n(t[1],o.y,i)?s="top":n(e[1],a.y,i)&&n(t[1],a.y,i)&&(s="bottom"),s},c.valuesWithinTolerance=function(e,t,r){return r=r||1,Math.abs(e-t)n.order&&(n.outline.order=n.order),n.outline.order-=.5,n.outline.preprocessed=!0}else n.outline.color=null,n.outline.width=null;return n}},preprocess:function(e){e.color=e.color&&{value:e.color},e.width=e.width&&{value:e.width},e.next_width=e.width&&{value:e.width.value},e.z=e.z&&{value:e.z},e.outline&&(e.outline.color=e.outline.color&&{value:e.outline.color},e.outline.width=e.outline.width&&{value:e.outline.width},e.outline.next_width=e.outline.width&&{value:e.outline.width.value})},makeVertexTemplate:function(e){var t=0;return this.vertex_template[t++]=0,this.vertex_template[t++]=0,this.vertex_template[t++]=e.z||0,this.vertex_template[t++]=e.order,this.vertex_template[t++]=0,this.vertex_template[t++]=0,this.vertex_template[t++]=0,this.vertex_template[t++]=e.next_width,this.vertex_template[t++]=255*e.color[0],this.vertex_template[t++]=255*e.color[1],this.vertex_template[t++]=255*e.color[2],this.vertex_template[t++]=255*e.color[3],this.selection&&(this.vertex_template[t++]=255*e.selection_color[0],this.vertex_template[t++]=255*e.selection_color[1],this.vertex_template[t++]=255*e.selection_color[2],this.vertex_template[t++]=255*e.selection_color[3]),this.texcoords&&(this.vertex_template[t++]=0,this.vertex_template[t++]=0),this.vertex_template},buildLines:function(e,t,r,n,i){var o=this.makeVertexTemplate(t);if(t.color&&t.width&&l.buildPolylines(e,t.width,r,o,{cap:t.cap,join:t.join,scaling_index:this.vertex_layout.index.a_extrude,scaling_normalize:f.scaleInt16(1,256),texcoord_index:this.vertex_layout.index.a_texcoord,texcoord_scale:this.texcoord_scale,texcoord_normalize:65535,closed_polygon:i&&i.closed_polygon,remove_tile_edges:!t.tile_edges&&i&&i.remove_tile_edges,tile_edge_tolerance:c.tile_scale*n.tile.pad_scale*4}),t.outline&&t.outline.color&&t.outline.width){var s=a.styles[t.outline.style];s&&s.addFeature(n.feature,t.outline,n)}},buildPolygons:function(e,t,r,n){for(var i=0;is&&(s=e[o].length);if(0===s)return null;for(i=0;s>i;i++)n=e.map(function(e){return e[i]&&e[i][t]}),0!==n.length&&f.apply(void 0,[a].concat(_(n)));return a.visible===!1?null:a}function o(e){return S.indexOf(e)>-1}function a(e){return 0===Object.keys(e).length}function s(e,t){e.parent&&s(e.parent,t),t(e)}function u(e,t){e.rules&&e.rules.forEach(function(e){u(e,t)}),t(e)}function l(e){var t={},r={};for(var n in e)o(n)?t[n]=e[n]:r[n]=e[n];return[t,r]}function c(e){var t=[];if(e.parent){var r=e.parent.calculatedDraw||[];t.push.apply(t,_(r))}return t.push(e.draw),t}function f(e){for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];var i=!0,o=!1,a=void 0;try{for(var s,u=r[Symbol.iterator]();!(i=(s=u.next()).done);i=!0){var l=s.value;if(l)for(var c in l){var h=l[c];"object"!=typeof h||Array.isArray(h)?e[c]=h:e[c]=f(e[c]||{},h)}}}catch(p){o=!0,a=p}finally{try{!i&&u["return"]&&u["return"]()}finally{if(o)throw a}}return e}function h(e){var t=void 0===arguments[1]?null:arguments[1],r=void 0===arguments[2]?0:arguments[2],n=r,i=!0,o=!1,a=void 0;try{for(var s,u=e[Symbol.iterator]();!(i=(s=u.next()).done);i=!0){var l=s.value;l="function"==typeof l?l(t):parseFloat(l),l&&!isNaN(l)&&(n+=l)}}catch(c){o=!0,a=c}finally{try{!i&&u["return"]&&u["return"]()}finally{if(o)throw a}}return n}function p(e,t,r){var n={name:e,parent:r},i=l(t),o=y(i,2),s=o[0],u=o[1],c=a(u),f=void 0;f=c&&null!=r?R:I;var h=new f(Object.assign(n,s));if(r&&r.addRule(h),!c)for(var d in u){var m=u[d];"object"==typeof m?p(d,m,h):T.warn("Rule property must be an object: ",e,t,m)}return h}function d(e){var t={};for(var r in e){var n=e[r];t[r]=p(r,n)}return t}function m(e,t){return"function"==typeof e&&e(t)||null==e}function v(e,t,r){var n=!1,i=!1;if(0!==t.length){for(var o=0;o0){var r=n(t);if(void 0===M[r])if(t.some(function(e){return e.visible===!1}))M[r]=null;else{var o=t.map(function(e){return e&&e.calculatedDraw}),a={},s=!0,u=!1,l=void 0;try{for(var c,f=o[Symbol.iterator]();!(s=(c=f.next()).done);s=!0){var h=c.value;if(h){var p=!0,d=!1,m=void 0;try{for(var g,y=h[Symbol.iterator]();!(p=(g=y.next()).done);p=!0){var _=g.value;for(var b in _)a[b]=!0}}catch(x){d=!0,m=x}finally{try{!p&&y["return"]&&y["return"]()}finally{if(d)throw m}}}}}catch(x){u=!0,l=x}finally{try{!s&&f["return"]&&f["return"]()}finally{if(u)throw l}}for(var w in a)M[r]=M[r]||{},M[r][w]=i(o,w,e),M[r][w]?M[r][w].key=r+"/"+w:delete M[r][w];M[r]&&0===Object.keys(M[r]).length&&(M[r]=null)}return M[r]}}}}),t}(k)},{loglevel:60,"match-feature":61}],103:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e};Object.defineProperty(r,"__esModule",{value:!0});var i=e("./style_parser").StyleParser,o=n(e("../selection")),a=n(e("../gl/shader_program")),s=n(e("../gl/vbo_mesh")),u=n(e("../material")),l=n(e("../light")),c=e("../utils/errors").MethodNotImplemented,f=n(e("../gl/shader_sources")),h=n(e("loglevel")),p={init:function(){var e=void 0===arguments[0]?{}:arguments[0],t=e.generation;this.isBuiltIn()||(this.built_in=!1),this.generation=t,this.defines=this.hasOwnProperty("defines")&&this.defines||{},this.shaders=this.hasOwnProperty("shaders")&&this.shaders||{},this.selection=this.selection||!1,this.compiling=!1,this.compiled=!1,this.program=null,this.selection_program=null,this.feature_style={},this.vertex_template=[],this.tile_data={},this.feature_options={},this.defines.TANGRAM_WORLD_POSITION_WRAP=1e5,this.blend=this.blend||"opaque",this.defines["TANGRAM_BLEND_"+this.blend.toUpperCase()]=!0,this.material instanceof u||(u.isValid(this.material)||(this.material=i.defaults.material),this.material=new u(this.material)),this.material.inject(this),l.setMode(this.lighting,this),this.initialized=!0},destroy:function(){this.program&&(this.program.destroy(),this.program=null),this.selection_program&&(this.selection_program.destroy(),this.selection_program=null),this.gl=null,this.initialized=!1},reset:function(){},isBuiltIn:function(){return this.hasOwnProperty("built_in")&&this.built_in},fillVertexTemplate:function(e,t,r){var n=r.size,i=r.offset;i=void 0===i?0:i;var o=this.vertex_layout.index[e];if(void 0===o)return void h.warn("Style: in style '"+this.name+"', no index found in vertex layout for attribute '"+e+"'");for(var a=0;n>a;++a){var s=t.length>a?t[a]:t;this.vertex_template[o+a+i]=s}},startData:function(e){return this.tile_data[e]={vertex_data:null,uniforms:null},this.tile_data[e]},endData:function(e){var t=this.tile_data[e];return t&&t.vertex_data&&(t.vertex_data.end(),t.vertex_data=t.vertex_data.buffer),this.tile_data[e]=null,Promise.resolve(t)},hasDataForTile:function(e){return null!=this.tile_data[e]},addFeature:function(e,t,r){var n=r.tile;if(n.generation===this.generation){this.tile_data[n.key]||this.startData(n.key);var i=this.parseFeature(e,t,r);i&&(this.tile_data[n.key].vertex_data||(this.tile_data[n.key].vertex_data=this.vertex_layout.createVertexData()),this.buildGeometry(e.geometry,i,this.tile_data[n.key].vertex_data,r))}},buildGeometry:function(e,t,r,n){"Polygon"===e.type?this.buildPolygons([e.coordinates],t,r,n):"MultiPolygon"===e.type?this.buildPolygons(e.coordinates,t,r,n):"LineString"===e.type?this.buildLines([e.coordinates],t,r,n):"MultiLineString"===e.type?this.buildLines(e.coordinates,t,r,n):"Point"===e.type?this.buildPoints([e.coordinates],t,r,n):"MultiPoint"===e.type&&this.buildPoints(e.coordinates,t,r,n)},parseFeature:function(e,t,r){try{var n=this.feature_style;t.preprocessed||(this.preprocess(t),t.preprocessed=!0),n.order=this.parseOrder(t.order,r);var i=!1;return n.interactive=t.interactive,this.selection&&(i="function"==typeof n.interactive?n.interactive(r):n.interactive),i?n.selection_color=o.makeColor(e,r.tile):n.selection_color=o.defaultColor,n=this._parseFeature(e,t,r)}catch(a){h.error("Style.parseFeature: style parsing error",e,n,a)}},_parseFeature:function(e,t,r){throw new c("_parseFeature")},preprocess:function(){},parseOrder:function(e,t){return"number"!=typeof e?i.calculateOrder(e,t):e},parseColor:function(e,t){return e?i.cacheColor(e,t):this.shaders.blocks.color||this.shaders.blocks.filter?i.defaults.color:void 0},buildPolygons:function(){},buildLines:function(){},buildPoints:function(){},setGL:function(e){this.gl=e},makeMesh:function(e){var t=void 0===arguments[1]?{}:arguments[1],r=t.uniforms;return new s(this.gl,e,this.vertex_layout,{uniforms:r})},compile:function(){if(!this.gl)throw new Error("style.compile(): skipping for "+this.name+" because no GL context");if(this.compiling)throw new Error("style.compile(): skipping for "+this.name+" because style is already compiling");this.compiling=!0,this.compiled=!1;var e=this.buildDefineList();if(this.selection){var t=Object.assign({},e);t.TANGRAM_FEATURE_SELECTION=!0}var r=this.shaders&&this.shaders.blocks,n=this.shaders&&this.shaders.block_scopes,i=this.shaders&&this.shaders.uniforms,o=this.shaders&&this.shaders.extensions;"string"==typeof o&&(o=[o]);try{this.program=new a(this.gl,f[this.vertex_shader_key],f[this.fragment_shader_key],{name:this.name,defines:e,uniforms:i,blocks:r,block_scopes:n,extensions:o}),this.program.compile(),this.selection?(this.selection_program=new a(this.gl,f[this.vertex_shader_key],f["gl/shaders/selection_fragment"],{name:this.name+" (selection)",defines:t,uniforms:i,blocks:r,block_scopes:n,extensions:o}),this.selection_program.compile()):this.selection_program=null}catch(s){throw this.compiling=!1,this.compiled=!1,new Error("style.compile(): style "+this.name+" error:",s)}this.compiling=!1,this.compiled=!0},addShaderBlock:function(e,t){var r=void 0===arguments[2]?null:arguments[2];this.shaders.blocks=this.shaders.blocks||{},this.shaders.blocks[e]=this.shaders.blocks[e]||[],this.shaders.blocks[e].push(t),this.shaders.block_scopes=this.shaders.block_scopes||{},this.shaders.block_scopes[e]=this.shaders.block_scopes[e]||[],this.shaders.block_scopes[e].push(r)},removeShaderBlock:function(e){this.shaders.blocks&&(this.shaders.blocks[e]=null)},replaceShaderBlock:function(e,t){var r=void 0===arguments[2]?null:arguments[2];this.removeShaderBlock(e),this.addShaderBlock(e,t,r)},buildDefineList:function(){var e={};if(null!=this.defines)for(var t in this.defines)e[t]=this.defines[t];if(null!=this.shaders&&null!=this.shaders.defines)for(t in this.shaders.defines)e[t]=this.shaders.defines[t];return e},setup:function(){this.setUniforms(),this.material.setupProgram(a.current)},setUniforms:function(){var e=a.current;e&&e.setUniforms(this.shaders&&this.shaders.uniforms,!0)},update:function(){}};r.Style=p},{"../gl/shader_program":79,"../gl/shader_sources":80,"../gl/vbo_mesh":83,"../light":87,"../material":88,"../selection":93,"../utils/errors":115,"./style_parser":105,loglevel:60}],104:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")},o=function(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);t0&&a([this.aabb],e,function(n,i){return u.intersect(t.aabb.obb,e[i].obb)?(r=!0,!0):void 0}),r||e.push(this.aabb),r}},inTileBounds:{value:function(){var e=[this.aabb[0],this.aabb[1]],t=[this.aabb[2],this.aabb[3]];return s.pointInTile(e)&&s.pointInTile(t)?!0:!1}},discard:{value:function t(e){var t=!1;if(this.options.keep_in_tile){var r=this.inTileBounds();if(!r&&this.options.move_in_tile)t=this.moveInTile();else if(!r)return!0}return t||this.occluded(e)}}}),e}();t.exports=l},{"../../utils/obb":116,"../../utils/utils":118,"box-intersect":4}],108:[function(e,t,r){"use strict";var n,i=function(e){return e&&e.__esModule?e["default"]:e},o=i(e("./label_point")),a=i(e("./label_line")),s=i(e("../../geo"));t.exports=n={},n.buildFromGeometry=function(e,t,r,n){var i=[];if("LineString"===r.type){var u=r.coordinates;i.push(new a(e,t,u,n))}else if("MultiLineString"===r.type)for(var u=r.coordinates,l=0;l=this.lines.length-1?!1:(this.segment_index++,this.update(),!0)}},computeAngle:{value:function(){var e=this.currentSegment(),t=u.sub(e[0],e[1]);t=u.normalize(t);var r=Math.PI/2,n=Math.atan2(t[0],t[1])+r;return(n>r||-r>n)&&(n+=Math.PI),n%=2*Math.PI}},fitToSegment:{value:function(){var e=void 0===arguments[0]?!0:arguments[0];if(!e)return!0;var t=this.currentSegment(),r=u.sub(t[0],t[1]),n=u.length(r),i=this.size.text_size[0]*this.options.units_per_pixel;if(i>n){var o=100*(1-n/i);return oi}},currentSegment:{value:function(){var e=this.lines[this.segment_index],t=this.lines[this.segment_index+1];return[e,t]}},computeAABB:{value:function(){var e=this.options.units_per_pixel,t=(this.size.text_size[0]+2*this.options.buffer[0])*e,r=(this.size.text_size[1]+2*this.options.buffer[1])*e,n=u.rot(this.options.offset,this.angle),i=[this.position[0]+n[0]*e,this.position[1]-n[1]*e],o=new c(i[0],i[1],-this.angle,t,r),a=o.getExtent();return a.obb=o,a}},moveInTile:{value:function(){for(var e=!1,t=this.fitToSegment();!e&&!t&&this.moveNextSegment();)e=this.inTileBounds(),t=this.fitToSegment();return!e||!t}},discard:{value:function(e){if(this.lines&&!this.fitToSegment())for(;!this.fitToSegment();)if(!this.moveNextSegment())return!0;return o(Object.getPrototypeOf(t.prototype),"discard",this).call(this,e)}}}),t}(l);t.exports=f},{"../../utils/obb":116,"../../vector":121,"./label":107}],110:[function(e,t,r){"use strict";var n=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},i=function o(e){var t=e.units_per_pixel,r=e.offset,i=e.line_exceed,a=e.move_in_tile,s=e.keep_in_tile,u=e.buffer;n(this,o),this.buffer=u||[0,0],this.keep_in_tile=null!=s?s:!0,this.move_in_tile=null!=a?a:!0,this.offset=r||[0,0],this.line_exceed=null!=i?i:80,this.units_per_pixel=t};t.exports=i},{}],111:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function h(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:h(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},a=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},s=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},u=n(e("./label")),l=n(e("../../geo")),c=n(e("../../utils/obb")),f=function(e){function t(e,r,n,i){s(this,t),o(Object.getPrototypeOf(t.prototype),"constructor",this).call(this,e,n,i),this.position=r,this.update()}return a(t,e),i(t,{update:{value:function(){this.aabb=this.computeAABB()}},computeAABB:{value:function(){var e=(this.size.text_size[0]+2*this.options.buffer[0])*this.options.units_per_pixel,t=(this.size.text_size[1]+2*this.options.buffer[1])*this.options.units_per_pixel,r=[this.position[0]+this.options.offset[0]*this.options.units_per_pixel,this.position[1]-this.options.offset[1]*this.options.units_per_pixel],n=new c(r[0],r[1],0,e,t),i=n.getExtent();return i.obb=n,i}},moveInTile:{value:function(){var e=!1;return this.aabb[0]<0&&(this.position[0]+=-this.aabb[0],e=!0),this.aabb[2]>=l.tile_scale&&(this.position[0]-=this.aabb[2]-l.tile_scale+1,e=!0),this.aabb[3]>0&&(this.position[1]-=this.aabb[3],e=!0),this.aabb[1]<=-l.tile_scale&&(this.position[1]-=this.aabb[1]+l.tile_scale-1,e=!0),e&&(this.aabb=this.computeAABB()),!this.inTileBounds()}}}),t}(u);t.exports=f},{"../../geo":73,"../../utils/obb":116,"./label":107}],112:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n; -}throw new TypeError("Invalid attempt to destructure non-iterable instance")};Object.defineProperty(r,"__esModule",{value:!0});var o=n(e("../builders")),a=n(e("../../gl/texture")),s=n(e("../../utils/worker_broker")),u=n(e("../../utils/utils")),l=e("../points/points").Points,c=n(e("./label_builder")),f=n(e("./feature_label")),h=n(e("./label_options")),p=e("../style_parser").StyleParser,d=n(e("loglevel")),m=Object.create(l);r.TextStyle=m,Object.assign(m,{name:"text","super":l,built_in:!0,selection:!1,init:function(){this["super"].init.apply(this,arguments),this.main_thread_target="TextStyle-"+this.name,u.isMainThread&&s.addTarget(this.main_thread_target,this),this.defines.TANGRAM_POINT_TEXTURE=!0,this.defines.TANGRAM_UNMULTIPLY_ALPHA=!0,this.default_font_style={style:"normal",weight:null,size:"12px",family:"Helvetica",fill:"white"},this.reset()},reset:function(){this["super"].reset.call(this),this.texts={},this.textures={},this.canvas={},this.aabbs={},this.features={},this.feature_labels={},this.feature_style_key={}},freeTile:function(e){delete this.texts[e],delete this.textures[e],delete this.canvas[e],delete this.aabbs[e];for(var t in this.features){for(var r=this.features[t],n=0;nt&&(t=s[0]),r+=s[1]}}return[t,r]},getTextSizes:function(e,t){if(!this.canvas[e]){var r=document.createElement("canvas");this.canvas[e]={canvas:r,context:r.getContext("2d")}}for(var n in t){var i=t[n];for(var o in i){var a=i[o].text_style;this.setFont(e,a),i[o].size=this.textSize(o,e,a.transform)}}return Promise.resolve(t)},rasterize:function(e,t,r){for(var n in t){var i=t[n];for(var a in i){var s=i[a];this.setFont(e,s.text_style),this.drawText(a,s.position,e,s.text_style.stroke,s.text_style.transform),s.texcoords=o.getTexcoordsForSprite(s.position,s.size.texture_text_size,r)}}},addTexts:function(e,t){if(!this.canvas[e])return Promise.resolve({});var r=this.setTextureTextPositions(t),n=this.canvas[e].context;d.trace("text summary for tile "+e+": fits in "+r[0]+"x"+r[1]+"px"),this.canvas[e].canvas.width=r[0],this.canvas[e].canvas.height=r[1],n.clearRect(0,0,r[0],r[1]);var i="labels-"+e+"-"+m.texture_id++;return this.textures[e]=new a(this.gl,i),this.rasterize(e,t,r),this.textures[e].setCanvas(this.canvas[e].canvas,{filtering:"linear",UNPACK_PREMULTIPLY_ALPHA_WEBGL:!0}),delete this.textures[e],delete this.canvas[e],Promise.resolve({texts:t,texture:i})},startData:function(e){var t=this["super"].startData.apply(this,arguments);return t.queue=[],t},createLabels:function(e,t){var r={};for(var n in t){var i=t[n];for(var o in i){var a=i[o];a.ref=0;var s=u.hashString(e+n+o);if(this.features[s])for(var l=this.features[s],f=0;f0&&(n=Object.keys(this.texts[e]||{}).length,d.trace("# texts for tile "+e+": "+n)),n?s.postMessage(this.main_thread_target,"getTextSizes",e,this.texts[e]).then(function(n){if(!n)return t.freeTile(e),t["super"].endData.apply(t,r);var o=t.createLabels(e,n);return o?(t.discardLabels(e,o,n),0===Object.keys(n).length?(t.freeTile(e),void s.postMessage(t.main_thread_target,"freeTile",e)):s.postMessage(t.main_thread_target,"addTexts",e,n).then(function(n){var o=n.texts,a=n.texture;return o&&(t.texts[e]=o,i.uniforms={u_texture:a},i.textures=[a],i.queue.forEach(function(e){return t["super"].addFeature.apply(t,e)}),i.queue=[]),t.freeTile(e),t["super"].endData.apply(t,r)})):(t.freeTile(e),t["super"].endData.apply(t,r))}):Promise.resolve()},addFeature:function(e,t,r){var n=r.tile;if(n.generation===this.generation){var i=void 0,o=t.text_source||"name";if("string"==typeof o?i=e.properties[o]:"function"==typeof o&&(i=o(r)),i){e.text=i,this.texts[n.key]||(this.texts[n.key]=this.texts[n.key]||{});var a=new f(e,t,r,i,n,this.default_font_style),s=a.getHash();if(!a.style)return;var u=a.style_key;this.feature_style_key[n.key]=this.feature_style_key[n.key]||new Map,this.feature_style_key[n.key].set(e,u),this.texts[n.key][u]||(this.texts[n.key][u]={});var l=t.priority;void 0!==l?"function"==typeof l&&(l=l(r)):l=-1>>>0;var c=t.offset||[0,0];c[0]=parseFloat(c[0]),c[1]=parseFloat(c[1]);var h=t.buffer;null!=h&&(Array.isArray(h)||(h=[h,h]),h[0]=parseFloat(h[0]),h[1]=parseFloat(h[1]));var p=void 0;t.line_exceed&&"%"===t.line_exceed.substr(-1)&&(p=t.line_exceed.substr(0,t.line_exceed.length-1)),this.texts[n.key][u][i]||(this.texts[n.key][u][i]={text_style:a.style,units_per_pixel:n.units_per_pixel,priority:l,offset:c,buffer:h,line_exceed:p,ref:0}),this.features=this.features||{},this.features[s]=this.features[s]||[],this.features[s].push(a),this.tile_data[n.key]||this.startData(n.key),this.tile_data[n.key].queue.push([e,t,r])}}},build:function(e,t){var r=this.makeVertexTemplate(e);for(var n in e.labels){var i=e.labels[n];this.buildQuad([i.position],i.size.texture_text_size,u.radToDeg(i.angle)||0,t,r,i.options.offset)}},buildLines:function(e,t,r){this.build(t,r)},buildPoints:function(e,t,r){this.build(t,r)},buildPolygons:function(e,t,r){this.build(t,r)},_parseFeature:function(e,t,r){var n=e.text,i=this.feature_style,o=r.tile.key,a=this.feature_style_key[o].get(e),s=this.texts[o]&&this.texts[o][a]&&this.texts[o][a][n];return s&&this.feature_labels[o].has(e)?(this.texcoord_scale=s.texcoords,i.text=n,i.labels=this.feature_labels[o].get(e),i.color=m.white,i.centroid=!0,i.z=t.z&&p.cacheDistance(t.z,r)||p.defaults.z,i):void 0}}),m.texture_id=0,m.white=[1,1,1,1]},{"../../gl/texture":81,"../../utils/utils":118,"../../utils/worker_broker":120,"../builders":98,"../points/points":100,"../style_parser":105,"./feature_label":106,"./label_builder":108,"./label_options":110,loglevel:60}],113:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);tthis.coords.z&&(this.units_per_pixel/=Math.pow(2,this.style_zoom-this.coords.z)),this.meshes={},this.textures=[]}return o(e,{freeResources:{value:function(){if(this.meshes)for(var e in this.meshes)this.meshes[e].destroy();if(this.textures){var t=!0,r=!1,n=void 0;try{for(var i,o=this.textures[Symbol.iterator]();!(t=(i=o.next()).done);t=!0){var a=i.value,s=f.textures[a];s&&s.destroy()}}catch(u){r=!0,n=u}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}}this.meshes={},this.textures=[]}},destroy:{value:function(){this.workerMessage("removeTile",this.key),this.freeResources(),this.worker=null}},buildAsMessage:{value:function(){return{key:this.key,coord_key:this.coord_key,source:this.source.name,coords:this.coords,min:this.min,max:this.max,units_per_pixel:this.units_per_pixel,style_zoom:this.style_zoom,generation:this.generation,debug:this.debug}}},workerMessage:{value:function(){for(var e=arguments.length,t=Array(e),r=0;e>r;r++)t[r]=arguments[r];return c.postMessage.apply(c,[this.worker].concat(t))}},build:{value:function(e){return this.generation=e,this.loaded||(this.loading=!0),this.workerMessage("buildTile",{tile:this.buildAsMessage()})["catch"](function(e){throw e})}},buildMeshes:{value:function(e){if(!this.error){this.freeResources(),this.debug.geometries=0,this.debug.buffer_size=0;var t=this.mesh_data;if(t)for(var r in t){if(t[r].vertex_data){if(this.debug.buffer_size+=t[r].vertex_data.byteLength,!e[r]){h.warn("Could not create mesh because style '"+r+"' not found, for tile "+this.key+", aborting tile"),this.meshes={};break}this.meshes[r]=e[r].makeMesh(t[r].vertex_data,t[r]),this.debug.geometries+=this.meshes[r].geometry_count}if(t[r].textures){var n;(n=this.textures).push.apply(n,i(t[r].textures))}}this.debug.geom_ratio=(this.debug.geometries/this.debug.features).toFixed(1),this.mesh_data=null,this.printDebug()}}},printDebug:{value:function(){h.debug("Tile: debug for "+this.key+": [ "+JSON.stringify(this.debug)+" ]")}},update:{value:function(t){var r=this.coords;r.z!==t.center_tile.z&&(r=e.coordinateAtZoom(r,t.center_tile.z)),this.center_dist=Math.abs(t.center_tile.x-r.x)+Math.abs(t.center_tile.y-r.y)}},merge:{value:function(e){for(var t in e)"key"!==t&&(this[t]=e[t]);return this}}},{create:{value:function(t){return new e(t)}},coordKey:{value:function(e){var t=e.x,r=e.y,n=e.z;return[t,r,n].join("/")}},key:{value:function(t,r,n){return t=e.overZoomedCoordinate(t,r.max_zoom),[r.name,n,t.x,t.y,t.z].join("/")}},coordinateAtZoom:{value:function(e,t){var r=e.x,n=e.y,i=e.z;if(i!==t){var o=Math.pow(2,i-t);r=Math.floor(r/o),n=Math.floor(n/o)}return{x:r,y:n,z:t}}},isChild:{value:function(t,r){if(r.z>t.z){var n=e.coordinateAtZoom(r,t.z),i=n.x,o=n.y;return t.x===i&&t.y===o}return!1}},overZoomedCoordinate:{value:function(t,r){var n=t.x,i=t.y,o=t.z;return void 0!==r&&o>r?e.coordinateAtZoom({x:n,y:i,z:o},r):{x:n,y:i,z:o}}},sort:{value:function(e){return e.sort(function(e,t){var r=e.center_dist,n=t.center_dist;return n>r?-1:n===r?0:1})}},buildGeometry:{value:function(t,r,n,i){t.debug.rendering=+new Date,t.debug.features=0;var o=t.source_data;for(var a in r){(function(a){var s=r[a];if(!s.data)return h.warn("Layer "+s+" was defined without a geometry data source and will not be rendered."),"continue";if(s.data.source!==t.source)return"continue";var l=e.getDataForSource(o,s.data,a);return 0===l.length?"continue":void l.forEach(function(e){var r=e.geom;if(r)for(var o=0;on?-1:i===n?0:1}),this.queued_coords.forEach(function(t){return e.loadCoordinate(t)}),this.queued_coords=[])},loadCoordinate:function(e){if(e.z===this.scene.center_tile.z){var t=!0,r=!1,n=void 0;try{for(var i,s=a.values(this.scene.sources)[Symbol.iterator]();!(t=(i=s.next()).done);t=!0){var u=i.value;if(u.tiled){var l=o.key(e,u,this.scene.tile_zoom);if(!this.hasTile(l)){var c=o.create({source:u,coords:e,worker:this.scene.nextWorker(),style_zoom:this.scene.styleZoom(e.z)});this.keepTile(c),this.buildTile(c)}}}}catch(f){r=!0,n=f}finally{try{!t&&s["return"]&&s["return"]()}finally{if(r)throw n}}}},buildTiles:function(e){var t=this;o.sort(e).forEach(function(e){return t.buildTile(e)}),this.checkBuildQueue()},buildTile:function(e){var t=this;this.tileBuildStart(e.key),this.updateVisibility(e),e.update(this.scene),e.build(this.scene.generation).then(function(e){return t.buildTileCompleted(e)})["catch"](function(){t.forgetTile(e.key),o.abortBuild(e)})},buildTileCompleted:function(e){var t=e.tile;null==this.tiles[t.key]?(s.trace("discarded tile "+t.key+" in TileManager.buildTileCompleted because previously removed"),o.abortBuild(t),this.scene.updateBounds()):t.generation!==this.scene.generation?(s.debug("discarded tile "+t.key+" in TileManager.buildTileCompleted because built with "+("scene config gen "+t.generation+", current "+this.scene.generation)),this.forgetTile(t.key),o.abortBuild(t),this.scene.updateBounds()):(this.tiles[t.key]&&(t=this.tiles[t.key].merge(t)),this.updateVisibility(t),t.update(this.scene),t.buildMeshes(this.scene.styles),this.scene.requestRedraw()),this.tileBuildStop(t.key)},tileBuildStart:function(e){this.building_tiles=this.building_tiles||{},this.building_tiles[e]=!0,s.trace("tileBuildStart for "+e+": "+Object.keys(this.building_tiles).length)},tileBuildStop:function(e){this.building_tiles&&(s.trace("tileBuildStop for "+e+": "+Object.keys(this.building_tiles).length),delete this.building_tiles[e],this.checkBuildQueue())},checkBuildQueue:function(){this.building_tiles&&0!==Object.keys(this.building_tiles).length||(this.building_tiles=null,this.scene.tileManagerBuildDone())},getDebugSum:function(e,t){var r=0;for(var n in this.tiles)null==this.tiles[n].debug[e]||"function"==typeof t&&t(this.tiles[n])!==!0||(r+=this.tiles[n].debug[e]);return r},getDebugAverage:function(e,t){return this.getDebugSum(e,t)/Object.keys(this.tiles).length}}},{"./tile":113,"./utils/utils":118,loglevel:60}],115:[function(e,t,r){"use strict";var n=function a(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:a(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},i=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});r.MethodNotImplemented=function(e){function t(e){o(this,t),n(Object.getPrototypeOf(t.prototype),"constructor",this).call(this),this.name="MethodNotImplemented",this.message="Method "+e+" must be implemented in subclass"}return i(t,e),t}(Error)},{}],116:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("../vector")),s=function(){function e(t,r,n,i,a){o(this,e),this.dimension=[i,a],this.angle=n,this.centroid=[t,r],this.quad=[],this.axes=[],this.update()}return i(e,{move:{value:function(e,t){this.centroid=[e,t],this.update()}},getExtent:{value:function(){for(var e=1e6,t=[e,e,-e,-e],r=0;4>r;++r)t[0]=Math.min(this.quad[r][0],t[0]),t[1]=Math.min(this.quad[r][1],t[1]),t[2]=Math.max(this.quad[r][0],t[2]),t[3]=Math.max(this.quad[r][1],t[3]);return t}},perpAxes:{value:function(){this.axes[0]=a.normalize(a.sub(this.quad[2],this.quad[3])),this.axes[1]=a.normalize(a.sub(this.quad[2],this.quad[1]))}},update:{value:function(){var e=[Math.cos(this.angle),Math.sin(this.angle)],t=[-Math.sin(this.angle),Math.cos(this.angle)];e=a.mult(e,this.dimension[0]/2),t=a.mult(t,this.dimension[1]/2),this.quad[0]=a.sub(a.sub(this.centroid,e),t),this.quad[1]=a.sub(a.add(this.centroid,e),t),this.quad[2]=a.add(a.add(this.centroid,e),t),this.quad[3]=a.add(a.sub(this.centroid,e),t),this.perpAxes()}}},{projectToAxis:{value:function(e,t){for(var r=1e6,n=r,i=-r,o=e.quad,s=0;4>s;++s){var u=a.dot(o[s],t);n=Math.min(n,u),i=Math.max(i,u)}return[n,i]}},axisCollide:{value:function(t,r,n){for(var i=0;2>i;++i){var o=e.projectToAxis(t,n[i]),a=e.projectToAxis(r,n[i]);if(a[0]>o[1]||a[1]1?r-1:0),i=1;r>i;i++)n[i-1]=arguments[i];var o=!0,a=!1,s=void 0;try{for(var u,l=t[Symbol.iterator]();!(o=(u=l.next()).done);o=!0){var c=u.value;"function"==typeof c[e]&&c[e].apply(c,n)}}catch(f){a=!0,s=f}finally{try{!o&&l["return"]&&l["return"]()}finally{if(a)throw s}}}})}t.exports=n},{}],118:[function(require,module,exports){"use strict";var _interopRequire=function(e){return e&&e.__esModule?e["default"]:e},log=_interopRequire(require("loglevel")),yaml=_interopRequire(require("js-yaml")),Geo=_interopRequire(require("../geo")),Utils;module.exports=Utils={},Utils.addBaseURL=function(e,t){if(e){if("//"===e.substr(0,2))e=window.location.protocol+e;else if(e.search(/^(http|https|data|blob):/)<0){var r,n="/"!==e[0];if(t?(r=document.createElement("a"),r.href=t):r=window.location,n){var i=r.href.match(/([^\#]+)/);i=i&&i.length>1?i[0]:"",e=i+e}else if(r.origin)e=r.origin+"/"+e;else{var o=e.match(/^((http|https|data|blob):\/\/[^\/]*\/)/);o=o&&o.length>1?o[0]:"",e=o+e}}return e}},Utils.pathForURL=function(e){return-1===e.search(/^(data|blob):/)?e.substr(0,e.lastIndexOf("/")+1):""},Utils.cacheBusterForUrl=function(e){return e.search(/^(data|blob):/)>-1?e:e+"?"+ +new Date},Utils._createObjectURL=void 0,Utils.createObjectURL=function(e){return void 0===Utils._createObjectURL&&(Utils._createObjectURL=window.URL&&window.URL.createObjectURL||window.webkitURL&&window.webkitURL.createObjectURL,"function"!=typeof Utils._createObjectURL&&(Utils._createObjectURL=null,log.warn("window.URL.createObjectURL (or vendor prefix) not found, unable to create local blob URLs"))),Utils._createObjectURL?Utils._createObjectURL(e):e},Utils.io=function(e){var t=void 0===arguments[1]?6e4:arguments[1],r=void 0===arguments[2]?"text":arguments[2],n=void 0===arguments[3]?"GET":arguments[3],i=(void 0===arguments[4]?{}:arguments[4],new XMLHttpRequest),o=new Promise(function(o,a){i.open(n,e,!0),i.timeout=t,i.responseType=r,i.onload=function(){200===i.status?o(["text","json"].indexOf(i.responseType)>-1?i.responseText:i.response):a(Error("Request error with a status of "+i.statusText))},i.onerror=function(e){a(Error("There was a network error"+e.toString()))},i.ontimeout=function(e){a(Error("timeout "+e.toString()))},i.send()});return Object.defineProperty(o,"request",{value:i}),o},Utils.parseResource=function(e){var t;try{t=yaml.safeLoad(e)}catch(r){throw r}return t},Utils.loadResource=function(e){return new Promise(function(t,r){"string"==typeof e?Utils.io(Utils.cacheBusterForUrl(e)).then(function(e){try{var n=Utils.parseResource(e);t(n)}catch(i){r(i)}},r):t(e)})},Utils.requestAnimationFramePolyfill=function(){"function"!=typeof window.requestAnimationFrame&&(window.requestAnimationFrame=window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)})},Utils.serializeWithFunctions=function(e){var t=JSON.stringify(e,function(e,t){return"function"==typeof t?t.toString():t});return t},Utils.deserializeWithFunctions=function(e,t){var r=JSON.parse(e);return r=Utils.stringsToFunctions(r,t)},Utils.stringsToFunctions=function(e,t){if("string"==typeof e)e=Utils.stringToFunction(e,t);else if("object"==typeof e)for(var r in e)e[r]=Utils.stringsToFunctions(e[r],t);return e},Utils.stringToFunction=function(val,wrap){if(null!=val.match(/^\s*function\s*\w*\s*\([\s\S]*\)\s*\{[\s\S]*\}/m)){var f;try{return"function"==typeof wrap?eval("f = "+wrap(val)):eval("f = "+val),f}catch(e){return val}}return val},Utils.log=function(e){for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];e=e||"info",Utils.isWorkerThread?self.postMessage({type:"log",level:e,worker_id:self._worker_id,msg:r}):"function"==typeof log[e]&&log[e].apply(log,r)},Utils.use_high_density_display=!0,Utils.updateDevicePixelRatio=function(){Utils.device_pixel_ratio=Utils.use_high_density_display&&window.devicePixelRatio||1},function(){try{void 0!==window.document&&(Utils.isWorkerThread=!1,Utils.isMainThread=!0,Utils.updateDevicePixelRatio())}catch(e){void 0!==self&&(Utils.isWorkerThread=!0,Utils.isMainThread=!1)}}(),Utils.findCurrentURL=function(){for(var e=arguments.length,t=Array(e),r=0;e>r;r++)t[r]=arguments[r];var n=document.currentScript;if(n)return n.src;if(Array.isArray(t))for(var i=document.getElementsByTagName("script"),o=0;o-1)return i[o].src}}catch(h){s=!0,u=h}finally{try{!a&&c["return"]&&c["return"]()}finally{if(s)throw u}}}},Utils.isPowerOf2=function(e){return 0===(e&e-1)},Utils.nextPowerOf2=function(e){return Math.pow(2,Math.ceil(Math.log2(e)))},Utils.interpolate=function(e,t){if(!Array.isArray(t)||!Array.isArray(t[0]))return t;if(t.length<1)return t;var r,n,i,o;if(e<=t[0][0])o=t[0][1];else if(e>=t[t.length-1][0])o=t[t.length-1][1];else for(var a=0;a=t[a][0]&&e=0&&e[1]>-Geo.tile_scale&&e[0]r;r++){var i=e.charCodeAt(r);t=(t<<5)-t+i,t|=0}return t}},{"../geo":73,"js-yaml":29,loglevel:60}],119:[function(e,t,r){"use strict";var n;t.exports=n={string:"v0.3.0",major:0,minor:3,patch:0,pre:!1}},{}],120:[function(e,t,r){"use strict";function n(){a.postMessage=function(e,t){for(var r=arguments.length,n=Array(r>2?r-2:0),i=2;r>i;i++)n[i-2]=arguments[i];var o=new Promise(function(e,r){c[l]={method:t,message:n,resolve:e,reject:r}});return e.postMessage({type:"main_send",message_id:l,method:t,message:n}),l++,o};var e=0,t={};a.addWorker=function(n){n._worker_broker_id=e++,t[n._worker_broker_id]=n,n.addEventListener("message",function(e){ +}throw new TypeError("Invalid attempt to destructure non-iterable instance")};Object.defineProperty(r,"__esModule",{value:!0});var o=n(e("../builders")),a=n(e("../../gl/texture")),s=n(e("../../utils/worker_broker")),u=n(e("../../utils/utils")),l=e("../points/points").Points,c=n(e("./label_builder")),f=n(e("./feature_label")),h=n(e("./label_options")),p=e("../style_parser").StyleParser,d=n(e("loglevel")),m=Object.create(l);r.TextStyle=m,Object.assign(m,{name:"text","super":l,built_in:!0,selection:!1,init:function(){this["super"].init.apply(this,arguments),this.main_thread_target="TextStyle-"+this.name,u.isMainThread&&s.addTarget(this.main_thread_target,this),this.defines.TANGRAM_POINT_TEXTURE=!0,this.defines.TANGRAM_UNMULTIPLY_ALPHA=!0,this.default_font_style={style:"normal",weight:null,size:"12px",family:"Helvetica",fill:"white"},this.reset()},reset:function(){this["super"].reset.call(this),this.texts={},this.textures={},this.canvas={},this.aabbs={},this.features={},this.feature_labels={},this.feature_style_key={}},freeTile:function(e){delete this.texts[e],delete this.textures[e],delete this.canvas[e],delete this.aabbs[e];for(var t in this.features){for(var r=this.features[t],n=0;nt&&(t=s[0]),r+=s[1]}}return[t,r]},getTextSizes:function(e,t){if(!this.canvas[e]){var r=document.createElement("canvas");this.canvas[e]={canvas:r,context:r.getContext("2d")}}for(var n in t){var i=t[n];for(var o in i){var a=i[o].text_style;this.setFont(e,a),i[o].size=this.textSize(o,e,a.transform)}}return Promise.resolve(t)},rasterize:function(e,t,r){for(var n in t){var i=t[n];for(var a in i){var s=i[a];this.setFont(e,s.text_style),this.drawText(a,s.position,e,s.text_style.stroke,s.text_style.transform),s.texcoords=o.getTexcoordsForSprite(s.position,s.size.texture_text_size,r)}}},addTexts:function(e,t){if(!this.canvas[e])return Promise.resolve({});var r=this.setTextureTextPositions(t),n=this.canvas[e].context;d.trace("text summary for tile "+e+": fits in "+r[0]+"x"+r[1]+"px"),this.canvas[e].canvas.width=r[0],this.canvas[e].canvas.height=r[1],n.clearRect(0,0,r[0],r[1]);var i="labels-"+e+"-"+m.texture_id++;return this.textures[e]=new a(this.gl,i),this.rasterize(e,t,r),this.textures[e].setCanvas(this.canvas[e].canvas,{filtering:"linear",UNPACK_PREMULTIPLY_ALPHA_WEBGL:!0}),delete this.textures[e],delete this.canvas[e],Promise.resolve({texts:t,texture:i})},startData:function(e){var t=this["super"].startData.apply(this,arguments);return t.queue=[],t},createLabels:function(e,t){var r={};for(var n in t){var i=t[n];for(var o in i){var a=i[o];a.ref=0;var s=u.hashString(e+n+o);if(this.features[s])for(var l=this.features[s],f=0;f0&&(n=Object.keys(this.texts[e]||{}).length,d.trace("# texts for tile "+e+": "+n)),n?s.postMessage(this.main_thread_target,"getTextSizes",e,this.texts[e]).then(function(n){if(!n)return t.freeTile(e),t["super"].endData.apply(t,r);var o=t.createLabels(e,n);return o?(t.discardLabels(e,o,n),0===Object.keys(n).length?(t.freeTile(e),void s.postMessage(t.main_thread_target,"freeTile",e)):s.postMessage(t.main_thread_target,"addTexts",e,n).then(function(n){var o=n.texts,a=n.texture;return o&&(t.texts[e]=o,i.uniforms={u_texture:a},i.textures=[a],i.queue.forEach(function(e){return t["super"].addFeature.apply(t,e)}),i.queue=[]),t.freeTile(e),t["super"].endData.apply(t,r)})):(t.freeTile(e),t["super"].endData.apply(t,r))}):Promise.resolve()},addFeature:function(e,t,r){var n=r.tile;if(n.generation===this.generation){var i=void 0,o=t.text_source||"name";if("string"==typeof o?i=e.properties[o]:"function"==typeof o&&(i=o(r)),i){e.text=i,this.texts[n.key]||(this.texts[n.key]=this.texts[n.key]||{});var a=new f(e,t,r,i,n,this.default_font_style),s=a.getHash();if(!a.style)return;var u=a.style_key;this.feature_style_key[n.key]=this.feature_style_key[n.key]||new Map,this.feature_style_key[n.key].set(e,u),this.texts[n.key][u]||(this.texts[n.key][u]={});var l=t.priority;void 0!==l?"function"==typeof l&&(l=l(r)):l=-1>>>0;var c=t.offset||[0,0];c[0]=parseFloat(c[0]),c[1]=parseFloat(c[1]);var h=t.buffer;null!=h&&(Array.isArray(h)||(h=[h,h]),h[0]=parseFloat(h[0]),h[1]=parseFloat(h[1]));var p=void 0;t.line_exceed&&"%"===t.line_exceed.substr(-1)&&(p=t.line_exceed.substr(0,t.line_exceed.length-1)),this.texts[n.key][u][i]||(this.texts[n.key][u][i]={text_style:a.style,units_per_pixel:n.units_per_pixel,priority:l,offset:c,buffer:h,line_exceed:p,ref:0}),this.features=this.features||{},this.features[s]=this.features[s]||[],this.features[s].push(a),this.tile_data[n.key]||this.startData(n.key),this.tile_data[n.key].queue.push([e,t,r])}}},build:function(e,t){var r=this.makeVertexTemplate(e);for(var n in e.labels){var i=e.labels[n];this.buildQuad([i.position],i.size.texture_text_size,u.radToDeg(i.angle)||0,t,r,i.options.offset)}},buildLines:function(e,t,r){this.build(t,r)},buildPoints:function(e,t,r){this.build(t,r)},buildPolygons:function(e,t,r){this.build(t,r)},_parseFeature:function(e,t,r){var n=e.text,i=this.feature_style,o=r.tile.key,a=this.feature_style_key[o].get(e),s=this.texts[o]&&this.texts[o][a]&&this.texts[o][a][n];return s&&this.feature_labels[o].has(e)?(this.texcoord_scale=s.texcoords,i.text=n,i.labels=this.feature_labels[o].get(e),i.color=m.white,i.centroid=!0,i.z=t.z&&p.cacheDistance(t.z,r)||p.defaults.z,i):void 0}}),m.texture_id=0,m.white=[1,1,1,1]},{"../../gl/texture":81,"../../utils/utils":118,"../../utils/worker_broker":120,"../builders":98,"../points/points":100,"../style_parser":105,"./feature_label":106,"./label_builder":108,"./label_options":110,loglevel:60}],113:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);tthis.coords.z&&(this.units_per_pixel/=Math.pow(2,this.style_zoom-this.coords.z)),this.meshes={},this.textures=[]}return o(e,{freeResources:{value:function(){if(this.meshes)for(var e in this.meshes)this.meshes[e].destroy();if(this.textures){var t=!0,r=!1,n=void 0;try{for(var i,o=this.textures[Symbol.iterator]();!(t=(i=o.next()).done);t=!0){var a=i.value,s=f.textures[a];s&&s.destroy()}}catch(u){r=!0,n=u}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}}this.meshes={},this.textures=[]}},destroy:{value:function(){this.workerMessage("removeTile",this.key),this.freeResources(),this.worker=null}},buildAsMessage:{value:function(){return{key:this.key,coord_key:this.coord_key,source:this.source.name,coords:this.coords,min:this.min,max:this.max,units_per_pixel:this.units_per_pixel,style_zoom:this.style_zoom,generation:this.generation,debug:this.debug}}},workerMessage:{value:function(){for(var e=arguments.length,t=Array(e),r=0;e>r;r++)t[r]=arguments[r];return c.postMessage.apply(c,[this.worker].concat(t))}},build:{value:function(e){return this.generation=e,this.loaded||(this.loading=!0),this.workerMessage("buildTile",{tile:this.buildAsMessage()})["catch"](function(e){throw e})}},buildMeshes:{value:function(e){if(!this.error){this.freeResources(),this.debug.geometries=0,this.debug.buffer_size=0;var t=this.mesh_data;if(t)for(var r in t){if(t[r].vertex_data){if(this.debug.buffer_size+=t[r].vertex_data.byteLength,!e[r]){h.warn("Could not create mesh because style '"+r+"' not found, for tile "+this.key+", aborting tile"),this.meshes={};break}this.meshes[r]=e[r].makeMesh(t[r].vertex_data,t[r]),this.debug.geometries+=this.meshes[r].geometry_count}if(t[r].textures){var n;(n=this.textures).push.apply(n,i(t[r].textures))}}this.debug.geom_ratio=(this.debug.geometries/this.debug.features).toFixed(1),this.mesh_data=null,this.printDebug()}}},printDebug:{value:function(){h.debug("Tile: debug for "+this.key+": [ "+JSON.stringify(this.debug)+" ]")}},update:{value:function(t){var r=this.coords;r.z!==t.center_tile.z&&(r=e.coordinateAtZoom(r,t.center_tile.z)),this.center_dist=Math.abs(t.center_tile.x-r.x)+Math.abs(t.center_tile.y-r.y)}},merge:{value:function(e){for(var t in e)"key"!==t&&(this[t]=e[t]);return this}}},{create:{value:function(t){return new e(t)}},coordKey:{value:function(e){var t=e.x,r=e.y,n=e.z;return[t,r,n].join("/")}},key:{value:function(t,r,n){return t=e.overZoomedCoordinate(t,r.max_zoom),[r.name,n,t.x,t.y,t.z].join("/")}},coordinateAtZoom:{value:function(e,t){var r=e.x,n=e.y,i=e.z;if(i!==t){var o=Math.pow(2,i-t);r=Math.floor(r/o),n=Math.floor(n/o)}return{x:r,y:n,z:t}}},isChild:{value:function(t,r){if(r.z>t.z){var n=e.coordinateAtZoom(r,t.z),i=n.x,o=n.y;return t.x===i&&t.y===o}return!1}},overZoomedCoordinate:{value:function(t,r){var n=t.x,i=t.y,o=t.z;return void 0!==r&&o>r?e.coordinateAtZoom({x:n,y:i,z:o},r):{x:n,y:i,z:o}}},sort:{value:function(e){return e.sort(function(e,t){var r=e.center_dist,n=t.center_dist;return n>r?-1:n===r?0:1})}},buildGeometry:{value:function(t,r,n,i){t.debug.rendering=+new Date,t.debug.features=0;var o=t.source_data;for(var a in r){(function(a){var s=r[a];if(!s.data)return h.warn("Layer "+s+" was defined without a geometry data source and will not be rendered."),"continue";if(s.data.source!==t.source)return"continue";var l=e.getDataForSource(o,s.data,a);return 0===l.length?"continue":void l.forEach(function(e){var r=e.geom;if(r)for(var o=0;on?-1:i===n?0:1}),this.queued_coords.forEach(function(t){return e.loadCoordinate(t)}),this.queued_coords=[])},loadCoordinate:function(e){if(e.z===this.scene.center_tile.z){var t=!0,r=!1,n=void 0;try{for(var i,s=a.values(this.scene.sources)[Symbol.iterator]();!(t=(i=s.next()).done);t=!0){var u=i.value;if(u.tiled){var l=o.key(e,u,this.scene.tile_zoom);if(!this.hasTile(l)){var c=o.create({source:u,coords:e,worker:this.scene.nextWorker(),style_zoom:this.scene.styleZoom(e.z)});this.keepTile(c),this.buildTile(c)}}}}catch(f){r=!0,n=f}finally{try{!t&&s["return"]&&s["return"]()}finally{if(r)throw n}}}},buildTiles:function(e){var t=this;o.sort(e).forEach(function(e){return t.buildTile(e)}),this.checkBuildQueue()},buildTile:function(e){var t=this;this.tileBuildStart(e.key),this.updateVisibility(e),e.update(this.scene),e.build(this.scene.generation).then(function(e){return t.buildTileCompleted(e)})["catch"](function(){t.forgetTile(e.key),o.abortBuild(e)})},buildTileCompleted:function(e){var t=e.tile;null==this.tiles[t.key]?(s.trace("discarded tile "+t.key+" in TileManager.buildTileCompleted because previously removed"),o.abortBuild(t),this.scene.updateBounds()):t.generation!==this.scene.generation?(s.debug("discarded tile "+t.key+" in TileManager.buildTileCompleted because built with "+("scene config gen "+t.generation+", current "+this.scene.generation)),this.forgetTile(t.key),o.abortBuild(t),this.scene.updateBounds()):(this.tiles[t.key]&&(t=this.tiles[t.key].merge(t)),this.updateVisibility(t),t.update(this.scene),t.buildMeshes(this.scene.styles),this.scene.requestRedraw()),this.tileBuildStop(t.key)},tileBuildStart:function(e){this.building_tiles=this.building_tiles||{},this.building_tiles[e]=!0,s.trace("tileBuildStart for "+e+": "+Object.keys(this.building_tiles).length)},tileBuildStop:function(e){this.building_tiles&&(s.trace("tileBuildStop for "+e+": "+Object.keys(this.building_tiles).length),delete this.building_tiles[e],this.checkBuildQueue())},checkBuildQueue:function(){this.building_tiles&&0!==Object.keys(this.building_tiles).length||(this.building_tiles=null,this.scene.tileManagerBuildDone())},getDebugSum:function(e,t){var r=0;for(var n in this.tiles)null==this.tiles[n].debug[e]||"function"==typeof t&&t(this.tiles[n])!==!0||(r+=this.tiles[n].debug[e]);return r},getDebugAverage:function(e,t){return this.getDebugSum(e,t)/Object.keys(this.tiles).length}}},{"./tile":113,"./utils/utils":118,loglevel:60}],115:[function(e,t,r){"use strict";var n=function a(e,t,r){var n=Object.getOwnPropertyDescriptor(e,t);if(void 0===n){var i=Object.getPrototypeOf(e);return null===i?void 0:a(i,t,r)}if("value"in n&&n.writable)return n.value;var o=n.get;return void 0===o?void 0:o.call(r)},i=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)},o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")};Object.defineProperty(r,"__esModule",{value:!0});r.MethodNotImplemented=function(e){function t(e){o(this,t),n(Object.getPrototypeOf(t.prototype),"constructor",this).call(this),this.name="MethodNotImplemented",this.message="Method "+e+" must be implemented in subclass"}return i(t,e),t}(Error)},{}],116:[function(e,t,r){"use strict";var n=function(e){return e&&e.__esModule?e["default"]:e},i=function(){function e(e,t){for(var r in t){var n=t[r];n.configurable=!0,n.value&&(n.writable=!0)}Object.defineProperties(e,t)}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),o=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},a=n(e("../vector")),s=function(){function e(t,r,n,i,a){o(this,e),this.dimension=[i,a],this.angle=n,this.centroid=[t,r],this.quad=[],this.axes=[],this.update()}return i(e,{move:{value:function(e,t){this.centroid=[e,t],this.update()}},getExtent:{value:function(){for(var e=1e6,t=[e,e,-e,-e],r=0;4>r;++r)t[0]=Math.min(this.quad[r][0],t[0]),t[1]=Math.min(this.quad[r][1],t[1]),t[2]=Math.max(this.quad[r][0],t[2]),t[3]=Math.max(this.quad[r][1],t[3]);return t}},perpAxes:{value:function(){this.axes[0]=a.normalize(a.sub(this.quad[2],this.quad[3])),this.axes[1]=a.normalize(a.sub(this.quad[2],this.quad[1]))}},update:{value:function(){var e=[Math.cos(this.angle),Math.sin(this.angle)],t=[-Math.sin(this.angle),Math.cos(this.angle)];e=a.mult(e,this.dimension[0]/2),t=a.mult(t,this.dimension[1]/2),this.quad[0]=a.sub(a.sub(this.centroid,e),t),this.quad[1]=a.sub(a.add(this.centroid,e),t),this.quad[2]=a.add(a.add(this.centroid,e),t),this.quad[3]=a.add(a.sub(this.centroid,e),t),this.perpAxes()}}},{projectToAxis:{value:function(e,t){for(var r=1e6,n=r,i=-r,o=e.quad,s=0;4>s;++s){var u=a.dot(o[s],t);n=Math.min(n,u),i=Math.max(i,u)}return[n,i]}},axisCollide:{value:function(t,r,n){for(var i=0;2>i;++i){var o=e.projectToAxis(t,n[i]),a=e.projectToAxis(r,n[i]);if(a[0]>o[1]||a[1]1?r-1:0),i=1;r>i;i++)n[i-1]=arguments[i];var o=!0,a=!1,s=void 0;try{for(var u,l=t[Symbol.iterator]();!(o=(u=l.next()).done);o=!0){var c=u.value;"function"==typeof c[e]&&c[e].apply(c,n)}}catch(f){a=!0,s=f}finally{try{!o&&l["return"]&&l["return"]()}finally{if(a)throw s}}}})}t.exports=n},{}],118:[function(require,module,exports){"use strict";var _interopRequire=function(e){return e&&e.__esModule?e["default"]:e},log=_interopRequire(require("loglevel")),yaml=_interopRequire(require("js-yaml")),Geo=_interopRequire(require("../geo")),Utils;module.exports=Utils={},Utils.addBaseURL=function(e,t){if(e){if("//"===e.substr(0,2))e=window.location.protocol+e;else if(e.search(/^(http|https|data|blob):/)<0){var r,n="/"!==e[0];if(t?(r=document.createElement("a"),r.href=t):r=window.location,n){var i=r.href.match(/([^\#]+)/);i=i&&i.length>1?i[0]:"",e=i+e}else if(r.origin)e=r.origin+"/"+e;else{var o=e.match(/^((http|https|data|blob):\/\/[^\/]*\/)/);o=o&&o.length>1?o[0]:"",e=o+e}}return e}},Utils.pathForURL=function(e){return-1===e.search(/^(data|blob):/)?e.substr(0,e.lastIndexOf("/")+1)||"./":"./"},Utils.cacheBusterForUrl=function(e){return e.search(/^(data|blob):/)>-1?e:e+"?"+ +new Date},Utils._createObjectURL=void 0,Utils.createObjectURL=function(e){return void 0===Utils._createObjectURL&&(Utils._createObjectURL=window.URL&&window.URL.createObjectURL||window.webkitURL&&window.webkitURL.createObjectURL,"function"!=typeof Utils._createObjectURL&&(Utils._createObjectURL=null,log.warn("window.URL.createObjectURL (or vendor prefix) not found, unable to create local blob URLs"))),Utils._createObjectURL?Utils._createObjectURL(e):e},Utils.io=function(e){var t=void 0===arguments[1]?6e4:arguments[1],r=void 0===arguments[2]?"text":arguments[2],n=void 0===arguments[3]?"GET":arguments[3],i=(void 0===arguments[4]?{}:arguments[4],new XMLHttpRequest),o=new Promise(function(o,a){i.open(n,e,!0),i.timeout=t,i.responseType=r,i.onload=function(){200===i.status?o(["text","json"].indexOf(i.responseType)>-1?i.responseText:i.response):a(Error("Request error with a status of "+i.statusText))},i.onerror=function(e){a(Error("There was a network error"+e.toString()))},i.ontimeout=function(e){a(Error("timeout "+e.toString()))},i.send()});return Object.defineProperty(o,"request",{value:i}),o},Utils.parseResource=function(e){var t;try{t=yaml.safeLoad(e)}catch(r){throw r}return t},Utils.loadResource=function(e){return new Promise(function(t,r){"string"==typeof e?Utils.io(Utils.cacheBusterForUrl(e)).then(function(e){try{var n=Utils.parseResource(e);t(n)}catch(i){r(i)}},r):t(e)})},Utils.requestAnimationFramePolyfill=function(){"function"!=typeof window.requestAnimationFrame&&(window.requestAnimationFrame=window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)})},Utils.serializeWithFunctions=function(e){var t=JSON.stringify(e,function(e,t){return"function"==typeof t?t.toString():t});return t},Utils.deserializeWithFunctions=function(e,t){var r=JSON.parse(e);return r=Utils.stringsToFunctions(r,t)},Utils.stringsToFunctions=function(e,t){if("string"==typeof e)e=Utils.stringToFunction(e,t);else if("object"==typeof e)for(var r in e)e[r]=Utils.stringsToFunctions(e[r],t);return e},Utils.stringToFunction=function(val,wrap){if(null!=val.match(/^\s*function\s*\w*\s*\([\s\S]*\)\s*\{[\s\S]*\}/m)){var f;try{return"function"==typeof wrap?eval("f = "+wrap(val)):eval("f = "+val),f}catch(e){return val}}return val},Utils.log=function(e){for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];e=e||"info",Utils.isWorkerThread?self.postMessage({type:"log",level:e,worker_id:self._worker_id,msg:r}):"function"==typeof log[e]&&log[e].apply(log,r)},Utils.use_high_density_display=!0,Utils.updateDevicePixelRatio=function(){Utils.device_pixel_ratio=Utils.use_high_density_display&&window.devicePixelRatio||1},function(){try{void 0!==window.document&&(Utils.isWorkerThread=!1,Utils.isMainThread=!0,Utils.updateDevicePixelRatio())}catch(e){void 0!==self&&(Utils.isWorkerThread=!0,Utils.isMainThread=!1)}}(),Utils.findCurrentURL=function(){for(var e=arguments.length,t=Array(e),r=0;e>r;r++)t[r]=arguments[r];var n=document.currentScript;if(n)return n.src;if(Array.isArray(t))for(var i=document.getElementsByTagName("script"),o=0;o-1)return i[o].src}}catch(h){s=!0,u=h}finally{try{!a&&c["return"]&&c["return"]()}finally{if(s)throw u}}}},Utils.isPowerOf2=function(e){return 0===(e&e-1)},Utils.nextPowerOf2=function(e){return Math.pow(2,Math.ceil(Math.log2(e)))},Utils.interpolate=function(e,t){if(!Array.isArray(t)||!Array.isArray(t[0]))return t;if(t.length<1)return t;var r,n,i,o;if(e<=t[0][0])o=t[0][1];else if(e>=t[t.length-1][0])o=t[t.length-1][1];else for(var a=0;a=t[a][0]&&e=0&&e[1]>-Geo.tile_scale&&e[0]r;r++){var i=e.charCodeAt(r);t=(t<<5)-t+i,t|=0}return t}},{"../geo":73,"js-yaml":29,loglevel:60}],119:[function(e,t,r){"use strict";var n;t.exports=n={string:"v0.3.1",major:0,minor:3,patch:1,pre:!1}},{}],120:[function(e,t,r){"use strict";function n(){a.postMessage=function(e,t){for(var r=arguments.length,n=Array(r>2?r-2:0),i=2;r>i;i++)n[i-2]=arguments[i];var o=new Promise(function(e,r){c[l]={method:t,message:n,resolve:e,reject:r}});return e.postMessage({type:"main_send",message_id:l,method:t,message:n}),l++,o};var e=0,t={};a.addWorker=function(n){n._worker_broker_id=e++,t[n._worker_broker_id]=n,n.addEventListener("message",function(e){ if("worker_reply"===e.data.type){var t=e.data.message_id;c[t]&&(e.data.error?c[t].reject(e.data.error):c[t].resolve(e.data.message),delete c[t])}}),n.addEventListener("message",function(e){var t=e.data.message_id;if("worker_send"===e.data.type&&null!=t){var i=r[e.data.target];if(!i)throw Error("Worker broker could not dispatch message type "+e.data.method+" on target "+e.data.target+" because no object with that name is registered on main thread");var o="function"==typeof i[e.data.method]&&i[e.data.method];if(!o)throw Error("Worker broker could not dispatch message type "+e.data.method+" on target "+e.data.target+" because object has no method with that name");var a,s;try{a=o.apply(i,e.data.message)}catch(u){s=u}a instanceof Promise?a.then(function(e){n.postMessage({type:"main_reply",message_id:t,message:e})},function(e){n.postMessage({type:"main_reply",message_id:t,error:e instanceof Error?""+e.message+": "+e.stack:e})}):n.postMessage({type:"main_reply",message_id:t,message:a,error:s instanceof Error?""+s.message+": "+s.stack:s})}})};var r={};a.addTarget=function(e,t){r[e]=t},a.getMessages=function(){return c},a.getMessageId=function(){return l}}function i(){a.postMessage=function(e,t){for(var r=arguments.length,n=Array(r>2?r-2:0),i=2;r>i;i++)n[i-2]=arguments[i];var o=new Promise(function(r,i){c[l]={target:e,method:t,message:n,resolve:r,reject:i}});return self.postMessage({type:"worker_send",message_id:l,target:e,method:t,message:n}),l++,o},self.addEventListener("message",function(e){if("main_reply"===e.data.type){var t=e.data.message_id;c[t]&&(e.data.error?c[t].reject(e.data.error):c[t].resolve(e.data.message),delete c[t])}}),self.addEventListener("message",function(e){var t=e.data.message_id;if("main_send"===e.data.type&&null!=t){var r=e.data.method,n="function"==typeof self[r]&&self[r];if(!n)throw Error("Worker broker could not dispatch message type "+r+" because worker has no method with that name");var i,a;try{i=n.apply(self,e.data.message)}catch(s){a=s}var l=void 0;i instanceof Promise?i.then(function(e){l=o(e),self.postMessage({type:"worker_reply",message_id:t,message:e},l),l.length>0&&u.log("trace","'"+r+"' transferred "+l.length+" objects to main thread")},function(e){self.postMessage({type:"worker_reply",message_id:t,error:e instanceof Error?""+e.message+": "+e.stack:e})}):(l=o(i),self.postMessage({type:"worker_reply",message_id:t,message:i,error:a instanceof Error?""+a.message+": "+a.stack:a},l),l.length>0&&u.log("trace","'"+r+"' transferred "+l.length+" objects to main thread"))}})}function o(e){var t=void 0===arguments[1]?[]:arguments[1];if(!e)return t;if(Array.isArray(e))e.forEach(function(e){return o(e,t)});else if("object"==typeof e)if(e instanceof ArrayBuffer)t.push(e);else if(e.buffer instanceof ArrayBuffer)t.push(e.buffer);else for(var r in e)o(e[r],t);return t}var a,s=function(e){return e&&e.__esModule?e["default"]:e},u=s(e("./utils"));t.exports=a={};var l=0,c={};u.isMainThread&&n(),u.isWorkerThread&&i()},{"./utils":118}],121:[function(e,t,r){"use strict";var n,i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e)){for(var r,n=[],i=e[Symbol.iterator]();!(r=i.next()).done&&(n.push(r.value),!t||n.length!==t););return n}throw new TypeError("Invalid attempt to destructure non-iterable instance")};t.exports=n={},n.set=function(e){for(var t=[],r=e.length,n=0;r>n;n++)t[n]=e[n];return t},n.neg=function(e){for(var t=[],r=e.length,n=0;r>n;n++)t[n]=-1*e[n];return t},n.add=function(e,t){for(var r=[],n=Math.min(e.length,t.length),i=0;n>i;i++)r[i]=e[i]+t[i];return r},n.sub=function(e,t){for(var r=[],n=Math.min(e.length,t.length),i=0;n>i;i++)r[i]=e[i]-t[i];return r},n.signed_area=function(e,t,r){return(t[0]-e[0])*(r[1]-e[1])-(r[0]-e[0])*(t[1]-e[1])},n.mult=function(e,t){var r,n=[],i=e.length;if("number"==typeof t)for(r=0;i>r;r++)n[r]=e[r]*t;else for(i=Math.min(e.length,t.length),r=0;i>r;r++)n[r]=e[r]*t[r];return n},n.div=function(e,t){var r,n=[];if("number"==typeof t)for(r=0;rr;r++)n[r]=e[r]/t[r]}return n},n.perp=function(e,t){return[t[1]-e[1],e[0]-t[0]]},n.rot=function(e,t){var r=n.length(e),i=n.angle(e);return[r*Math.cos(i+t),r*Math.sin(i+t)]},n.angle=function(e){var t=i(e,2),r=t[0],n=t[1];return Math.atan2(n,r)},n.isEqual=function(e,t){for(var r=e.length,n=0;r>n;n++)if(e[n]!==t[n])return!1;return!0},n.lengthSq=function(e){return 2===e.length?e[0]*e[0]+e[1]*e[1]:e[0]*e[0]+e[1]*e[1]+e[2]*e[2]},n.length=function(e){return Math.sqrt(n.lengthSq(e))},n.normalize=function(e){var t;return 2===e.length?(t=e[0]*e[0]+e[1]*e[1],t=Math.sqrt(t),0!==t?[e[0]/t,e[1]/t]:[0,0]):(t=e[0]*e[0]+e[1]*e[1]+e[2]*e[2],t=Math.sqrt(t),0!==t?[e[0]/t,e[1]/t,e[2]/t]:[0,0,0])},n.cross=function(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]},n.dot=function(e,t){for(var r=0,n=Math.min(e.length,t.length),i=0;n>i;i++)r+=e[i]*t[i];return r},n.lineIntersection=function(e,t,r,n,i){i=i||.01;var o=e[1]-t[1],a=e[0]-t[0],s=r[1]-n[1],u=r[0]-n[0],l=e[0]*t[1]-e[1]*t[0],c=r[0]*n[1]-r[1]*n[0],f=a*s-o*u;return Math.abs(f)>i?[(l*u-a*c)/f,(l*s-o*c)/f]:null}},{}],122:[function(e,t,r){t.exports=e("./lib/babel/polyfill")},{"./lib/babel/polyfill":1}]},{},[122,89]); \ No newline at end of file diff --git a/src/utils/version.js b/src/utils/version.js index 12bc34884..967b3c0e1 100644 --- a/src/utils/version.js +++ b/src/utils/version.js @@ -1,8 +1,8 @@ var version; export default version = { - string: 'v0.3.0', + string: 'v0.3.1', major: 0, minor: 3, - patch: 0, + patch: 1, pre: false };