From c14ed7db54181be4f086716e7325e52b4dfcff17 Mon Sep 17 00:00:00 2001 From: Brett Camper Date: Thu, 28 Apr 2016 14:04:59 -0400 Subject: [PATCH] v0.7.2 builds --- dist/tangram.debug.js | 184 +++++++++++++++++++++--------------------- dist/tangram.min.js | 10 +-- 2 files changed, 95 insertions(+), 99 deletions(-) diff --git a/dist/tangram.debug.js b/dist/tangram.debug.js index 07c217bb3..2ec6332f9 100644 --- a/dist/tangram.debug.js +++ b/dist/tangram.debug.js @@ -15112,96 +15112,95 @@ var _createClass = _dereq_("babel-runtime/helpers/create-class")["default"]; var _classCallCheck = _dereq_("babel-runtime/helpers/class-call-check")["default"]; Object.defineProperty(exports, "__esModule", { - value: true + value: true }); var RenderState = (function () { - function RenderState(value, setup) { - _classCallCheck(this, RenderState); - - setup(value); - this.value = value; - this.setup = setup; - } + function RenderState(value, setup) { + _classCallCheck(this, RenderState); - _createClass(RenderState, [{ - key: "set", - value: function set(value) { - // if the states are different, call the GL context for a state change - if (JSON.stringify(this.value) !== JSON.stringify(value)) { - this.setup(value); + setup(value); this.value = value; - } + this.setup = setup; } - }], [{ - key: "initialize", - value: function initialize(gl) { - RenderState.defaults = {}; - // Culling - RenderState.defaults.culling = true; - RenderState.defaults.culling_face = gl.BACK; - - // Blending - RenderState.defaults.blending = false; - RenderState.defaults.blending_src = gl.ONE_MINUS_SRC_ALPHA; - RenderState.defaults.blending_dst = gl.ONE_MINUS_SRC_ALPHA; - RenderState.defaults.blending_src_alpha = gl.ONE; - RenderState.defaults.blending_dst_alpha = gl.ONE_MINUS_SRC_ALPHA; - - // Depth test/write - RenderState.defaults.depth_write = true; - RenderState.defaults.depth_test = true; - RenderState.defaults.depth_func = gl.LESS; - - // Culling - RenderState.culling = new RenderState({ cull: RenderState.defaults.culling, face: RenderState.defaults.culling_face }, function (value) { - if (value.cull) { - gl.enable(gl.CULL_FACE); - gl.cullFace(value.face); - } else { - gl.disable(gl.CULL_FACE); - } - }); - // Blending mode - RenderState.blending = new RenderState({ - blend: RenderState.defaults.blending, - src: RenderState.defaults.blending_src, - dst: RenderState.defaults.blending_dst, - src_alpha: RenderState.defaults.blending_src_alpha, - dst_alpha: RenderState.defaults.blending_dst_alpha - }, function (value) { - if (value.blend) { - gl.enable(gl.BLEND); - - if (value.src_alpha && value.dst_alpha) { - gl.blendFuncSeparate(value.src, value.dst, value.src_alpha, value.dst_alpha); - } else { - gl.blendFunc(value.src, value.dst); - } - } else { - gl.disable(gl.BLEND); + _createClass(RenderState, [{ + key: "set", + value: function set(value) { + // if the states are different, call the GL context for a state change + if (JSON.stringify(this.value) !== JSON.stringify(value)) { + this.setup(value); + this.value = value; + } } - }); + }], [{ + key: "initialize", + value: function initialize(gl) { + RenderState.defaults = {}; + // Culling + RenderState.defaults.culling = true; + RenderState.defaults.culling_face = gl.BACK; + + // Blending + RenderState.defaults.blending = false; + RenderState.defaults.blending_src = gl.ONE_MINUS_SRC_ALPHA; + RenderState.defaults.blending_dst = gl.ONE_MINUS_SRC_ALPHA; + RenderState.defaults.blending_src_alpha = gl.ONE; + RenderState.defaults.blending_dst_alpha = gl.ONE_MINUS_SRC_ALPHA; + + // Depth test/write + RenderState.defaults.depth_write = true; + RenderState.defaults.depth_test = true; + gl.depthFunc(gl.LESS); // depth function only needs to be set once + + // Culling + RenderState.culling = new RenderState({ cull: RenderState.defaults.culling, face: RenderState.defaults.culling_face }, function (value) { + if (value.cull) { + gl.enable(gl.CULL_FACE); + gl.cullFace(value.face); + } else { + gl.disable(gl.CULL_FACE); + } + }); - // Depth write - RenderState.depth_write = new RenderState({ depth_write: RenderState.defaults.depth_write }, function (value) { - gl.depthMask(value.depth_write); - }); + // Blending mode + RenderState.blending = new RenderState({ + blend: RenderState.defaults.blending, + src: RenderState.defaults.blending_src, + dst: RenderState.defaults.blending_dst, + src_alpha: RenderState.defaults.blending_src_alpha, + dst_alpha: RenderState.defaults.blending_dst_alpha + }, function (value) { + if (value.blend) { + gl.enable(gl.BLEND); + + if (value.src_alpha && value.dst_alpha) { + gl.blendFuncSeparate(value.src, value.dst, value.src_alpha, value.dst_alpha); + } else { + gl.blendFunc(value.src, value.dst); + } + } else { + gl.disable(gl.BLEND); + } + }); - // Depth test - RenderState.depth_test = new RenderState({ depth_test: RenderState.defaults.depth_test, depth_func: RenderState.defaults.depth_func }, function (value) { - if (value.depth_test) { - gl.enable(gl.DEPTH_TEST); - gl.depthFunc(value.depth_func); - } else { - gl.disable(gl.DEPTH_TEST); + // Depth write + RenderState.depth_write = new RenderState({ depth_write: RenderState.defaults.depth_write }, function (value) { + gl.depthMask(value.depth_write); + }); + + // Depth test + RenderState.depth_test = new RenderState({ depth_test: RenderState.defaults.depth_test }, function (value) { + if (value.depth_test) { + gl.enable(gl.DEPTH_TEST); + } else { + gl.disable(gl.DEPTH_TEST); + } + }); } - }); - } - }]); + }]); - return RenderState; + return RenderState; })(); exports["default"] = RenderState; @@ -19051,10 +19050,10 @@ var _createClass = _dereq_('babel-runtime/helpers/create-class')['default']; var _classCallCheck = _dereq_('babel-runtime/helpers/class-call-check')['default']; -var _toConsumableArray = _dereq_('babel-runtime/helpers/to-consumable-array')['default']; - var _slicedToArray = _dereq_('babel-runtime/helpers/sliced-to-array')['default']; +var _toConsumableArray = _dereq_('babel-runtime/helpers/to-consumable-array')['default']; + var _Object$assign = _dereq_('babel-runtime/core-js/object/assign')['default']; var _Promise = _dereq_('babel-runtime/core-js/promise')['default']; @@ -19754,17 +19753,10 @@ var Scene = (function () { clear_color = clear_color === false ? false : true; // default true clear_depth = clear_depth === false ? false : true; // default true - // Reset frame state - var gl = this.gl; - - if (clear_color) { - gl.clearColor.apply(gl, _toConsumableArray(this.background.color)); - } - - if (clear_depth) { - gl.depthMask(true); // always clear depth if requested, even if depth write will be turned off - } + // Set GL state + _glRender_state2['default'].depth_write.set({ depth_write: clear_depth }); + var gl = this.gl; if (clear_color || clear_depth) { var mask = (clear_color && gl.COLOR_BUFFER_BIT) | (clear_depth && gl.DEPTH_BUFFER_BIT); gl.clear(mask); @@ -19794,7 +19786,7 @@ var Scene = (function () { // Reset frame state var gl = this.gl; - _glRender_state2['default'].depth_test.set({ depth_test: depth_test, depth_func: _glRender_state2['default'].defaults.depth_func }); + _glRender_state2['default'].depth_test.set({ depth_test: depth_test }); _glRender_state2['default'].depth_write.set({ depth_write: depth_write }); _glRender_state2['default'].culling.set({ cull: cull_face, face: _glRender_state2['default'].defaults.culling_face }); @@ -20294,6 +20286,8 @@ var Scene = (function () { }, { key: 'setBackground', value: function setBackground() { + var _gl; + var bg = this.config.scene.background; this.background = {}; if (bg && bg.color) { @@ -20311,6 +20305,8 @@ var Scene = (function () { } else { this.canvas.style.backgroundColor = 'transparent'; } + + (_gl = this.gl).clearColor.apply(_gl, _toConsumableArray(this.background.color)); } // Update scene config, and optionally rebuild geometry @@ -29334,7 +29330,7 @@ var version; exports["default"] = version = _Object$defineProperties({ major: 0, minor: 7, - patch: 1, + patch: 2, pre: false }, { string: { @@ -30508,6 +30504,6 @@ exports['default'] = View; module.exports = exports['default']; },{"./camera":200,"./geo":201,"./tile":244,"./utils/subscribe":251,"./utils/utils":252,"babel-runtime/helpers/class-call-check":18,"babel-runtime/helpers/create-class":19,"babel-runtime/helpers/interop-require-default":23,"babel-runtime/helpers/sliced-to-array":24,"loglevel":183}]},{},[222]) -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/babel-runtime/core-js/array/from.js","node_modules/babel-runtime/core-js/get-iterator.js","node_modules/babel-runtime/core-js/is-iterable.js","node_modules/babel-runtime/core-js/map.js","node_modules/babel-runtime/core-js/math/log2.js","node_modules/babel-runtime/core-js/object/assign.js","node_modules/babel-runtime/core-js/object/create.js","node_modules/babel-runtime/core-js/object/define-properties.js","node_modules/babel-runtime/core-js/object/define-property.js","node_modules/babel-runtime/core-js/object/freeze.js","node_modules/babel-runtime/core-js/object/get-own-property-descriptor.js","node_modules/babel-runtime/core-js/object/keys.js","node_modules/babel-runtime/core-js/object/set-prototype-of.js","node_modules/babel-runtime/core-js/promise.js","node_modules/babel-runtime/core-js/set.js","node_modules/babel-runtime/core-js/symbol.js","node_modules/babel-runtime/core-js/symbol/iterator.js","node_modules/babel-runtime/helpers/class-call-check.js","node_modules/babel-runtime/helpers/create-class.js","node_modules/babel-runtime/helpers/define-property.js","node_modules/babel-runtime/helpers/get.js","node_modules/babel-runtime/helpers/inherits.js","node_modules/babel-runtime/helpers/interop-require-default.js","node_modules/babel-runtime/helpers/sliced-to-array.js","node_modules/babel-runtime/helpers/to-consumable-array.js","node_modules/babel-runtime/regenerator/index.js","node_modules/babel-runtime/regenerator/runtime.js","node_modules/base64-js/lib/b64.js","node_modules/bit-twiddle/twiddle.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/browser-resolve/empty.js","node_modules/buffer/index.js","node_modules/core-js/library/fn/array/from.js","node_modules/core-js/library/fn/get-iterator.js","node_modules/core-js/library/fn/is-iterable.js","node_modules/core-js/library/fn/map.js","node_modules/core-js/library/fn/math/log2.js","node_modules/core-js/library/fn/object/assign.js","node_modules/core-js/library/fn/object/create.js","node_modules/core-js/library/fn/object/define-properties.js","node_modules/core-js/library/fn/object/define-property.js","node_modules/core-js/library/fn/object/freeze.js","node_modules/core-js/library/fn/object/get-own-property-descriptor.js","node_modules/core-js/library/fn/object/keys.js","node_modules/core-js/library/fn/object/set-prototype-of.js","node_modules/core-js/library/fn/promise.js","node_modules/core-js/library/fn/set.js","node_modules/core-js/library/fn/symbol/index.js","node_modules/core-js/library/fn/symbol/iterator.js","node_modules/core-js/library/modules/$.a-function.js","node_modules/core-js/library/modules/$.add-to-unscopables.js","node_modules/core-js/library/modules/$.an-object.js","node_modules/core-js/library/modules/$.classof.js","node_modules/core-js/library/modules/$.cof.js","node_modules/core-js/library/modules/$.collection-strong.js","node_modules/core-js/library/modules/$.collection-to-json.js","node_modules/core-js/library/modules/$.collection.js","node_modules/core-js/library/modules/$.core.js","node_modules/core-js/library/modules/$.ctx.js","node_modules/core-js/library/modules/$.defined.js","node_modules/core-js/library/modules/$.descriptors.js","node_modules/core-js/library/modules/$.dom-create.js","node_modules/core-js/library/modules/$.enum-keys.js","node_modules/core-js/library/modules/$.export.js","node_modules/core-js/library/modules/$.fails.js","node_modules/core-js/library/modules/$.for-of.js","node_modules/core-js/library/modules/$.get-names.js","node_modules/core-js/library/modules/$.global.js","node_modules/core-js/library/modules/$.has.js","node_modules/core-js/library/modules/$.hide.js","node_modules/core-js/library/modules/$.html.js","node_modules/core-js/library/modules/$.invoke.js","node_modules/core-js/library/modules/$.iobject.js","node_modules/core-js/library/modules/$.is-array-iter.js","node_modules/core-js/library/modules/$.is-array.js","node_modules/core-js/library/modules/$.is-object.js","node_modules/core-js/library/modules/$.iter-call.js","node_modules/core-js/library/modules/$.iter-create.js","node_modules/core-js/library/modules/$.iter-define.js","node_modules/core-js/library/modules/$.iter-detect.js","node_modules/core-js/library/modules/$.iter-step.js","node_modules/core-js/library/modules/$.iterators.js","node_modules/core-js/library/modules/$.js","node_modules/core-js/library/modules/$.keyof.js","node_modules/core-js/library/modules/$.library.js","node_modules/core-js/library/modules/$.microtask.js","node_modules/core-js/library/modules/$.object-assign.js","node_modules/core-js/library/modules/$.object-sap.js","node_modules/core-js/library/modules/$.property-desc.js","node_modules/core-js/library/modules/$.redefine-all.js","node_modules/core-js/library/modules/$.redefine.js","node_modules/core-js/library/modules/$.same-value.js","node_modules/core-js/library/modules/$.set-proto.js","node_modules/core-js/library/modules/$.set-species.js","node_modules/core-js/library/modules/$.set-to-string-tag.js","node_modules/core-js/library/modules/$.shared.js","node_modules/core-js/library/modules/$.species-constructor.js","node_modules/core-js/library/modules/$.strict-new.js","node_modules/core-js/library/modules/$.string-at.js","node_modules/core-js/library/modules/$.task.js","node_modules/core-js/library/modules/$.to-integer.js","node_modules/core-js/library/modules/$.to-iobject.js","node_modules/core-js/library/modules/$.to-length.js","node_modules/core-js/library/modules/$.to-object.js","node_modules/core-js/library/modules/$.uid.js","node_modules/core-js/library/modules/$.wks.js","node_modules/core-js/library/modules/core.get-iterator-method.js","node_modules/core-js/library/modules/core.get-iterator.js","node_modules/core-js/library/modules/core.is-iterable.js","node_modules/core-js/library/modules/es6.array.from.js","node_modules/core-js/library/modules/es6.array.iterator.js","node_modules/core-js/library/modules/es6.map.js","node_modules/core-js/library/modules/es6.math.log2.js","node_modules/core-js/library/modules/es6.object.assign.js","node_modules/core-js/library/modules/es6.object.freeze.js","node_modules/core-js/library/modules/es6.object.get-own-property-descriptor.js","node_modules/core-js/library/modules/es6.object.keys.js","node_modules/core-js/library/modules/es6.object.set-prototype-of.js","node_modules/core-js/library/modules/es6.promise.js","node_modules/core-js/library/modules/es6.set.js","node_modules/core-js/library/modules/es6.string.iterator.js","node_modules/core-js/library/modules/es6.symbol.js","node_modules/core-js/library/modules/es7.map.to-json.js","node_modules/core-js/library/modules/es7.set.to-json.js","node_modules/core-js/library/modules/web.dom.iterable.js","node_modules/csscolorparser/csscolorparser.js","node_modules/dup/dup.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-mat3/invert.js","node_modules/gl-mat3/normal-from-mat4.js","node_modules/gl-mat4/copy.js","node_modules/gl-mat4/identity.js","node_modules/gl-mat4/lookAt.js","node_modules/gl-mat4/multiply.js","node_modules/gl-mat4/perspective.js","node_modules/gl-mat4/scale.js","node_modules/gl-mat4/translate.js","node_modules/gl-shader-errors/index.js","node_modules/ieee754/index.js","node_modules/is-array/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/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/loglevel/lib/loglevel.js","node_modules/match-feature/index.js","node_modules/pbf/buffer.js","node_modules/pbf/index.js","node_modules/point-geometry/index.js","node_modules/process/browser.js","node_modules/strip-comments/index.js","node_modules/topojson/topojson.js","node_modules/typedarray-pool/pool.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","/Users/bcamper/Documents/dev/vector-map/src/builders/common.js","/Users/bcamper/Documents/dev/vector-map/src/builders/points.js","/Users/bcamper/Documents/dev/vector-map/src/builders/polygons.js","/Users/bcamper/Documents/dev/vector-map/src/builders/polylines.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/labels/collision.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label_line.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label_point.js","/Users/bcamper/Documents/dev/vector-map/src/labels/repeat_group.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/raster.js","/Users/bcamper/Documents/dev/vector-map/src/sources/topojson.js","/Users/bcamper/Documents/dev/vector-map/src/styles/lines/lines.js","/Users/bcamper/Documents/dev/vector-map/src/styles/points/point_anchor.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/raster/raster.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/canvas_text.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text_settings.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/tile_pyramid.js","/Users/bcamper/Documents/dev/vector-map/src/utils/errors.js","/Users/bcamper/Documents/dev/vector-map/src/utils/gl-matrix.js","/Users/bcamper/Documents/dev/vector-map/src/utils/merge.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","/Users/bcamper/Documents/dev/vector-map/src/view.js"],"names":[],"mappings":"AAAA;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;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;;ACvBA;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;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;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;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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/HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;ACFA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;;ACDA;AACA;;ACDA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;;ACDA;AACA;AACA;AACA;AACA;;ACJA;AACA;;ACDA;AACA;;ACDA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;;ACHA;;ACAA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;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;;ACnBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;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;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;;ACFA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;;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;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;;ACJA;;ACAA;AACA;AACA;AACA;;ACHA;AACA;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;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;ACLA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;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;;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;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClOA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AClIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;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;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;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;;AC7BA;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;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;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;;;;;;;;;;;;mBC5DgB,QAAQ;;;;AAEjB,IAAM,WAAW,GAAG,CACvB,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,EACb,EAAE,CAAC,EAAE,iBAAI,UAAU,EAAE,CAAC,EAAE,CAAC,iBAAI,UAAU,EAAE;CAC5C,CAAC;;;AAEK,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;;;;;;AAIjC,SAA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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})","module.exports = { \"default\": require(\"core-js/library/fn/array/from\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/get-iterator\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/is-iterable\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/map\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/math/log2\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/assign\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/create\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/define-properties\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/define-property\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/freeze\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/get-own-property-descriptor\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/keys\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/set-prototype-of\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/promise\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/set\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/symbol\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/symbol/iterator\"), __esModule: true };","\"use strict\";\n\nexports[\"default\"] = function (instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$defineProperty = require(\"babel-runtime/core-js/object/define-property\")[\"default\"];\n\nexports[\"default\"] = (function () {\n  function defineProperties(target, props) {\n    for (var i = 0; i < props.length; i++) {\n      var descriptor = props[i];\n      descriptor.enumerable = descriptor.enumerable || false;\n      descriptor.configurable = true;\n      if (\"value\" in descriptor) descriptor.writable = true;\n\n      _Object$defineProperty(target, descriptor.key, descriptor);\n    }\n  }\n\n  return function (Constructor, protoProps, staticProps) {\n    if (protoProps) defineProperties(Constructor.prototype, protoProps);\n    if (staticProps) defineProperties(Constructor, staticProps);\n    return Constructor;\n  };\n})();\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$defineProperty = require(\"babel-runtime/core-js/object/define-property\")[\"default\"];\n\nexports[\"default\"] = function (obj, key, value) {\n  if (key in obj) {\n    _Object$defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$getOwnPropertyDescriptor = require(\"babel-runtime/core-js/object/get-own-property-descriptor\")[\"default\"];\n\nexports[\"default\"] = function get(_x, _x2, _x3) {\n  var _again = true;\n\n  _function: while (_again) {\n    var object = _x,\n        property = _x2,\n        receiver = _x3;\n    _again = false;\n    if (object === null) object = Function.prototype;\n\n    var desc = _Object$getOwnPropertyDescriptor(object, property);\n\n    if (desc === undefined) {\n      var parent = Object.getPrototypeOf(object);\n\n      if (parent === null) {\n        return undefined;\n      } else {\n        _x = parent;\n        _x2 = property;\n        _x3 = receiver;\n        _again = true;\n        desc = parent = undefined;\n        continue _function;\n      }\n    } else if (\"value\" in desc) {\n      return desc.value;\n    } else {\n      var getter = desc.get;\n\n      if (getter === undefined) {\n        return undefined;\n      }\n\n      return getter.call(receiver);\n    }\n  }\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Object$setPrototypeOf = require(\"babel-runtime/core-js/object/set-prototype-of\")[\"default\"];\n\nexports[\"default\"] = function (subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n  }\n\n  subClass.prototype = _Object$create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) _Object$setPrototypeOf ? _Object$setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nexports.__esModule = true;","\"use strict\";\n\nexports[\"default\"] = function (obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _getIterator = require(\"babel-runtime/core-js/get-iterator\")[\"default\"];\n\nvar _isIterable = require(\"babel-runtime/core-js/is-iterable\")[\"default\"];\n\nexports[\"default\"] = (function () {\n  function sliceIterator(arr, i) {\n    var _arr = [];\n    var _n = true;\n    var _d = false;\n    var _e = undefined;\n\n    try {\n      for (var _i = _getIterator(arr), _s; !(_n = (_s = _i.next()).done); _n = true) {\n        _arr.push(_s.value);\n\n        if (i && _arr.length === i) break;\n      }\n    } catch (err) {\n      _d = true;\n      _e = err;\n    } finally {\n      try {\n        if (!_n && _i[\"return\"]) _i[\"return\"]();\n      } finally {\n        if (_d) throw _e;\n      }\n    }\n\n    return _arr;\n  }\n\n  return function (arr, i) {\n    if (Array.isArray(arr)) {\n      return arr;\n    } else if (_isIterable(Object(arr))) {\n      return sliceIterator(arr, i);\n    } else {\n      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n    }\n  };\n})();\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Array$from = require(\"babel-runtime/core-js/array/from\")[\"default\"];\n\nexports[\"default\"] = function (arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n    return arr2;\n  } else {\n    return _Array$from(arr);\n  }\n};\n\nexports.__esModule = true;","(function (global){\n// This method of obtaining a reference to the global object needs to be\n// kept identical to the way it is obtained in runtime.js\nvar g =\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window :\n  typeof self === \"object\" ? self : this;\n\n// Use `getOwnPropertyNames` because not all browsers support calling\n// `hasOwnProperty` on the global `self` object in a worker. See #183.\nvar hadRuntime = g.regeneratorRuntime &&\n  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n// Save the old regeneratorRuntime in case it needs to be restored later.\nvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n// Force reevalutation of runtime.js.\ng.regeneratorRuntime = undefined;\n\nmodule.exports = require(\"./runtime\");\n\nif (hadRuntime) {\n  // Restore the original runtime.\n  g.regeneratorRuntime = oldRuntime;\n} else {\n  // Remove the global property added by runtime.js.\n  try {\n    delete g.regeneratorRuntime;\n  } catch(e) {\n    g.regeneratorRuntime = undefined;\n  }\n}\n\nmodule.exports = { \"default\": module.exports, __esModule: true };\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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9iYWJlbC1ydW50aW1lL3JlZ2VuZXJhdG9yL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBtZXRob2Qgb2Ygb2J0YWluaW5nIGEgcmVmZXJlbmNlIHRvIHRoZSBnbG9iYWwgb2JqZWN0IG5lZWRzIHRvIGJlXG4vLyBrZXB0IGlkZW50aWNhbCB0byB0aGUgd2F5IGl0IGlzIG9idGFpbmVkIGluIHJ1bnRpbWUuanNcbnZhciBnID1cbiAgdHlwZW9mIGdsb2JhbCA9PT0gXCJvYmplY3RcIiA/IGdsb2JhbCA6XG4gIHR5cGVvZiB3aW5kb3cgPT09IFwib2JqZWN0XCIgPyB3aW5kb3cgOlxuICB0eXBlb2Ygc2VsZiA9PT0gXCJvYmplY3RcIiA/IHNlbGYgOiB0aGlzO1xuXG4vLyBVc2UgYGdldE93blByb3BlcnR5TmFtZXNgIGJlY2F1c2Ugbm90IGFsbCBicm93c2VycyBzdXBwb3J0IGNhbGxpbmdcbi8vIGBoYXNPd25Qcm9wZXJ0eWAgb24gdGhlIGdsb2JhbCBgc2VsZmAgb2JqZWN0IGluIGEgd29ya2VyLiBTZWUgIzE4My5cbnZhciBoYWRSdW50aW1lID0gZy5yZWdlbmVyYXRvclJ1bnRpbWUgJiZcbiAgT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMoZykuaW5kZXhPZihcInJlZ2VuZXJhdG9yUnVudGltZVwiKSA+PSAwO1xuXG4vLyBTYXZlIHRoZSBvbGQgcmVnZW5lcmF0b3JSdW50aW1lIGluIGNhc2UgaXQgbmVlZHMgdG8gYmUgcmVzdG9yZWQgbGF0ZXIuXG52YXIgb2xkUnVudGltZSA9IGhhZFJ1bnRpbWUgJiYgZy5yZWdlbmVyYXRvclJ1bnRpbWU7XG5cbi8vIEZvcmNlIHJlZXZhbHV0YXRpb24gb2YgcnVudGltZS5qcy5cbmcucmVnZW5lcmF0b3JSdW50aW1lID0gdW5kZWZpbmVkO1xuXG5tb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCIuL3J1bnRpbWVcIik7XG5cbmlmIChoYWRSdW50aW1lKSB7XG4gIC8vIFJlc3RvcmUgdGhlIG9yaWdpbmFsIHJ1bnRpbWUuXG4gIGcucmVnZW5lcmF0b3JSdW50aW1lID0gb2xkUnVudGltZTtcbn0gZWxzZSB7XG4gIC8vIFJlbW92ZSB0aGUgZ2xvYmFsIHByb3BlcnR5IGFkZGVkIGJ5IHJ1bnRpbWUuanMuXG4gIHRyeSB7XG4gICAgZGVsZXRlIGcucmVnZW5lcmF0b3JSdW50aW1lO1xuICB9IGNhdGNoKGUpIHtcbiAgICBnLnJlZ2VuZXJhdG9yUnVudGltZSA9IHVuZGVmaW5lZDtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHsgXCJkZWZhdWx0XCI6IG1vZHVsZS5leHBvcnRzLCBfX2VzTW9kdWxlOiB0cnVlIH07XG4iXX0=","(function (process,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\"use strict\";\n\nvar _Symbol = require(\"babel-runtime/core-js/symbol\")[\"default\"];\n\nvar _Symbol$iterator = require(\"babel-runtime/core-js/symbol/iterator\")[\"default\"];\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Promise = require(\"babel-runtime/core-js/promise\")[\"default\"];\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 = 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    // If outerFn provided, then outerFn.prototype instanceof Generator.\n    var generator = _Object$create((outerFn || Generator).prototype);\n\n    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n    return generator;\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 Generator() {}\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  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n      prototype[method] = function (arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function (genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor ? 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\" : false;\n  };\n\n  runtime.mark = function (genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = _Object$create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `value instanceof AwaitArgument` to determine if the yielded value is\n  // meant to be awaited. Some may consider the name of this method too\n  // cutesy, but they are curmudgeons.\n  runtime.awrap = function (arg) {\n    return new AwaitArgument(arg);\n  };\n\n  function AwaitArgument(arg) {\n    this.arg = arg;\n  }\n\n  function AsyncIterator(generator) {\n    // This invoke function is written in a style that assumes some\n    // calling function (or Promise) will handle exceptions.\n    function invoke(method, arg) {\n      var result = generator[method](arg);\n      var value = result.value;\n      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n        // When a yielded Promise is resolved, its final value becomes\n        // the .value of the Promise<{value,done}> result for the\n        // current iteration. If the Promise is rejected, however, the\n        // result for this iteration will be rejected with the same\n        // reason. Note that rejections of yielded Promises are not\n        // thrown back into the generator function, as is the case\n        // when an awaited Promise is rejected. This difference in\n        // behavior between yield and await is important, because it\n        // allows the consumer to decide what to do with the yielded\n        // rejection (swallow it and continue, manually .throw it back\n        // into the generator, abandon iteration, whatever). With\n        // await, by contrast, there is no opportunity to examine the\n        // rejection reason outside the generator function, so the\n        // only option is to throw it from the await expression, and\n        // let the generator function handle the exception.\n        result.value = unwrapped;\n        return result;\n      });\n    }\n\n    if (typeof process === \"object\" && process.domain) {\n      invoke = process.domain.bind(invoke);\n    }\n\n    var invokeNext = invoke.bind(generator, \"next\");\n    var invokeThrow = invoke.bind(generator, \"throw\");\n    var invokeReturn = invoke.bind(generator, \"return\");\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      var enqueueResult =\n      // If enqueue has been called before, then we want to wait until\n      // all previous Promises have been resolved before calling invoke,\n      // so that results are always delivered in the correct order. If\n      // enqueue has not been called before, then it is important to\n      // call invoke immediately, without waiting on a callback to fire,\n      // so that the async generator function has the opportunity to do\n      // any necessary setup in a predictable way. This predictability\n      // is why the Promise constructor synchronously invokes its\n      // executor callback, and why async functions synchronously\n      // execute code before the first await. Since we implement simple\n      // async functions in terms of async generators, it is especially\n      // important to get this right, even though it requires care.\n      previousPromise ? previousPromise.then(function () {\n        return invoke(method, arg);\n      }) : new _Promise(function (resolve) {\n        resolve(invoke(method, arg));\n      });\n\n      // Avoid propagating enqueueResult failures to Promises returned by\n      // later invocations of the iterator.\n      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n      return enqueueResult;\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n    : iter.next().then(function (result) {\n      return result.done ? result.value : iter.next();\n    });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\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          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n            // A return or throw (when the delegate iterator has no throw\n            // method) always terminates the yield* loop.\n            context.delegate = null;\n\n            // If the delegate iterator has a return method, give it a\n            // chance to clean up.\n            var returnMethod = delegate.iterator[\"return\"];\n            if (returnMethod) {\n              var record = tryCatch(returnMethod, delegate.iterator, arg);\n              if (record.type === \"throw\") {\n                // If the return method threw an exception, let that\n                // exception prevail over the original return or throw.\n                method = \"throw\";\n                arg = record.arg;\n                continue;\n              }\n            }\n\n            if (method === \"return\") {\n              // Continue with the outer return, now that the delegate\n              // iterator has been terminated.\n              continue;\n            }\n          }\n\n          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\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            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 === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            context.sent = undefined;\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        } 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 ? GenStateCompleted : 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        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(arg) call above.\n          method = \"throw\";\n          arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\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(true);\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,\n            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 reset(skipTempReset) {\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      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function stop() {\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 dispatchException(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          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function abrupt(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 && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && 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 complete(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" || 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\n    finish: function finish(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function _catch(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 delegateYield(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).\ntypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);\n}).call(this,require('_process'),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-runtime/regenerator/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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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\"use strict\";\n\nvar _Symbol = require(\"babel-runtime/core-js/symbol\")[\"default\"];\n\nvar _Symbol$iterator = require(\"babel-runtime/core-js/symbol/iterator\")[\"default\"];\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Promise = require(\"babel-runtime/core-js/promise\")[\"default\"];\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 = 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    // If outerFn provided, then outerFn.prototype instanceof Generator.\n    var generator = _Object$create((outerFn || Generator).prototype);\n\n    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n    return generator;\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 Generator() {}\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  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n      prototype[method] = function (arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function (genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor ? 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\" : false;\n  };\n\n  runtime.mark = function (genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = _Object$create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `value instanceof AwaitArgument` to determine if the yielded value is\n  // meant to be awaited. Some may consider the name of this method too\n  // cutesy, but they are curmudgeons.\n  runtime.awrap = function (arg) {\n    return new AwaitArgument(arg);\n  };\n\n  function AwaitArgument(arg) {\n    this.arg = arg;\n  }\n\n  function AsyncIterator(generator) {\n    // This invoke function is written in a style that assumes some\n    // calling function (or Promise) will handle exceptions.\n    function invoke(method, arg) {\n      var result = generator[method](arg);\n      var value = result.value;\n      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n        // When a yielded Promise is resolved, its final value becomes\n        // the .value of the Promise<{value,done}> result for the\n        // current iteration. If the Promise is rejected, however, the\n        // result for this iteration will be rejected with the same\n        // reason. Note that rejections of yielded Promises are not\n        // thrown back into the generator function, as is the case\n        // when an awaited Promise is rejected. This difference in\n        // behavior between yield and await is important, because it\n        // allows the consumer to decide what to do with the yielded\n        // rejection (swallow it and continue, manually .throw it back\n        // into the generator, abandon iteration, whatever). With\n        // await, by contrast, there is no opportunity to examine the\n        // rejection reason outside the generator function, so the\n        // only option is to throw it from the await expression, and\n        // let the generator function handle the exception.\n        result.value = unwrapped;\n        return result;\n      });\n    }\n\n    if (typeof process === \"object\" && process.domain) {\n      invoke = process.domain.bind(invoke);\n    }\n\n    var invokeNext = invoke.bind(generator, \"next\");\n    var invokeThrow = invoke.bind(generator, \"throw\");\n    var invokeReturn = invoke.bind(generator, \"return\");\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      var enqueueResult =\n      // If enqueue has been called before, then we want to wait until\n      // all previous Promises have been resolved before calling invoke,\n      // so that results are always delivered in the correct order. If\n      // enqueue has not been called before, then it is important to\n      // call invoke immediately, without waiting on a callback to fire,\n      // so that the async generator function has the opportunity to do\n      // any necessary setup in a predictable way. This predictability\n      // is why the Promise constructor synchronously invokes its\n      // executor callback, and why async functions synchronously\n      // execute code before the first await. Since we implement simple\n      // async functions in terms of async generators, it is especially\n      // important to get this right, even though it requires care.\n      previousPromise ? previousPromise.then(function () {\n        return invoke(method, arg);\n      }) : new _Promise(function (resolve) {\n        resolve(invoke(method, arg));\n      });\n\n      // Avoid propagating enqueueResult failures to Promises returned by\n      // later invocations of the iterator.\n      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n      return enqueueResult;\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n    : iter.next().then(function (result) {\n      return result.done ? result.value : iter.next();\n    });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\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          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n            // A return or throw (when the delegate iterator has no throw\n            // method) always terminates the yield* loop.\n            context.delegate = null;\n\n            // If the delegate iterator has a return method, give it a\n            // chance to clean up.\n            var returnMethod = delegate.iterator[\"return\"];\n            if (returnMethod) {\n              var record = tryCatch(returnMethod, delegate.iterator, arg);\n              if (record.type === \"throw\") {\n                // If the return method threw an exception, let that\n                // exception prevail over the original return or throw.\n                method = \"throw\";\n                arg = record.arg;\n                continue;\n              }\n            }\n\n            if (method === \"return\") {\n              // Continue with the outer return, now that the delegate\n              // iterator has been terminated.\n              continue;\n            }\n          }\n\n          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\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            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 === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            context.sent = undefined;\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        } 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 ? GenStateCompleted : 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        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(arg) call above.\n          method = \"throw\";\n          arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\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(true);\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,\n            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 reset(skipTempReset) {\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      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function stop() {\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 dispatchException(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          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function abrupt(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 && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && 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 complete(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" || 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\n    finish: function finish(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function _catch(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 delegateYield(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).\ntypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);"]}","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","/**\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\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//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      result = []\n      boxIntersect(arg0, arg0, function(i,j) {\n        result.push([i, j])\n      }, true)\n      return result\n    case 2:\n      if(typeof arg1 === 'function') {\n        var visit = arg1\n        return boxIntersect(arg0, arg0, visit, true)\n      } else {\n        result = []\n        boxIntersect(arg0, arg1, function(i,j) {\n          result.push([i, j])\n        }, false)\n        return result\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}",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","require('../../modules/es6.string.iterator');\nrequire('../../modules/es6.array.from');\nmodule.exports = require('../../modules/$.core').Array.from;","require('../modules/web.dom.iterable');\nrequire('../modules/es6.string.iterator');\nmodule.exports = require('../modules/core.get-iterator');","require('../modules/web.dom.iterable');\nrequire('../modules/es6.string.iterator');\nmodule.exports = require('../modules/core.is-iterable');","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.map');\nrequire('../modules/es7.map.to-json');\nmodule.exports = require('../modules/$.core').Map;","require('../../modules/es6.math.log2');\nmodule.exports = require('../../modules/$.core').Math.log2;","require('../../modules/es6.object.assign');\nmodule.exports = require('../../modules/$.core').Object.assign;","var $ = require('../../modules/$');\nmodule.exports = function create(P, D){\n  return $.create(P, D);\n};","var $ = require('../../modules/$');\nmodule.exports = function defineProperties(T, D){\n  return $.setDescs(T, D);\n};","var $ = require('../../modules/$');\nmodule.exports = function defineProperty(it, key, desc){\n  return $.setDesc(it, key, desc);\n};","require('../../modules/es6.object.freeze');\nmodule.exports = require('../../modules/$.core').Object.freeze;","var $ = require('../../modules/$');\nrequire('../../modules/es6.object.get-own-property-descriptor');\nmodule.exports = function getOwnPropertyDescriptor(it, key){\n  return $.getDesc(it, key);\n};","require('../../modules/es6.object.keys');\nmodule.exports = require('../../modules/$.core').Object.keys;","require('../../modules/es6.object.set-prototype-of');\nmodule.exports = require('../../modules/$.core').Object.setPrototypeOf;","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.promise');\nmodule.exports = require('../modules/$.core').Promise;","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.set');\nrequire('../modules/es7.set.to-json');\nmodule.exports = require('../modules/$.core').Set;","require('../../modules/es6.symbol');\nrequire('../../modules/es6.object.to-string');\nmodule.exports = require('../../modules/$.core').Symbol;","require('../../modules/es6.string.iterator');\nrequire('../../modules/web.dom.iterable');\nmodule.exports = require('../../modules/$.wks')('iterator');","module.exports = function(it){\n  if(typeof it != 'function')throw TypeError(it + ' is not a function!');\n  return it;\n};","module.exports = function(){ /* empty */ };","var isObject = require('./$.is-object');\nmodule.exports = function(it){\n  if(!isObject(it))throw TypeError(it + ' is not an object!');\n  return it;\n};","// getting tag from 19.1.3.6 Object.prototype.toString()\nvar cof = require('./$.cof')\n  , TAG = require('./$.wks')('toStringTag')\n  // ES3 wrong here\n  , ARG = cof(function(){ return arguments; }()) == 'Arguments';\n\nmodule.exports = function(it){\n  var O, T, B;\n  return it === undefined ? 'Undefined' : it === null ? 'Null'\n    // @@toStringTag case\n    : typeof (T = (O = Object(it))[TAG]) == 'string' ? T\n    // builtinTag case\n    : ARG ? cof(O)\n    // ES3 arguments fallback\n    : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n};","var toString = {}.toString;\n\nmodule.exports = function(it){\n  return toString.call(it).slice(8, -1);\n};","'use strict';\nvar $            = require('./$')\n  , hide         = require('./$.hide')\n  , redefineAll  = require('./$.redefine-all')\n  , ctx          = require('./$.ctx')\n  , strictNew    = require('./$.strict-new')\n  , defined      = require('./$.defined')\n  , forOf        = require('./$.for-of')\n  , $iterDefine  = require('./$.iter-define')\n  , step         = require('./$.iter-step')\n  , ID           = require('./$.uid')('id')\n  , $has         = require('./$.has')\n  , isObject     = require('./$.is-object')\n  , setSpecies   = require('./$.set-species')\n  , DESCRIPTORS  = require('./$.descriptors')\n  , isExtensible = Object.isExtensible || isObject\n  , SIZE         = DESCRIPTORS ? '_s' : 'size'\n  , id           = 0;\n\nvar fastKey = function(it, create){\n  // return primitive with prefix\n  if(!isObject(it))return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n  if(!$has(it, ID)){\n    // can't set id to frozen object\n    if(!isExtensible(it))return 'F';\n    // not necessary to add id\n    if(!create)return 'E';\n    // add missing object id\n    hide(it, ID, ++id);\n  // return object id with prefix\n  } return 'O' + it[ID];\n};\n\nvar getEntry = function(that, key){\n  // fast case\n  var index = fastKey(key), entry;\n  if(index !== 'F')return that._i[index];\n  // frozen object case\n  for(entry = that._f; entry; entry = entry.n){\n    if(entry.k == key)return entry;\n  }\n};\n\nmodule.exports = {\n  getConstructor: function(wrapper, NAME, IS_MAP, ADDER){\n    var C = wrapper(function(that, iterable){\n      strictNew(that, C, NAME);\n      that._i = $.create(null); // index\n      that._f = undefined;      // first entry\n      that._l = undefined;      // last entry\n      that[SIZE] = 0;           // size\n      if(iterable != undefined)forOf(iterable, IS_MAP, that[ADDER], that);\n    });\n    redefineAll(C.prototype, {\n      // 23.1.3.1 Map.prototype.clear()\n      // 23.2.3.2 Set.prototype.clear()\n      clear: function clear(){\n        for(var that = this, data = that._i, entry = that._f; entry; entry = entry.n){\n          entry.r = true;\n          if(entry.p)entry.p = entry.p.n = undefined;\n          delete data[entry.i];\n        }\n        that._f = that._l = undefined;\n        that[SIZE] = 0;\n      },\n      // 23.1.3.3 Map.prototype.delete(key)\n      // 23.2.3.4 Set.prototype.delete(value)\n      'delete': function(key){\n        var that  = this\n          , entry = getEntry(that, key);\n        if(entry){\n          var next = entry.n\n            , prev = entry.p;\n          delete that._i[entry.i];\n          entry.r = true;\n          if(prev)prev.n = next;\n          if(next)next.p = prev;\n          if(that._f == entry)that._f = next;\n          if(that._l == entry)that._l = prev;\n          that[SIZE]--;\n        } return !!entry;\n      },\n      // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n      // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n      forEach: function forEach(callbackfn /*, that = undefined */){\n        var f = ctx(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3)\n          , entry;\n        while(entry = entry ? entry.n : this._f){\n          f(entry.v, entry.k, this);\n          // revert to the last existing entry\n          while(entry && entry.r)entry = entry.p;\n        }\n      },\n      // 23.1.3.7 Map.prototype.has(key)\n      // 23.2.3.7 Set.prototype.has(value)\n      has: function has(key){\n        return !!getEntry(this, key);\n      }\n    });\n    if(DESCRIPTORS)$.setDesc(C.prototype, 'size', {\n      get: function(){\n        return defined(this[SIZE]);\n      }\n    });\n    return C;\n  },\n  def: function(that, key, value){\n    var entry = getEntry(that, key)\n      , prev, index;\n    // change existing entry\n    if(entry){\n      entry.v = value;\n    // create new entry\n    } else {\n      that._l = entry = {\n        i: index = fastKey(key, true), // <- index\n        k: key,                        // <- key\n        v: value,                      // <- value\n        p: prev = that._l,             // <- previous entry\n        n: undefined,                  // <- next entry\n        r: false                       // <- removed\n      };\n      if(!that._f)that._f = entry;\n      if(prev)prev.n = entry;\n      that[SIZE]++;\n      // add to index\n      if(index !== 'F')that._i[index] = entry;\n    } return that;\n  },\n  getEntry: getEntry,\n  setStrong: function(C, NAME, IS_MAP){\n    // add .keys, .values, .entries, [@@iterator]\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\n    $iterDefine(C, NAME, function(iterated, kind){\n      this._t = iterated;  // target\n      this._k = kind;      // kind\n      this._l = undefined; // previous\n    }, function(){\n      var that  = this\n        , kind  = that._k\n        , entry = that._l;\n      // revert to the last existing entry\n      while(entry && entry.r)entry = entry.p;\n      // get next entry\n      if(!that._t || !(that._l = entry = entry ? entry.n : that._t._f)){\n        // or finish the iteration\n        that._t = undefined;\n        return step(1);\n      }\n      // return step by kind\n      if(kind == 'keys'  )return step(0, entry.k);\n      if(kind == 'values')return step(0, entry.v);\n      return step(0, [entry.k, entry.v]);\n    }, IS_MAP ? 'entries' : 'values' , !IS_MAP, true);\n\n    // add [@@species], 23.1.2.2, 23.2.2.2\n    setSpecies(NAME);\n  }\n};","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar forOf   = require('./$.for-of')\n  , classof = require('./$.classof');\nmodule.exports = function(NAME){\n  return function toJSON(){\n    if(classof(this) != NAME)throw TypeError(NAME + \"#toJSON isn't generic\");\n    var arr = [];\n    forOf(this, false, arr.push, arr);\n    return arr;\n  };\n};","'use strict';\nvar $              = require('./$')\n  , global         = require('./$.global')\n  , $export        = require('./$.export')\n  , fails          = require('./$.fails')\n  , hide           = require('./$.hide')\n  , redefineAll    = require('./$.redefine-all')\n  , forOf          = require('./$.for-of')\n  , strictNew      = require('./$.strict-new')\n  , isObject       = require('./$.is-object')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , DESCRIPTORS    = require('./$.descriptors');\n\nmodule.exports = function(NAME, wrapper, methods, common, IS_MAP, IS_WEAK){\n  var Base  = global[NAME]\n    , C     = Base\n    , ADDER = IS_MAP ? 'set' : 'add'\n    , proto = C && C.prototype\n    , O     = {};\n  if(!DESCRIPTORS || typeof C != 'function' || !(IS_WEAK || proto.forEach && !fails(function(){\n    new C().entries().next();\n  }))){\n    // create collection constructor\n    C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n    redefineAll(C.prototype, methods);\n  } else {\n    C = wrapper(function(target, iterable){\n      strictNew(target, C, NAME);\n      target._c = new Base;\n      if(iterable != undefined)forOf(iterable, IS_MAP, target[ADDER], target);\n    });\n    $.each.call('add,clear,delete,forEach,get,has,set,keys,values,entries'.split(','),function(KEY){\n      var IS_ADDER = KEY == 'add' || KEY == 'set';\n      if(KEY in proto && !(IS_WEAK && KEY == 'clear'))hide(C.prototype, KEY, function(a, b){\n        if(!IS_ADDER && IS_WEAK && !isObject(a))return KEY == 'get' ? undefined : false;\n        var result = this._c[KEY](a === 0 ? 0 : a, b);\n        return IS_ADDER ? this : result;\n      });\n    });\n    if('size' in proto)$.setDesc(C.prototype, 'size', {\n      get: function(){\n        return this._c.size;\n      }\n    });\n  }\n\n  setToStringTag(C, NAME);\n\n  O[NAME] = C;\n  $export($export.G + $export.W + $export.F, O);\n\n  if(!IS_WEAK)common.setStrong(C, NAME, IS_MAP);\n\n  return C;\n};","var core = module.exports = {version: '1.2.6'};\nif(typeof __e == 'number')__e = core; // eslint-disable-line no-undef","// optional / simple context binding\nvar aFunction = require('./$.a-function');\nmodule.exports = function(fn, that, length){\n  aFunction(fn);\n  if(that === undefined)return fn;\n  switch(length){\n    case 1: return function(a){\n      return fn.call(that, a);\n    };\n    case 2: return function(a, b){\n      return fn.call(that, a, b);\n    };\n    case 3: return function(a, b, c){\n      return fn.call(that, a, b, c);\n    };\n  }\n  return function(/* ...args */){\n    return fn.apply(that, arguments);\n  };\n};","// 7.2.1 RequireObjectCoercible(argument)\nmodule.exports = function(it){\n  if(it == undefined)throw TypeError(\"Can't call method on  \" + it);\n  return it;\n};","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./$.fails')(function(){\n  return Object.defineProperty({}, 'a', {get: function(){ return 7; }}).a != 7;\n});","var isObject = require('./$.is-object')\n  , document = require('./$.global').document\n  // in old IE typeof document.createElement is 'object'\n  , is = isObject(document) && isObject(document.createElement);\nmodule.exports = function(it){\n  return is ? document.createElement(it) : {};\n};","// all enumerable object keys, includes symbols\nvar $ = require('./$');\nmodule.exports = function(it){\n  var keys       = $.getKeys(it)\n    , getSymbols = $.getSymbols;\n  if(getSymbols){\n    var symbols = getSymbols(it)\n      , isEnum  = $.isEnum\n      , i       = 0\n      , key;\n    while(symbols.length > i)if(isEnum.call(it, key = symbols[i++]))keys.push(key);\n  }\n  return keys;\n};","var global    = require('./$.global')\n  , core      = require('./$.core')\n  , ctx       = require('./$.ctx')\n  , PROTOTYPE = 'prototype';\n\nvar $export = function(type, name, source){\n  var IS_FORCED = type & $export.F\n    , IS_GLOBAL = type & $export.G\n    , IS_STATIC = type & $export.S\n    , IS_PROTO  = type & $export.P\n    , IS_BIND   = type & $export.B\n    , IS_WRAP   = type & $export.W\n    , exports   = IS_GLOBAL ? core : core[name] || (core[name] = {})\n    , target    = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE]\n    , key, own, out;\n  if(IS_GLOBAL)source = name;\n  for(key in source){\n    // contains in native\n    own = !IS_FORCED && target && key in target;\n    if(own && key in exports)continue;\n    // export native or passed\n    out = own ? target[key] : source[key];\n    // prevent global pollution for namespaces\n    exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n    // bind timers to global for call from export context\n    : IS_BIND && own ? ctx(out, global)\n    // wrap global constructors for prevent change them in library\n    : IS_WRAP && target[key] == out ? (function(C){\n      var F = function(param){\n        return this instanceof C ? new C(param) : C(param);\n      };\n      F[PROTOTYPE] = C[PROTOTYPE];\n      return F;\n    // make static versions for prototype methods\n    })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n    if(IS_PROTO)(exports[PROTOTYPE] || (exports[PROTOTYPE] = {}))[key] = out;\n  }\n};\n// type bitmap\n$export.F = 1;  // forced\n$export.G = 2;  // global\n$export.S = 4;  // static\n$export.P = 8;  // proto\n$export.B = 16; // bind\n$export.W = 32; // wrap\nmodule.exports = $export;","module.exports = function(exec){\n  try {\n    return !!exec();\n  } catch(e){\n    return true;\n  }\n};","var ctx         = require('./$.ctx')\n  , call        = require('./$.iter-call')\n  , isArrayIter = require('./$.is-array-iter')\n  , anObject    = require('./$.an-object')\n  , toLength    = require('./$.to-length')\n  , getIterFn   = require('./core.get-iterator-method');\nmodule.exports = function(iterable, entries, fn, that){\n  var iterFn = getIterFn(iterable)\n    , f      = ctx(fn, that, entries ? 2 : 1)\n    , index  = 0\n    , length, step, iterator;\n  if(typeof iterFn != 'function')throw TypeError(iterable + ' is not iterable!');\n  // fast case for arrays with default iterator\n  if(isArrayIter(iterFn))for(length = toLength(iterable.length); length > index; index++){\n    entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n  } else for(iterator = iterFn.call(iterable); !(step = iterator.next()).done; ){\n    call(iterator, f, step.value, entries);\n  }\n};","// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\nvar toIObject = require('./$.to-iobject')\n  , getNames  = require('./$').getNames\n  , toString  = {}.toString;\n\nvar windowNames = typeof window == 'object' && Object.getOwnPropertyNames\n  ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function(it){\n  try {\n    return getNames(it);\n  } catch(e){\n    return windowNames.slice();\n  }\n};\n\nmodule.exports.get = function getOwnPropertyNames(it){\n  if(windowNames && toString.call(it) == '[object Window]')return getWindowNames(it);\n  return getNames(toIObject(it));\n};","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n  ? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();\nif(typeof __g == 'number')__g = global; // eslint-disable-line no-undef","var hasOwnProperty = {}.hasOwnProperty;\nmodule.exports = function(it, key){\n  return hasOwnProperty.call(it, key);\n};","var $          = require('./$')\n  , createDesc = require('./$.property-desc');\nmodule.exports = require('./$.descriptors') ? function(object, key, value){\n  return $.setDesc(object, key, createDesc(1, value));\n} : function(object, key, value){\n  object[key] = value;\n  return object;\n};","module.exports = require('./$.global').document && document.documentElement;","// fast apply, http://jsperf.lnkit.com/fast-apply/5\nmodule.exports = function(fn, args, that){\n  var un = that === undefined;\n  switch(args.length){\n    case 0: return un ? fn()\n                      : fn.call(that);\n    case 1: return un ? fn(args[0])\n                      : fn.call(that, args[0]);\n    case 2: return un ? fn(args[0], args[1])\n                      : fn.call(that, args[0], args[1]);\n    case 3: return un ? fn(args[0], args[1], args[2])\n                      : fn.call(that, args[0], args[1], args[2]);\n    case 4: return un ? fn(args[0], args[1], args[2], args[3])\n                      : fn.call(that, args[0], args[1], args[2], args[3]);\n  } return              fn.apply(that, args);\n};","// fallback for non-array-like ES3 and non-enumerable old V8 strings\nvar cof = require('./$.cof');\nmodule.exports = Object('z').propertyIsEnumerable(0) ? Object : function(it){\n  return cof(it) == 'String' ? it.split('') : Object(it);\n};","// check on default Array iterator\nvar Iterators  = require('./$.iterators')\n  , ITERATOR   = require('./$.wks')('iterator')\n  , ArrayProto = Array.prototype;\n\nmodule.exports = function(it){\n  return it !== undefined && (Iterators.Array === it || ArrayProto[ITERATOR] === it);\n};","// 7.2.2 IsArray(argument)\nvar cof = require('./$.cof');\nmodule.exports = Array.isArray || function(arg){\n  return cof(arg) == 'Array';\n};","module.exports = function(it){\n  return typeof it === 'object' ? it !== null : typeof it === 'function';\n};","// call something on iterator step with safe closing on error\nvar anObject = require('./$.an-object');\nmodule.exports = function(iterator, fn, value, entries){\n  try {\n    return entries ? fn(anObject(value)[0], value[1]) : fn(value);\n  // 7.4.6 IteratorClose(iterator, completion)\n  } catch(e){\n    var ret = iterator['return'];\n    if(ret !== undefined)anObject(ret.call(iterator));\n    throw e;\n  }\n};","'use strict';\nvar $              = require('./$')\n  , descriptor     = require('./$.property-desc')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , IteratorPrototype = {};\n\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\nrequire('./$.hide')(IteratorPrototype, require('./$.wks')('iterator'), function(){ return this; });\n\nmodule.exports = function(Constructor, NAME, next){\n  Constructor.prototype = $.create(IteratorPrototype, {next: descriptor(1, next)});\n  setToStringTag(Constructor, NAME + ' Iterator');\n};","'use strict';\nvar LIBRARY        = require('./$.library')\n  , $export        = require('./$.export')\n  , redefine       = require('./$.redefine')\n  , hide           = require('./$.hide')\n  , has            = require('./$.has')\n  , Iterators      = require('./$.iterators')\n  , $iterCreate    = require('./$.iter-create')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , getProto       = require('./$').getProto\n  , ITERATOR       = require('./$.wks')('iterator')\n  , BUGGY          = !([].keys && 'next' in [].keys()) // Safari has buggy iterators w/o `next`\n  , FF_ITERATOR    = '@@iterator'\n  , KEYS           = 'keys'\n  , VALUES         = 'values';\n\nvar returnThis = function(){ return this; };\n\nmodule.exports = function(Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCED){\n  $iterCreate(Constructor, NAME, next);\n  var getMethod = function(kind){\n    if(!BUGGY && kind in proto)return proto[kind];\n    switch(kind){\n      case KEYS: return function keys(){ return new Constructor(this, kind); };\n      case VALUES: return function values(){ return new Constructor(this, kind); };\n    } return function entries(){ return new Constructor(this, kind); };\n  };\n  var TAG        = NAME + ' Iterator'\n    , DEF_VALUES = DEFAULT == VALUES\n    , VALUES_BUG = false\n    , proto      = Base.prototype\n    , $native    = proto[ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT]\n    , $default   = $native || getMethod(DEFAULT)\n    , methods, key;\n  // Fix native\n  if($native){\n    var IteratorPrototype = getProto($default.call(new Base));\n    // Set @@toStringTag to native iterators\n    setToStringTag(IteratorPrototype, TAG, true);\n    // FF fix\n    if(!LIBRARY && has(proto, FF_ITERATOR))hide(IteratorPrototype, ITERATOR, returnThis);\n    // fix Array#{values, @@iterator}.name in V8 / FF\n    if(DEF_VALUES && $native.name !== VALUES){\n      VALUES_BUG = true;\n      $default = function values(){ return $native.call(this); };\n    }\n  }\n  // Define iterator\n  if((!LIBRARY || FORCED) && (BUGGY || VALUES_BUG || !proto[ITERATOR])){\n    hide(proto, ITERATOR, $default);\n  }\n  // Plug for library\n  Iterators[NAME] = $default;\n  Iterators[TAG]  = returnThis;\n  if(DEFAULT){\n    methods = {\n      values:  DEF_VALUES  ? $default : getMethod(VALUES),\n      keys:    IS_SET      ? $default : getMethod(KEYS),\n      entries: !DEF_VALUES ? $default : getMethod('entries')\n    };\n    if(FORCED)for(key in methods){\n      if(!(key in proto))redefine(proto, key, methods[key]);\n    } else $export($export.P + $export.F * (BUGGY || VALUES_BUG), NAME, methods);\n  }\n  return methods;\n};","var ITERATOR     = require('./$.wks')('iterator')\n  , SAFE_CLOSING = false;\n\ntry {\n  var riter = [7][ITERATOR]();\n  riter['return'] = function(){ SAFE_CLOSING = true; };\n  Array.from(riter, function(){ throw 2; });\n} catch(e){ /* empty */ }\n\nmodule.exports = function(exec, skipClosing){\n  if(!skipClosing && !SAFE_CLOSING)return false;\n  var safe = false;\n  try {\n    var arr  = [7]\n      , iter = arr[ITERATOR]();\n    iter.next = function(){ safe = true; };\n    arr[ITERATOR] = function(){ return iter; };\n    exec(arr);\n  } catch(e){ /* empty */ }\n  return safe;\n};","module.exports = function(done, value){\n  return {value: value, done: !!done};\n};","module.exports = {};","var $Object = Object;\nmodule.exports = {\n  create:     $Object.create,\n  getProto:   $Object.getPrototypeOf,\n  isEnum:     {}.propertyIsEnumerable,\n  getDesc:    $Object.getOwnPropertyDescriptor,\n  setDesc:    $Object.defineProperty,\n  setDescs:   $Object.defineProperties,\n  getKeys:    $Object.keys,\n  getNames:   $Object.getOwnPropertyNames,\n  getSymbols: $Object.getOwnPropertySymbols,\n  each:       [].forEach\n};","var $         = require('./$')\n  , toIObject = require('./$.to-iobject');\nmodule.exports = function(object, el){\n  var O      = toIObject(object)\n    , keys   = $.getKeys(O)\n    , length = keys.length\n    , index  = 0\n    , key;\n  while(length > index)if(O[key = keys[index++]] === el)return key;\n};","module.exports = true;","var global    = require('./$.global')\n  , macrotask = require('./$.task').set\n  , Observer  = global.MutationObserver || global.WebKitMutationObserver\n  , process   = global.process\n  , Promise   = global.Promise\n  , isNode    = require('./$.cof')(process) == 'process'\n  , head, last, notify;\n\nvar flush = function(){\n  var parent, domain, fn;\n  if(isNode && (parent = process.domain)){\n    process.domain = null;\n    parent.exit();\n  }\n  while(head){\n    domain = head.domain;\n    fn     = head.fn;\n    if(domain)domain.enter();\n    fn(); // <- currently we use it only for Promise - try / catch not required\n    if(domain)domain.exit();\n    head = head.next;\n  } last = undefined;\n  if(parent)parent.enter();\n};\n\n// Node.js\nif(isNode){\n  notify = function(){\n    process.nextTick(flush);\n  };\n// browsers with MutationObserver\n} else if(Observer){\n  var toggle = 1\n    , node   = document.createTextNode('');\n  new Observer(flush).observe(node, {characterData: true}); // eslint-disable-line no-new\n  notify = function(){\n    node.data = toggle = -toggle;\n  };\n// environments with maybe non-completely correct, but existent Promise\n} else if(Promise && Promise.resolve){\n  notify = function(){\n    Promise.resolve().then(flush);\n  };\n// for other environments - macrotask based on:\n// - setImmediate\n// - MessageChannel\n// - window.postMessag\n// - onreadystatechange\n// - setTimeout\n} else {\n  notify = function(){\n    // strange IE + webpack dev server bug - use .call(global)\n    macrotask.call(global, flush);\n  };\n}\n\nmodule.exports = function asap(fn){\n  var task = {fn: fn, next: undefined, domain: isNode && process.domain};\n  if(last)last.next = task;\n  if(!head){\n    head = task;\n    notify();\n  } last = task;\n};","// 19.1.2.1 Object.assign(target, source, ...)\nvar $        = require('./$')\n  , toObject = require('./$.to-object')\n  , IObject  = require('./$.iobject');\n\n// should work with symbols and should have deterministic property order (V8 bug)\nmodule.exports = require('./$.fails')(function(){\n  var a = Object.assign\n    , A = {}\n    , B = {}\n    , S = Symbol()\n    , K = 'abcdefghijklmnopqrst';\n  A[S] = 7;\n  K.split('').forEach(function(k){ B[k] = k; });\n  return a({}, A)[S] != 7 || Object.keys(a({}, B)).join('') != K;\n}) ? function assign(target, source){ // eslint-disable-line no-unused-vars\n  var T     = toObject(target)\n    , $$    = arguments\n    , $$len = $$.length\n    , index = 1\n    , getKeys    = $.getKeys\n    , getSymbols = $.getSymbols\n    , isEnum     = $.isEnum;\n  while($$len > index){\n    var S      = IObject($$[index++])\n      , keys   = getSymbols ? getKeys(S).concat(getSymbols(S)) : getKeys(S)\n      , length = keys.length\n      , j      = 0\n      , key;\n    while(length > j)if(isEnum.call(S, key = keys[j++]))T[key] = S[key];\n  }\n  return T;\n} : Object.assign;","// most Object methods by ES6 should accept primitives\nvar $export = require('./$.export')\n  , core    = require('./$.core')\n  , fails   = require('./$.fails');\nmodule.exports = function(KEY, exec){\n  var fn  = (core.Object || {})[KEY] || Object[KEY]\n    , exp = {};\n  exp[KEY] = exec(fn);\n  $export($export.S + $export.F * fails(function(){ fn(1); }), 'Object', exp);\n};","module.exports = function(bitmap, value){\n  return {\n    enumerable  : !(bitmap & 1),\n    configurable: !(bitmap & 2),\n    writable    : !(bitmap & 4),\n    value       : value\n  };\n};","var redefine = require('./$.redefine');\nmodule.exports = function(target, src){\n  for(var key in src)redefine(target, key, src[key]);\n  return target;\n};","module.exports = require('./$.hide');","// 7.2.9 SameValue(x, y)\nmodule.exports = Object.is || function is(x, y){\n  return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\n};","// Works with __proto__ only. Old v8 can't work with null proto objects.\n/* eslint-disable no-proto */\nvar getDesc  = require('./$').getDesc\n  , isObject = require('./$.is-object')\n  , anObject = require('./$.an-object');\nvar check = function(O, proto){\n  anObject(O);\n  if(!isObject(proto) && proto !== null)throw TypeError(proto + \": can't set as prototype!\");\n};\nmodule.exports = {\n  set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line\n    function(test, buggy, set){\n      try {\n        set = require('./$.ctx')(Function.call, getDesc(Object.prototype, '__proto__').set, 2);\n        set(test, []);\n        buggy = !(test instanceof Array);\n      } catch(e){ buggy = true; }\n      return function setPrototypeOf(O, proto){\n        check(O, proto);\n        if(buggy)O.__proto__ = proto;\n        else set(O, proto);\n        return O;\n      };\n    }({}, false) : undefined),\n  check: check\n};","'use strict';\nvar core        = require('./$.core')\n  , $           = require('./$')\n  , DESCRIPTORS = require('./$.descriptors')\n  , SPECIES     = require('./$.wks')('species');\n\nmodule.exports = function(KEY){\n  var C = core[KEY];\n  if(DESCRIPTORS && C && !C[SPECIES])$.setDesc(C, SPECIES, {\n    configurable: true,\n    get: function(){ return this; }\n  });\n};","var def = require('./$').setDesc\n  , has = require('./$.has')\n  , TAG = require('./$.wks')('toStringTag');\n\nmodule.exports = function(it, tag, stat){\n  if(it && !has(it = stat ? it : it.prototype, TAG))def(it, TAG, {configurable: true, value: tag});\n};","var global = require('./$.global')\n  , SHARED = '__core-js_shared__'\n  , store  = global[SHARED] || (global[SHARED] = {});\nmodule.exports = function(key){\n  return store[key] || (store[key] = {});\n};","// 7.3.20 SpeciesConstructor(O, defaultConstructor)\nvar anObject  = require('./$.an-object')\n  , aFunction = require('./$.a-function')\n  , SPECIES   = require('./$.wks')('species');\nmodule.exports = function(O, D){\n  var C = anObject(O).constructor, S;\n  return C === undefined || (S = anObject(C)[SPECIES]) == undefined ? D : aFunction(S);\n};","module.exports = function(it, Constructor, name){\n  if(!(it instanceof Constructor))throw TypeError(name + \": use the 'new' operator!\");\n  return it;\n};","var toInteger = require('./$.to-integer')\n  , defined   = require('./$.defined');\n// true  -> String#at\n// false -> String#codePointAt\nmodule.exports = function(TO_STRING){\n  return function(that, pos){\n    var s = String(defined(that))\n      , i = toInteger(pos)\n      , l = s.length\n      , a, b;\n    if(i < 0 || i >= l)return TO_STRING ? '' : undefined;\n    a = s.charCodeAt(i);\n    return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n      ? TO_STRING ? s.charAt(i) : a\n      : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n  };\n};","var ctx                = require('./$.ctx')\n  , invoke             = require('./$.invoke')\n  , html               = require('./$.html')\n  , cel                = require('./$.dom-create')\n  , global             = require('./$.global')\n  , process            = global.process\n  , setTask            = global.setImmediate\n  , clearTask          = global.clearImmediate\n  , MessageChannel     = global.MessageChannel\n  , counter            = 0\n  , queue              = {}\n  , ONREADYSTATECHANGE = 'onreadystatechange'\n  , defer, channel, port;\nvar run = function(){\n  var id = +this;\n  if(queue.hasOwnProperty(id)){\n    var fn = queue[id];\n    delete queue[id];\n    fn();\n  }\n};\nvar listner = function(event){\n  run.call(event.data);\n};\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif(!setTask || !clearTask){\n  setTask = function setImmediate(fn){\n    var args = [], i = 1;\n    while(arguments.length > i)args.push(arguments[i++]);\n    queue[++counter] = function(){\n      invoke(typeof fn == 'function' ? fn : Function(fn), args);\n    };\n    defer(counter);\n    return counter;\n  };\n  clearTask = function clearImmediate(id){\n    delete queue[id];\n  };\n  // Node.js 0.8-\n  if(require('./$.cof')(process) == 'process'){\n    defer = function(id){\n      process.nextTick(ctx(run, id, 1));\n    };\n  // Browsers with MessageChannel, includes WebWorkers\n  } else if(MessageChannel){\n    channel = new MessageChannel;\n    port    = channel.port2;\n    channel.port1.onmessage = listner;\n    defer = ctx(port.postMessage, port, 1);\n  // Browsers with postMessage, skip WebWorkers\n  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n  } else if(global.addEventListener && typeof postMessage == 'function' && !global.importScripts){\n    defer = function(id){\n      global.postMessage(id + '', '*');\n    };\n    global.addEventListener('message', listner, false);\n  // IE8-\n  } else if(ONREADYSTATECHANGE in cel('script')){\n    defer = function(id){\n      html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function(){\n        html.removeChild(this);\n        run.call(id);\n      };\n    };\n  // Rest old browsers\n  } else {\n    defer = function(id){\n      setTimeout(ctx(run, id, 1), 0);\n    };\n  }\n}\nmodule.exports = {\n  set:   setTask,\n  clear: clearTask\n};","// 7.1.4 ToInteger\nvar ceil  = Math.ceil\n  , floor = Math.floor;\nmodule.exports = function(it){\n  return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n};","// to indexed object, toObject with fallback for non-array-like ES3 strings\nvar IObject = require('./$.iobject')\n  , defined = require('./$.defined');\nmodule.exports = function(it){\n  return IObject(defined(it));\n};","// 7.1.15 ToLength\nvar toInteger = require('./$.to-integer')\n  , min       = Math.min;\nmodule.exports = function(it){\n  return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n};","// 7.1.13 ToObject(argument)\nvar defined = require('./$.defined');\nmodule.exports = function(it){\n  return Object(defined(it));\n};","var id = 0\n  , px = Math.random();\nmodule.exports = function(key){\n  return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n};","var store  = require('./$.shared')('wks')\n  , uid    = require('./$.uid')\n  , Symbol = require('./$.global').Symbol;\nmodule.exports = function(name){\n  return store[name] || (store[name] =\n    Symbol && Symbol[name] || (Symbol || uid)('Symbol.' + name));\n};","var classof   = require('./$.classof')\n  , ITERATOR  = require('./$.wks')('iterator')\n  , Iterators = require('./$.iterators');\nmodule.exports = require('./$.core').getIteratorMethod = function(it){\n  if(it != undefined)return it[ITERATOR]\n    || it['@@iterator']\n    || Iterators[classof(it)];\n};","var anObject = require('./$.an-object')\n  , get      = require('./core.get-iterator-method');\nmodule.exports = require('./$.core').getIterator = function(it){\n  var iterFn = get(it);\n  if(typeof iterFn != 'function')throw TypeError(it + ' is not iterable!');\n  return anObject(iterFn.call(it));\n};","var classof   = require('./$.classof')\n  , ITERATOR  = require('./$.wks')('iterator')\n  , Iterators = require('./$.iterators');\nmodule.exports = require('./$.core').isIterable = function(it){\n  var O = Object(it);\n  return O[ITERATOR] !== undefined\n    || '@@iterator' in O\n    || Iterators.hasOwnProperty(classof(O));\n};","'use strict';\nvar ctx         = require('./$.ctx')\n  , $export     = require('./$.export')\n  , toObject    = require('./$.to-object')\n  , call        = require('./$.iter-call')\n  , isArrayIter = require('./$.is-array-iter')\n  , toLength    = require('./$.to-length')\n  , getIterFn   = require('./core.get-iterator-method');\n$export($export.S + $export.F * !require('./$.iter-detect')(function(iter){ Array.from(iter); }), 'Array', {\n  // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\n  from: function from(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\n    var O       = toObject(arrayLike)\n      , C       = typeof this == 'function' ? this : Array\n      , $$      = arguments\n      , $$len   = $$.length\n      , mapfn   = $$len > 1 ? $$[1] : undefined\n      , mapping = mapfn !== undefined\n      , index   = 0\n      , iterFn  = getIterFn(O)\n      , length, result, step, iterator;\n    if(mapping)mapfn = ctx(mapfn, $$len > 2 ? $$[2] : undefined, 2);\n    // if object isn't iterable or it's array with default iterator - use simple case\n    if(iterFn != undefined && !(C == Array && isArrayIter(iterFn))){\n      for(iterator = iterFn.call(O), result = new C; !(step = iterator.next()).done; index++){\n        result[index] = mapping ? call(iterator, mapfn, [step.value, index], true) : step.value;\n      }\n    } else {\n      length = toLength(O.length);\n      for(result = new C(length); length > index; index++){\n        result[index] = mapping ? mapfn(O[index], index) : O[index];\n      }\n    }\n    result.length = index;\n    return result;\n  }\n});\n","'use strict';\nvar addToUnscopables = require('./$.add-to-unscopables')\n  , step             = require('./$.iter-step')\n  , Iterators        = require('./$.iterators')\n  , toIObject        = require('./$.to-iobject');\n\n// 22.1.3.4 Array.prototype.entries()\n// 22.1.3.13 Array.prototype.keys()\n// 22.1.3.29 Array.prototype.values()\n// 22.1.3.30 Array.prototype[@@iterator]()\nmodule.exports = require('./$.iter-define')(Array, 'Array', function(iterated, kind){\n  this._t = toIObject(iterated); // target\n  this._i = 0;                   // next index\n  this._k = kind;                // kind\n// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n}, function(){\n  var O     = this._t\n    , kind  = this._k\n    , index = this._i++;\n  if(!O || index >= O.length){\n    this._t = undefined;\n    return step(1);\n  }\n  if(kind == 'keys'  )return step(0, index);\n  if(kind == 'values')return step(0, O[index]);\n  return step(0, [index, O[index]]);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\nIterators.Arguments = Iterators.Array;\n\naddToUnscopables('keys');\naddToUnscopables('values');\naddToUnscopables('entries');","'use strict';\nvar strong = require('./$.collection-strong');\n\n// 23.1 Map Objects\nrequire('./$.collection')('Map', function(get){\n  return function Map(){ return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n  // 23.1.3.6 Map.prototype.get(key)\n  get: function get(key){\n    var entry = strong.getEntry(this, key);\n    return entry && entry.v;\n  },\n  // 23.1.3.9 Map.prototype.set(key, value)\n  set: function set(key, value){\n    return strong.def(this, key === 0 ? 0 : key, value);\n  }\n}, strong, true);","// 20.2.2.22 Math.log2(x)\nvar $export = require('./$.export');\n\n$export($export.S, 'Math', {\n  log2: function log2(x){\n    return Math.log(x) / Math.LN2;\n  }\n});","// 19.1.3.1 Object.assign(target, source)\nvar $export = require('./$.export');\n\n$export($export.S + $export.F, 'Object', {assign: require('./$.object-assign')});","// 19.1.2.5 Object.freeze(O)\nvar isObject = require('./$.is-object');\n\nrequire('./$.object-sap')('freeze', function($freeze){\n  return function freeze(it){\n    return $freeze && isObject(it) ? $freeze(it) : it;\n  };\n});","// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\nvar toIObject = require('./$.to-iobject');\n\nrequire('./$.object-sap')('getOwnPropertyDescriptor', function($getOwnPropertyDescriptor){\n  return function getOwnPropertyDescriptor(it, key){\n    return $getOwnPropertyDescriptor(toIObject(it), key);\n  };\n});","// 19.1.2.14 Object.keys(O)\nvar toObject = require('./$.to-object');\n\nrequire('./$.object-sap')('keys', function($keys){\n  return function keys(it){\n    return $keys(toObject(it));\n  };\n});","// 19.1.3.19 Object.setPrototypeOf(O, proto)\nvar $export = require('./$.export');\n$export($export.S, 'Object', {setPrototypeOf: require('./$.set-proto').set});","'use strict';\nvar $          = require('./$')\n  , LIBRARY    = require('./$.library')\n  , global     = require('./$.global')\n  , ctx        = require('./$.ctx')\n  , classof    = require('./$.classof')\n  , $export    = require('./$.export')\n  , isObject   = require('./$.is-object')\n  , anObject   = require('./$.an-object')\n  , aFunction  = require('./$.a-function')\n  , strictNew  = require('./$.strict-new')\n  , forOf      = require('./$.for-of')\n  , setProto   = require('./$.set-proto').set\n  , same       = require('./$.same-value')\n  , SPECIES    = require('./$.wks')('species')\n  , speciesConstructor = require('./$.species-constructor')\n  , asap       = require('./$.microtask')\n  , PROMISE    = 'Promise'\n  , process    = global.process\n  , isNode     = classof(process) == 'process'\n  , P          = global[PROMISE]\n  , Wrapper;\n\nvar testResolve = function(sub){\n  var test = new P(function(){});\n  if(sub)test.constructor = Object;\n  return P.resolve(test) === test;\n};\n\nvar USE_NATIVE = function(){\n  var works = false;\n  function P2(x){\n    var self = new P(x);\n    setProto(self, P2.prototype);\n    return self;\n  }\n  try {\n    works = P && P.resolve && testResolve();\n    setProto(P2, P);\n    P2.prototype = $.create(P.prototype, {constructor: {value: P2}});\n    // actual Firefox has broken subclass support, test that\n    if(!(P2.resolve(5).then(function(){}) instanceof P2)){\n      works = false;\n    }\n    // actual V8 bug, https://code.google.com/p/v8/issues/detail?id=4162\n    if(works && require('./$.descriptors')){\n      var thenableThenGotten = false;\n      P.resolve($.setDesc({}, 'then', {\n        get: function(){ thenableThenGotten = true; }\n      }));\n      works = thenableThenGotten;\n    }\n  } catch(e){ works = false; }\n  return works;\n}();\n\n// helpers\nvar sameConstructor = function(a, b){\n  // library wrapper special case\n  if(LIBRARY && a === P && b === Wrapper)return true;\n  return same(a, b);\n};\nvar getConstructor = function(C){\n  var S = anObject(C)[SPECIES];\n  return S != undefined ? S : C;\n};\nvar isThenable = function(it){\n  var then;\n  return isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n};\nvar PromiseCapability = function(C){\n  var resolve, reject;\n  this.promise = new C(function($$resolve, $$reject){\n    if(resolve !== undefined || reject !== undefined)throw TypeError('Bad Promise constructor');\n    resolve = $$resolve;\n    reject  = $$reject;\n  });\n  this.resolve = aFunction(resolve),\n  this.reject  = aFunction(reject)\n};\nvar perform = function(exec){\n  try {\n    exec();\n  } catch(e){\n    return {error: e};\n  }\n};\nvar notify = function(record, isReject){\n  if(record.n)return;\n  record.n = true;\n  var chain = record.c;\n  asap(function(){\n    var value = record.v\n      , ok    = record.s == 1\n      , i     = 0;\n    var run = function(reaction){\n      var handler = ok ? reaction.ok : reaction.fail\n        , resolve = reaction.resolve\n        , reject  = reaction.reject\n        , result, then;\n      try {\n        if(handler){\n          if(!ok)record.h = true;\n          result = handler === true ? value : handler(value);\n          if(result === reaction.promise){\n            reject(TypeError('Promise-chain cycle'));\n          } else if(then = isThenable(result)){\n            then.call(result, resolve, reject);\n          } else resolve(result);\n        } else reject(value);\n      } catch(e){\n        reject(e);\n      }\n    };\n    while(chain.length > i)run(chain[i++]); // variable length - can't use forEach\n    chain.length = 0;\n    record.n = false;\n    if(isReject)setTimeout(function(){\n      var promise = record.p\n        , handler, console;\n      if(isUnhandled(promise)){\n        if(isNode){\n          process.emit('unhandledRejection', value, promise);\n        } else if(handler = global.onunhandledrejection){\n          handler({promise: promise, reason: value});\n        } else if((console = global.console) && console.error){\n          console.error('Unhandled promise rejection', value);\n        }\n      } record.a = undefined;\n    }, 1);\n  });\n};\nvar isUnhandled = function(promise){\n  var record = promise._d\n    , chain  = record.a || record.c\n    , i      = 0\n    , reaction;\n  if(record.h)return false;\n  while(chain.length > i){\n    reaction = chain[i++];\n    if(reaction.fail || !isUnhandled(reaction.promise))return false;\n  } return true;\n};\nvar $reject = function(value){\n  var record = this;\n  if(record.d)return;\n  record.d = true;\n  record = record.r || record; // unwrap\n  record.v = value;\n  record.s = 2;\n  record.a = record.c.slice();\n  notify(record, true);\n};\nvar $resolve = function(value){\n  var record = this\n    , then;\n  if(record.d)return;\n  record.d = true;\n  record = record.r || record; // unwrap\n  try {\n    if(record.p === value)throw TypeError(\"Promise can't be resolved itself\");\n    if(then = isThenable(value)){\n      asap(function(){\n        var wrapper = {r: record, d: false}; // wrap\n        try {\n          then.call(value, ctx($resolve, wrapper, 1), ctx($reject, wrapper, 1));\n        } catch(e){\n          $reject.call(wrapper, e);\n        }\n      });\n    } else {\n      record.v = value;\n      record.s = 1;\n      notify(record, false);\n    }\n  } catch(e){\n    $reject.call({r: record, d: false}, e); // wrap\n  }\n};\n\n// constructor polyfill\nif(!USE_NATIVE){\n  // 25.4.3.1 Promise(executor)\n  P = function Promise(executor){\n    aFunction(executor);\n    var record = this._d = {\n      p: strictNew(this, P, PROMISE),         // <- promise\n      c: [],                                  // <- awaiting reactions\n      a: undefined,                           // <- checked in isUnhandled reactions\n      s: 0,                                   // <- state\n      d: false,                               // <- done\n      v: undefined,                           // <- value\n      h: false,                               // <- handled rejection\n      n: false                                // <- notify\n    };\n    try {\n      executor(ctx($resolve, record, 1), ctx($reject, record, 1));\n    } catch(err){\n      $reject.call(record, err);\n    }\n  };\n  require('./$.redefine-all')(P.prototype, {\n    // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n    then: function then(onFulfilled, onRejected){\n      var reaction = new PromiseCapability(speciesConstructor(this, P))\n        , promise  = reaction.promise\n        , record   = this._d;\n      reaction.ok   = typeof onFulfilled == 'function' ? onFulfilled : true;\n      reaction.fail = typeof onRejected == 'function' && onRejected;\n      record.c.push(reaction);\n      if(record.a)record.a.push(reaction);\n      if(record.s)notify(record, false);\n      return promise;\n    },\n    // 25.4.5.1 Promise.prototype.catch(onRejected)\n    'catch': function(onRejected){\n      return this.then(undefined, onRejected);\n    }\n  });\n}\n\n$export($export.G + $export.W + $export.F * !USE_NATIVE, {Promise: P});\nrequire('./$.set-to-string-tag')(P, PROMISE);\nrequire('./$.set-species')(PROMISE);\nWrapper = require('./$.core')[PROMISE];\n\n// statics\n$export($export.S + $export.F * !USE_NATIVE, PROMISE, {\n  // 25.4.4.5 Promise.reject(r)\n  reject: function reject(r){\n    var capability = new PromiseCapability(this)\n      , $$reject   = capability.reject;\n    $$reject(r);\n    return capability.promise;\n  }\n});\n$export($export.S + $export.F * (!USE_NATIVE || testResolve(true)), PROMISE, {\n  // 25.4.4.6 Promise.resolve(x)\n  resolve: function resolve(x){\n    // instanceof instead of internal slot check because we should fix it without replacement native Promise core\n    if(x instanceof P && sameConstructor(x.constructor, this))return x;\n    var capability = new PromiseCapability(this)\n      , $$resolve  = capability.resolve;\n    $$resolve(x);\n    return capability.promise;\n  }\n});\n$export($export.S + $export.F * !(USE_NATIVE && require('./$.iter-detect')(function(iter){\n  P.all(iter)['catch'](function(){});\n})), PROMISE, {\n  // 25.4.4.1 Promise.all(iterable)\n  all: function all(iterable){\n    var C          = getConstructor(this)\n      , capability = new PromiseCapability(C)\n      , resolve    = capability.resolve\n      , reject     = capability.reject\n      , values     = [];\n    var abrupt = perform(function(){\n      forOf(iterable, false, values.push, values);\n      var remaining = values.length\n        , results   = Array(remaining);\n      if(remaining)$.each.call(values, function(promise, index){\n        var alreadyCalled = false;\n        C.resolve(promise).then(function(value){\n          if(alreadyCalled)return;\n          alreadyCalled = true;\n          results[index] = value;\n          --remaining || resolve(results);\n        }, reject);\n      });\n      else resolve(results);\n    });\n    if(abrupt)reject(abrupt.error);\n    return capability.promise;\n  },\n  // 25.4.4.4 Promise.race(iterable)\n  race: function race(iterable){\n    var C          = getConstructor(this)\n      , capability = new PromiseCapability(C)\n      , reject     = capability.reject;\n    var abrupt = perform(function(){\n      forOf(iterable, false, function(promise){\n        C.resolve(promise).then(capability.resolve, reject);\n      });\n    });\n    if(abrupt)reject(abrupt.error);\n    return capability.promise;\n  }\n});","'use strict';\nvar strong = require('./$.collection-strong');\n\n// 23.2 Set Objects\nrequire('./$.collection')('Set', function(get){\n  return function Set(){ return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n  // 23.2.3.1 Set.prototype.add(value)\n  add: function add(value){\n    return strong.def(this, value = value === 0 ? 0 : value, value);\n  }\n}, strong);","'use strict';\nvar $at  = require('./$.string-at')(true);\n\n// 21.1.3.27 String.prototype[@@iterator]()\nrequire('./$.iter-define')(String, 'String', function(iterated){\n  this._t = String(iterated); // target\n  this._i = 0;                // next index\n// 21.1.5.2.1 %StringIteratorPrototype%.next()\n}, function(){\n  var O     = this._t\n    , index = this._i\n    , point;\n  if(index >= O.length)return {value: undefined, done: true};\n  point = $at(O, index);\n  this._i += point.length;\n  return {value: point, done: false};\n});","'use strict';\n// ECMAScript 6 symbols shim\nvar $              = require('./$')\n  , global         = require('./$.global')\n  , has            = require('./$.has')\n  , DESCRIPTORS    = require('./$.descriptors')\n  , $export        = require('./$.export')\n  , redefine       = require('./$.redefine')\n  , $fails         = require('./$.fails')\n  , shared         = require('./$.shared')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , uid            = require('./$.uid')\n  , wks            = require('./$.wks')\n  , keyOf          = require('./$.keyof')\n  , $names         = require('./$.get-names')\n  , enumKeys       = require('./$.enum-keys')\n  , isArray        = require('./$.is-array')\n  , anObject       = require('./$.an-object')\n  , toIObject      = require('./$.to-iobject')\n  , createDesc     = require('./$.property-desc')\n  , getDesc        = $.getDesc\n  , setDesc        = $.setDesc\n  , _create        = $.create\n  , getNames       = $names.get\n  , $Symbol        = global.Symbol\n  , $JSON          = global.JSON\n  , _stringify     = $JSON && $JSON.stringify\n  , setter         = false\n  , HIDDEN         = wks('_hidden')\n  , isEnum         = $.isEnum\n  , SymbolRegistry = shared('symbol-registry')\n  , AllSymbols     = shared('symbols')\n  , useNative      = typeof $Symbol == 'function'\n  , ObjectProto    = Object.prototype;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar setSymbolDesc = DESCRIPTORS && $fails(function(){\n  return _create(setDesc({}, 'a', {\n    get: function(){ return setDesc(this, 'a', {value: 7}).a; }\n  })).a != 7;\n}) ? function(it, key, D){\n  var protoDesc = getDesc(ObjectProto, key);\n  if(protoDesc)delete ObjectProto[key];\n  setDesc(it, key, D);\n  if(protoDesc && it !== ObjectProto)setDesc(ObjectProto, key, protoDesc);\n} : setDesc;\n\nvar wrap = function(tag){\n  var sym = AllSymbols[tag] = _create($Symbol.prototype);\n  sym._k = tag;\n  DESCRIPTORS && setter && setSymbolDesc(ObjectProto, tag, {\n    configurable: true,\n    set: function(value){\n      if(has(this, HIDDEN) && has(this[HIDDEN], tag))this[HIDDEN][tag] = false;\n      setSymbolDesc(this, tag, createDesc(1, value));\n    }\n  });\n  return sym;\n};\n\nvar isSymbol = function(it){\n  return typeof it == 'symbol';\n};\n\nvar $defineProperty = function defineProperty(it, key, D){\n  if(D && has(AllSymbols, key)){\n    if(!D.enumerable){\n      if(!has(it, HIDDEN))setDesc(it, HIDDEN, createDesc(1, {}));\n      it[HIDDEN][key] = true;\n    } else {\n      if(has(it, HIDDEN) && it[HIDDEN][key])it[HIDDEN][key] = false;\n      D = _create(D, {enumerable: createDesc(0, false)});\n    } return setSymbolDesc(it, key, D);\n  } return setDesc(it, key, D);\n};\nvar $defineProperties = function defineProperties(it, P){\n  anObject(it);\n  var keys = enumKeys(P = toIObject(P))\n    , i    = 0\n    , l = keys.length\n    , key;\n  while(l > i)$defineProperty(it, key = keys[i++], P[key]);\n  return it;\n};\nvar $create = function create(it, P){\n  return P === undefined ? _create(it) : $defineProperties(_create(it), P);\n};\nvar $propertyIsEnumerable = function propertyIsEnumerable(key){\n  var E = isEnum.call(this, key);\n  return E || !has(this, key) || !has(AllSymbols, key) || has(this, HIDDEN) && this[HIDDEN][key]\n    ? E : true;\n};\nvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key){\n  var D = getDesc(it = toIObject(it), key);\n  if(D && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key]))D.enumerable = true;\n  return D;\n};\nvar $getOwnPropertyNames = function getOwnPropertyNames(it){\n  var names  = getNames(toIObject(it))\n    , result = []\n    , i      = 0\n    , key;\n  while(names.length > i)if(!has(AllSymbols, key = names[i++]) && key != HIDDEN)result.push(key);\n  return result;\n};\nvar $getOwnPropertySymbols = function getOwnPropertySymbols(it){\n  var names  = getNames(toIObject(it))\n    , result = []\n    , i      = 0\n    , key;\n  while(names.length > i)if(has(AllSymbols, key = names[i++]))result.push(AllSymbols[key]);\n  return result;\n};\nvar $stringify = function stringify(it){\n  if(it === undefined || isSymbol(it))return; // IE8 returns string on undefined\n  var args = [it]\n    , i    = 1\n    , $$   = arguments\n    , replacer, $replacer;\n  while($$.length > i)args.push($$[i++]);\n  replacer = args[1];\n  if(typeof replacer == 'function')$replacer = replacer;\n  if($replacer || !isArray(replacer))replacer = function(key, value){\n    if($replacer)value = $replacer.call(this, key, value);\n    if(!isSymbol(value))return value;\n  };\n  args[1] = replacer;\n  return _stringify.apply($JSON, args);\n};\nvar buggyJSON = $fails(function(){\n  var S = $Symbol();\n  // MS Edge converts symbol values to JSON as {}\n  // WebKit converts symbol values to JSON as null\n  // V8 throws on boxed symbols\n  return _stringify([S]) != '[null]' || _stringify({a: S}) != '{}' || _stringify(Object(S)) != '{}';\n});\n\n// 19.4.1.1 Symbol([description])\nif(!useNative){\n  $Symbol = function Symbol(){\n    if(isSymbol(this))throw TypeError('Symbol is not a constructor');\n    return wrap(uid(arguments.length > 0 ? arguments[0] : undefined));\n  };\n  redefine($Symbol.prototype, 'toString', function toString(){\n    return this._k;\n  });\n\n  isSymbol = function(it){\n    return it instanceof $Symbol;\n  };\n\n  $.create     = $create;\n  $.isEnum     = $propertyIsEnumerable;\n  $.getDesc    = $getOwnPropertyDescriptor;\n  $.setDesc    = $defineProperty;\n  $.setDescs   = $defineProperties;\n  $.getNames   = $names.get = $getOwnPropertyNames;\n  $.getSymbols = $getOwnPropertySymbols;\n\n  if(DESCRIPTORS && !require('./$.library')){\n    redefine(ObjectProto, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n  }\n}\n\nvar symbolStatics = {\n  // 19.4.2.1 Symbol.for(key)\n  'for': function(key){\n    return has(SymbolRegistry, key += '')\n      ? SymbolRegistry[key]\n      : SymbolRegistry[key] = $Symbol(key);\n  },\n  // 19.4.2.5 Symbol.keyFor(sym)\n  keyFor: function keyFor(key){\n    return keyOf(SymbolRegistry, key);\n  },\n  useSetter: function(){ setter = true; },\n  useSimple: function(){ setter = false; }\n};\n// 19.4.2.2 Symbol.hasInstance\n// 19.4.2.3 Symbol.isConcatSpreadable\n// 19.4.2.4 Symbol.iterator\n// 19.4.2.6 Symbol.match\n// 19.4.2.8 Symbol.replace\n// 19.4.2.9 Symbol.search\n// 19.4.2.10 Symbol.species\n// 19.4.2.11 Symbol.split\n// 19.4.2.12 Symbol.toPrimitive\n// 19.4.2.13 Symbol.toStringTag\n// 19.4.2.14 Symbol.unscopables\n$.each.call((\n  'hasInstance,isConcatSpreadable,iterator,match,replace,search,' +\n  'species,split,toPrimitive,toStringTag,unscopables'\n).split(','), function(it){\n  var sym = wks(it);\n  symbolStatics[it] = useNative ? sym : wrap(sym);\n});\n\nsetter = true;\n\n$export($export.G + $export.W, {Symbol: $Symbol});\n\n$export($export.S, 'Symbol', symbolStatics);\n\n$export($export.S + $export.F * !useNative, 'Object', {\n  // 19.1.2.2 Object.create(O [, Properties])\n  create: $create,\n  // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n  defineProperty: $defineProperty,\n  // 19.1.2.3 Object.defineProperties(O, Properties)\n  defineProperties: $defineProperties,\n  // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n  getOwnPropertyDescriptor: $getOwnPropertyDescriptor,\n  // 19.1.2.7 Object.getOwnPropertyNames(O)\n  getOwnPropertyNames: $getOwnPropertyNames,\n  // 19.1.2.8 Object.getOwnPropertySymbols(O)\n  getOwnPropertySymbols: $getOwnPropertySymbols\n});\n\n// 24.3.2 JSON.stringify(value [, replacer [, space]])\n$JSON && $export($export.S + $export.F * (!useNative || buggyJSON), 'JSON', {stringify: $stringify});\n\n// 19.4.3.5 Symbol.prototype[@@toStringTag]\nsetToStringTag($Symbol, 'Symbol');\n// 20.2.1.9 Math[@@toStringTag]\nsetToStringTag(Math, 'Math', true);\n// 24.3.3 JSON[@@toStringTag]\nsetToStringTag(global.JSON, 'JSON', true);","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar $export  = require('./$.export');\n\n$export($export.P, 'Map', {toJSON: require('./$.collection-to-json')('Map')});","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar $export  = require('./$.export');\n\n$export($export.P, 'Set', {toJSON: require('./$.collection-to-json')('Set')});","require('./es6.array.iterator');\nvar Iterators = require('./$.iterators');\nIterators.NodeList = Iterators.HTMLCollection = Iterators.Array;","// (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\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","'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    this.tileCoords = [];\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    if (features.length) this.splitTile(features, 0, 0, 0);\n\n    if (debug) {\n        if (features.length) 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    solidChildren: false,   // whether to tile solid square tiles further\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\n    // avoid recursion by using a processing queue\n    while (stack.length) {\n        y = stack.pop();\n        x = stack.pop();\n        z = stack.pop();\n        features = stack.pop();\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 * options.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            this.tileCoords.push({z: z, x: x, y: y});\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 solid clipped square\n        if (!options.solidChildren && isClippedSquare(tile, options.extent, options.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 * options.buffer / options.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 (!parent) return null;\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, 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    if (!this.tiles[id]) return null;\n\n    return transformTile(this.tiles[id], extent);\n};\n\nfunction transformTile(tile, extent) {\n    if (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\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\n// checks whether a tile is a whole-area fill after clipping; if it is, there's no sense slicing it further\nfunction isClippedSquare(tile, extent, buffer) {\n\n    var features = tile.source;\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    var len = feature.geometry[0].length;\n    if (len !== 5) return false;\n\n    for (var i = 0; i < len; i++) {\n        var p = transformPoint(feature.geometry[0][i], extent, tile.z2, tile.x, tile.y);\n        if ((p[0] !== -buffer && p[0] !== extent + buffer) ||\n            (p[1] !== -buffer && p[1] !== extent + buffer)) return false;\n    }\n\n    return true;\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","module.exports = invert\n\n/**\n * Inverts a mat3\n *\n * @alias mat3.invert\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nfunction invert(out, a) {\n  var a00 = a[0], a01 = a[1], a02 = a[2]\n  var a10 = a[3], a11 = a[4], a12 = a[5]\n  var a20 = a[6], a21 = a[7], a22 = a[8]\n\n  var b01 = a22 * a11 - a12 * a21\n  var b11 = -a22 * a10 + a12 * a20\n  var b21 = a21 * a10 - a11 * a20\n\n  // Calculate the determinant\n  var det = a00 * b01 + a01 * b11 + a02 * b21\n\n  if (!det) return null\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\n  return out\n}\n","module.exports = normalFromMat4\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @alias mat3.normalFromMat4\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*/\nfunction normalFromMat4(out, a) {\n  var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3]\n  var a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7]\n  var a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11]\n  var a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15]\n\n  var b00 = a00 * a11 - a01 * a10\n  var b01 = a00 * a12 - a02 * a10\n  var b02 = a00 * a13 - a03 * a10\n  var b03 = a01 * a12 - a02 * a11\n  var b04 = a01 * a13 - a03 * a11\n  var b05 = a02 * a13 - a03 * a12\n  var b06 = a20 * a31 - a21 * a30\n  var b07 = a20 * a32 - a22 * a30\n  var b08 = a20 * a33 - a23 * a30\n  var b09 = a21 * a32 - a22 * a31\n  var b10 = a21 * a33 - a23 * a31\n  var b11 = a22 * a33 - a23 * a32\n\n  // Calculate the determinant\n  var det = b00 * b11\n          - b01 * b10\n          + b02 * b09\n          + b03 * b08\n          - b04 * b07\n          + b05 * b06\n\n  if (!det) return null\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","module.exports = copy;\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 */\nfunction copy(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};","module.exports = identity;\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nfunction identity(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};","var identity = require('./identity');\n\nmodule.exports = lookAt;\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 */\nfunction lookAt(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) < 0.000001 &&\n        Math.abs(eyey - centery) < 0.000001 &&\n        Math.abs(eyez - centerz) < 0.000001) {\n        return 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};","module.exports = multiply;\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 */\nfunction multiply(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};","module.exports = perspective;\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 */\nfunction perspective(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};","module.exports = scale;\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 **/\nfunction scale(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};","module.exports = translate;\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 */\nfunction translate(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};","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","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","'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');\n// var 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;\n// module.exports.dump                = dumper.dump;\n// module.exports.safeDump            = dumper.safeDump;\nmodule.exports.YAMLException       = require('./js-yaml/exception');\n\n// Deprecated 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') || (subject === null);\n}\n\n\nfunction isObject(subject) {\n  return (typeof subject === 'object') && (subject !== null);\n}\n\n\nfunction toArray(sequence) {\n  if (Array.isArray(sequence)) return sequence;\n  else if (isNothing(sequence)) 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 (number === 0) && (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","// YAML error class. http://stackoverflow.com/questions/8458984\n//\n'use strict';\n\nfunction YAMLException(reason, mark) {\n  // Super constructor\n  Error.call(this);\n\n  // Include stack trace in error object\n  if (Error.captureStackTrace) {\n    // Chrome and NodeJS\n    Error.captureStackTrace(this, this.constructor);\n  } else {\n    // FF, IE 10+ and Safari 6+. Fallback for others\n    this.stack = (new Error()).stack || '';\n  }\n\n  this.name = 'YAMLException';\n  this.reason = reason;\n  this.mark = mark;\n  this.message = (this.reason || '(unknown reason)') + (this.mark ? ' ' + this.mark.toString() : '');\n}\n\n\n// Inherit from Error\nYAMLException.prototype = Object.create(Error.prototype);\nYAMLException.prototype.constructor = YAMLException;\n\n\nYAMLException.prototype.toString = function toString(compact) {\n  var result = this.name + ': ';\n\n  result += 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 c === 0x2C/* , */ ||\n         c === 0x5B/* [ */ ||\n         c === 0x5D/* ] */ ||\n         c === 0x7B/* { */ ||\n         c === 0x7D/* } */;\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  this.json      = options['json']      || false;\n  this.listener  = options['listener']  || null;\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  if (state.onWarning) {\n    state.onWarning.call(null, generateError(state, message));\n  }\n}\n\n\nvar directiveHandlers = {\n\n  YAML: function handleYamlDirective(state, name, args) {\n\n    var match, major, minor;\n\n    if (state.version !== null) {\n      throwError(state, 'duplication of %YAML directive');\n    }\n\n    if (args.length !== 1) {\n      throwError(state, 'YAML directive accepts exactly one argument');\n    }\n\n    match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n    if (match === null) {\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 (major !== 1) {\n      throwError(state, 'unacceptable YAML version of the document');\n    }\n\n    state.version = args[0];\n    state.checkLineBreaks = (minor < 2);\n\n    if (minor !== 1 && minor !== 2) {\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 (args.length !== 2) {\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 (!(_character === 0x09 ||\n              (0x20 <= _character && _character <= 0x10FFFF))) {\n          throwError(state, 'expected valid JSON character');\n        }\n      }\n    } else if (PATTERN_NON_PRINTABLE.test(_result)) {\n      throwError(state, 'the stream contains non-printable characters');\n    }\n\n    state.result += _result;\n  }\n}\n\nfunction mergeMappings(state, destination, source, overridableKeys) {\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      overridableKeys[key] = true;\n    }\n  }\n}\n\nfunction storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode) {\n  var index, quantity;\n\n  keyNode = String(keyNode);\n\n  if (_result === null) {\n    _result = {};\n  }\n\n  if (keyTag === 'tag:yaml.org,2002:merge') {\n    if (Array.isArray(valueNode)) {\n      for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n        mergeMappings(state, _result, valueNode[index], overridableKeys);\n      }\n    } else {\n      mergeMappings(state, _result, valueNode, overridableKeys);\n    }\n  } else {\n    if (!state.json &&\n        !_hasOwnProperty.call(overridableKeys, keyNode) &&\n        _hasOwnProperty.call(_result, keyNode)) {\n      throwError(state, 'duplicated mapping key');\n    }\n    _result[keyNode] = valueNode;\n    delete overridableKeys[keyNode];\n  }\n\n  return _result;\n}\n\nfunction readLineBreak(state) {\n  var ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x0A/* LF */) {\n    state.position++;\n  } else if (ch === 0x0D/* CR */) {\n    state.position++;\n    if (state.input.charCodeAt(state.position) === 0x0A/* LF */) {\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 (ch !== 0) {\n    while (is_WHITE_SPACE(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (allowComments && ch === 0x23/* # */) {\n      do {\n        ch = state.input.charCodeAt(++state.position);\n      } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && ch !== 0);\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 (ch === 0x20/* Space */) {\n        state.lineIndent++;\n        ch = state.input.charCodeAt(++state.position);\n      }\n    } else {\n      break;\n    }\n  }\n\n  if (checkIndent !== -1 && lineBreaks !== 0 && 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 ((ch === 0x2D/* - */ || ch === 0x2E/* . */) &&\n      ch === state.input.charCodeAt(_position + 1) &&\n      ch === state.input.charCodeAt(_position + 2)) {\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 (count === 1) {\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      ch === 0x23/* # */    ||\n      ch === 0x26/* & */    ||\n      ch === 0x2A/* * */    ||\n      ch === 0x21/* ! */    ||\n      ch === 0x7C/* | */    ||\n      ch === 0x3E/* > */    ||\n      ch === 0x27/* ' */    ||\n      ch === 0x22/* \" */    ||\n      ch === 0x25/* % */    ||\n      ch === 0x40/* @ */    ||\n      ch === 0x60/* ` */) {\n    return false;\n  }\n\n  if (ch === 0x3F/* ? */ || ch === 0x2D/* - */) {\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 (ch !== 0) {\n    if (ch === 0x3A/* : */) {\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 (ch === 0x23/* # */) {\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 (ch !== 0x27/* ' */) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    if (ch === 0x27/* ' */) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (ch === 0x27/* ' */) {\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,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch !== 0x22/* \" */) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    if (ch === 0x22/* \" */) {\n      captureSegment(state, captureStart, state.position, true);\n      state.position++;\n      return true;\n\n    } else if (ch === 0x5C/* \\ */) {\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      overridableKeys = {},\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 (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  while (ch !== 0) {\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 (ch === 0x3F/* ? */) {\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) && ch === 0x3A/* : */) {\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, overridableKeys, keyTag, keyNode, valueNode);\n    } else if (isPair) {\n      _result.push(storeMappingPair(state, null, overridableKeys, 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 (ch === 0x2C/* , */) {\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 (ch !== 0) {\n    ch = state.input.charCodeAt(++state.position);\n\n    if (ch === 0x2B/* + */ || ch === 0x2D/* - */) {\n      if (CHOMPING_CLIP === chomping) {\n        chomping = (ch === 0x2B/* + */) ? 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 (ch === 0x23/* # */) {\n      do { ch = state.input.charCodeAt(++state.position); }\n      while (!is_EOL(ch) && (ch !== 0));\n    }\n  }\n\n  while (ch !== 0) {\n    readLineBreak(state);\n    state.lineIndent = 0;\n\n    ch = state.input.charCodeAt(state.position);\n\n    while ((!detectedIndent || state.lineIndent < textIndent) &&\n           (ch === 0x20/* Space */)) {\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 (emptyLines === 0) {\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      state.result += common.repeat('\\n', emptyLines);\n    }\n\n    detectedIndent = true;\n    emptyLines = 0;\n    captureStart = state.position;\n\n    while (!is_EOL(ch) && (ch !== 0)) {\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 (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (ch !== 0) {\n\n    if (ch !== 0x2D/* - */) {\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) && (ch !== 0)) {\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      overridableKeys = {},\n      keyTag        = null,\n      keyNode       = null,\n      valueNode     = null,\n      atExplicitKey = false,\n      detected      = false,\n      ch;\n\n  if (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (ch !== 0) {\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 ((ch === 0x3F/* ? */ || ch === 0x3A/* : */) && is_WS_OR_EOL(following)) {\n\n      if (ch === 0x3F/* ? */) {\n        if (atExplicitKey) {\n          storeMappingPair(state, _result, overridableKeys, 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 (ch === 0x3A/* : */) {\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, overridableKeys, 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, overridableKeys, 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 && (ch !== 0)) {\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, overridableKeys, 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 (ch !== 0x21/* ! */) return false;\n\n  if (state.tag !== null) {\n    throwError(state, 'duplication of a tag property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  if (ch === 0x3C/* < */) {\n    isVerbatim = true;\n    ch = state.input.charCodeAt(++state.position);\n\n  } else if (ch === 0x21/* ! */) {\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 (ch !== 0 && ch !== 0x3E/* > */);\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 (ch !== 0 && !is_WS_OR_EOL(ch)) {\n\n      if (ch === 0x21/* ! */) {\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 (ch !== 0x26/* & */) return false;\n\n  if (state.anchor !== null) {\n    throwError(state, 'duplication of an anchor property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (ch !== 0 && !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      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch !== 0x2A/* * */) return false;\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (ch !== 0 && !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\n  if (state.listener !== null) {\n    state.listener('open', state);\n  }\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 (indentStatus === 1) {\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 (indentStatus === 1 || 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 (indentStatus === 1) {\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 (state.tag !== null || state.anchor !== null) {\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 (state.tag === null) {\n            state.tag = '?';\n          }\n        }\n\n        if (state.anchor !== null) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else if (indentStatus === 0) {\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 (state.tag !== null && 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 (state.anchor !== null) {\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 (state.result !== null && 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 (state.anchor !== null) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else {\n      throwError(state, 'unknown tag !<' + state.tag + '>');\n    }\n  }\n\n  if (state.listener !== null) {\n    state.listener('close', state);\n  }\n  return state.tag !== null ||  state.anchor !== null || 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 ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (state.lineIndent > 0 || ch !== 0x25/* % */) {\n      break;\n    }\n\n    hasDirectives = true;\n    ch = state.input.charCodeAt(++state.position);\n    _position = state.position;\n\n    while (ch !== 0 && !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 (ch !== 0) {\n      while (is_WHITE_SPACE(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      if (ch === 0x23/* # */) {\n        do { ch = state.input.charCodeAt(++state.position); }\n        while (ch !== 0 && !is_EOL(ch));\n        break;\n      }\n\n      if (is_EOL(ch)) break;\n\n      _position = state.position;\n\n      while (ch !== 0 && !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 (ch !== 0) readLineBreak(state);\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 (state.lineIndent === 0 &&\n      state.input.charCodeAt(state.position)     === 0x2D/* - */ &&\n      state.input.charCodeAt(state.position + 1) === 0x2D/* - */ &&\n      state.input.charCodeAt(state.position + 2) === 0x2D/* - */) {\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 (state.input.charCodeAt(state.position) === 0x2E/* . */) {\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 (input.charCodeAt(input.length - 1) !== 0x0A/* LF */ &&\n        input.charCodeAt(input.length - 1) !== 0x0D/* CR */) {\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  // Use 0 as string terminator. That significantly simplifies bounds check.\n  state.input += '\\0';\n\n  while (state.input.charCodeAt(state.position) === 0x20/* Space */) {\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);\n\n  if (documents.length === 0) {\n    /*eslint-disable no-undefined*/\n    return undefined;\n  } else if (documents.length === 1) {\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) return null;\n\n  indent = indent || 4;\n  maxLength = maxLength || 75;\n\n  head = '';\n  start = this.position;\n\n  while (start > 0 && '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(start - 1)) === -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 && '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(end)) === -1) {\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 exclude.indexOf(index) === -1;\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 && type.loadKind !== 'scalar') {\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 (map !== null) {\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 (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) {\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 (YAML_NODE_KINDS.indexOf(this.kind) === -1) {\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 (data === null) return false;\n\n  var code, idx, bitlen = 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 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) return new NodeBuffer(result);\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 (data === null) return false;\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.prototype.toString.call(object) === '[object Boolean]';\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 (data === null) return false;\n\n  if (!YAML_FLOAT_PATTERN.test(data)) 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 ('+-'.indexOf(value[0]) >= 0) {\n    value = value.slice(1);\n  }\n\n  if (value === '.inf') {\n    return (sign === 1) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n  } else if (value === '.nan') {\n    return NaN;\n\n  } else if (value.indexOf(':') >= 0) {\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\n\nvar SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/;\n\nfunction representYamlFloat(object, style) {\n  var res;\n\n  if (isNaN(object)) {\n    switch (style) {\n      case 'lowercase': return '.nan';\n      case 'uppercase': return '.NAN';\n      case 'camelcase': return '.NaN';\n    }\n  } else if (Number.POSITIVE_INFINITY === object) {\n    switch (style) {\n      case 'lowercase': return '.inf';\n      case 'uppercase': return '.INF';\n      case 'camelcase': return '.Inf';\n    }\n  } else if (Number.NEGATIVE_INFINITY === object) {\n    switch (style) {\n      case 'lowercase': return '-.inf';\n      case 'uppercase': return '-.INF';\n      case 'camelcase': return '-.Inf';\n    }\n  } else if (common.isNegativeZero(object)) {\n    return '-0.0';\n  }\n\n  res = object.toString(10);\n\n  // JS stringifier can build scientific format without dots: 5e-100,\n  // while YAML requres dot: 5.e-100. Fix it with simple hack\n\n  return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace('e', '.e') : res;\n}\n\nfunction isFloat(object) {\n  return (Object.prototype.toString.call(object) === '[object Number]') &&\n         (object % 1 !== 0 || 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 (data === null) return false;\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') return false;\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))) return false;\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))) return false;\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 (value === '0') return 0;\n\n  if (ch === '0') {\n    if (value[1] === 'b') return sign * parseInt(value.slice(2), 2);\n    if (value[1] === 'x') return sign * parseInt(value, 16);\n    return sign * parseInt(value, 8);\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.prototype.toString.call(object)) === '[object Number]' &&\n         (object % 1 === 0 && !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  // workaround to exclude package from browserify list.\n  var _require = require;\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 (data === null) return false;\n\n  try {\n    var source = '(' + data + ')',\n        ast    = esprima.parse(source, { range: true });\n\n    if (ast.type                    !== 'Program'             ||\n        ast.body.length             !== 1                     ||\n        ast.body[0].type            !== 'ExpressionStatement' ||\n        ast.body[0].expression.type !== 'FunctionExpression') {\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 (ast.type                    !== 'Program'             ||\n      ast.body.length             !== 1                     ||\n      ast.body[0].type            !== 'ExpressionStatement' ||\n      ast.body[0].expression.type !== 'FunctionExpression') {\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.prototype.toString.call(object) === '[object Function]';\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 (data === null) return false;\n  if (data.length === 0) return false;\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) modifiers = tail[1];\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\n  return true;\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) modifiers = tail[1];\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) result += 'g';\n  if (object.multiline) result += 'm';\n  if (object.ignoreCase) result += 'i';\n\n  return result;\n}\n\nfunction isRegExp(object) {\n  return Object.prototype.toString.call(object) === '[object RegExp]';\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 typeof object === 'undefined';\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 data !== null ? data : {}; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlMerge(data) {\n  return data === '<<' || data === null;\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 (data === null) return true;\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 object === null;\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 (data === null) return true;\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 (_toString.call(pair) !== '[object Object]') return false;\n\n    for (pairKey in pair) {\n      if (_hasOwnProperty.call(pair, pairKey)) {\n        if (!pairHasKey) pairHasKey = true;\n        else return false;\n      }\n    }\n\n    if (!pairHasKey) return false;\n\n    if (objectKeys.indexOf(pairKey) === -1) objectKeys.push(pairKey);\n    else return false;\n  }\n\n  return true;\n}\n\nfunction constructYamlOmap(data) {\n  return data !== null ? 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 (data === null) return true;\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 (_toString.call(pair) !== '[object Object]') return false;\n\n    keys = Object.keys(pair);\n\n    if (keys.length !== 1) return false;\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return true;\n}\n\nfunction constructYamlPairs(data) {\n  if (data === null) return [];\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 data !== null ? data : []; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n  if (data === null) return true;\n\n  var key, object = data;\n\n  for (key in object) {\n    if (_hasOwnProperty.call(object, key)) {\n      if (object[key] !== null) return false;\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlSet(data) {\n  return data !== null ? 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 data !== null ? 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 (data === null) return false;\n  if (YAML_TIMESTAMP_REGEXP.exec(data) === null) return false;\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 (match === null) throw new Error('Date resolve error');\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] === '-') delta = -delta;\n  }\n\n  date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n  if (delta) date.setTime(date.getTime() - delta);\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","/*\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\nfunction notNull(x)  { return x != null; }\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[0] === '$') {\n        return 'context.' + key.substring(1);\n    }\n    return 'context.feature.properties.' + key;\n}\n\nfunction nullValue(key, value) {\n    return ' true ';\n}\n\nfunction propertyEqual(key, value) {\n    return wrap(maybeQuote(value) + ' === ' + lookUp(key));\n}\n\nfunction propertyOr(key, values) {\n    return wrap(values.map(function (x) { return propertyEqual(key, x); }).join(' || '));\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 (values && values.length > 0) ? printNested(values.map(parseFilter), '||') : 'true';\n}\n\nfunction all(_, values) {\n    return (values && values.length > 0) ? printNested(values.map(parseFilter), '&&') : 'true';\n}\n\nfunction not(key, value) {\n    return '!' + wrap(parseFilter(value).join(' && '));\n}\n\nfunction none(key, values) {\n    return '!' + wrap(any(null, values));\n}\n\nfunction propertyMatchesBoolean(key, value) {\n    return wrap(lookUp(key) + (value ? ' != ' : ' == ')  + 'null');\n}\n\nfunction rangeMatch(key, values) {\n    var expressions = [];\n\n    if (values.max) {\n        expressions.push('' + lookUp(key) + ' < ' + values.max);\n    }\n\n    if (values.min) {\n        expressions.push('' + lookUp(key) + ' >= ' + values.min);\n    }\n\n    return wrap(expressions.join(' && '));\n}\n\nfunction parseFilter(filter) {\n    var filterAST = [];\n\n    // Function filter\n    if (typeof filter === 'function') {\n        return [wrap(filter.toString() + '(context)')];\n    }\n    // Array filter, implicit 'any'\n    else if (Array.isArray(filter)) {\n        return [any(null, filter)];\n    }\n    // Null filter object\n    else if (filter == null) {\n        return ['true'];\n    }\n\n    // Object filter, e.g. implicit 'all'\n    var keys = Object.keys(filter);\n    for (var k=0; k < keys.length; k++) {\n        var key = keys[k];\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 (key === 'not') {\n            filterAST.push(not(key, value));\n        } else if (key === 'any') {\n            filterAST.push(any(key, value));\n        } else if (key === 'all') {\n            filterAST.push(all(key, value));\n        } else if (key === 'none') {\n            filterAST.push(none(key, value));\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 if (value == null) {\n            filterAST.push(nullValue(key, value));\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"]}","'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","// shim for using process in browser\n\nvar process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n    && window.setImmediate;\n    var canMutationObserver = typeof window !== 'undefined'\n    && window.MutationObserver;\n    var canPost = typeof window !== 'undefined'\n    && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    var queue = [];\n\n    if (canMutationObserver) {\n        var hiddenDiv = document.createElement(\"div\");\n        var observer = new MutationObserver(function () {\n            var queueList = queue.slice();\n            queue.length = 0;\n            queueList.forEach(function (fn) {\n                fn();\n            });\n        });\n\n        observer.observe(hiddenDiv, { attributes: true });\n\n        return function nextTick(fn) {\n            if (!queue.length) {\n                hiddenDiv.setAttribute('yes', 'no');\n            }\n            queue.push(fn);\n        };\n    }\n\n    if (canPost) {\n        window.addEventListener('message', function (ev) {\n            var source = ev.source;\n            if ((source === window || source === null) && ev.data === 'process-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('process-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\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","(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/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}"]}","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","// Geometry building functions\nimport Geo from '../geo';\n\nexport const tile_bounds = [\n    { x: 0, y: 0},\n    { x: Geo.tile_scale, y: -Geo.tile_scale } // TODO: correct for flipped y-axis?\n];\n\nexport const default_uvs = [0, 0, 1, 1];\n\n// Tests if a line segment (from point A to B) is outside the tile bounds\n// (within a certain tolerance to account for geometry nearly on tile edges)\nexport function outsideTile (_a, _b, tolerance) {\n    let tile_min = tile_bounds[0];\n    let tile_max = tile_bounds[1];\n\n    // TODO: fix flipped Y coords here, confusing with 'max' reference\n    if ((_a[0] <= tile_min.x + tolerance && _b[0] <= tile_min.x + tolerance) ||\n        (_a[0] >= tile_max.x - tolerance && _b[0] >= tile_max.x - tolerance) ||\n        (_a[1] >= tile_min.y - tolerance && _b[1] >= tile_min.y - tolerance) ||\n        (_a[1] <= tile_max.y + tolerance && _b[1] <= tile_max.y + tolerance)) {\n        return true;\n    }\n\n    return false;\n}\n","// Point builders\nimport { default_uvs } from './common';\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.\nexport function buildQuadsForPoints (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        var [min_u, min_v, max_u, max_v] = texcoord_scale || default_uvs;\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","// Polygon builders\nimport Geo from '../geo';\nimport Vector from '../vector';\nimport { default_uvs, outsideTile } from './common';\n\nimport earcut from 'earcut';\n\nconst up_vec3 = [0, 0, 1];\n\n// Tesselate a flat 2D polygon\n// x & y coordinates will be set as first two elements of provided vertex_template\nexport function buildPolygons (\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 || default_uvs;\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 = 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\nexport function buildExtrudedPolygons (\n    polygons,\n    z, height, min_height,\n    vertex_data, vertex_template,\n    normal_index,\n    normal_normalize,\n    {\n        remove_tile_edges,\n        tile_edge_tolerance,\n        texcoord_index,\n        texcoord_scale,\n        texcoord_normalize,\n        winding\n    }) {\n\n    // Top\n    var min_z = z + (min_height || 0);\n    var max_z = z + height;\n    vertex_template[2] = max_z;\n    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 || default_uvs;\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                if (remove_tile_edges && outsideTile(contour[w], contour[w+1], tile_edge_tolerance)) {\n                    continue; // don't extrude tile edges\n                }\n\n                // Wall order is dependent on winding order, so that normals face outward\n                let w0, w1;\n                if (winding === 'CCW') {\n                    w0 = w;\n                    w1 = w+1;\n                }\n                else {\n                    w0 = w+1;\n                    w1 = w;\n                }\n\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[w1][0], contour[w1][1], max_z],\n                    [contour[w1][0], contour[w1][1], min_z],\n                    [contour[w0][0], contour[w0][1], min_z],\n                    // Triangle\n                    [contour[w0][0], contour[w0][1], min_z],\n                    [contour[w0][0], contour[w0][1], max_z],\n                    [contour[w1][0], contour[w1][1], max_z]\n                ];\n\n                // Calc the normal of the wall from up vector and one segment of the wall triangles\n                let wall_vec = Vector.normalize([contour[w1][0] - contour[w0][0], contour[w1][1] - contour[w0][1], 0]);\n                let normal = Vector.cross(up_vec3, wall_vec);\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// Triangulation using earcut\n// https://github.com/mapbox/earcut\nexport function triangulatePolygon (contours) {\n    return earcut(contours);\n}\n","// Geometry building functions\n\nimport Vector from '../vector';\nimport Geo from '../geo';\nimport { default_uvs, outsideTile } from './common';\n\nconst zero_vec2 = [0, 0];\n\n// Build tessellated triangles for a polyline\nconst corners_for_cap = {\n    butt: 0,\n    square: 2,\n    round: 3\n};\n\nconst triangles_for_join = {\n    miter: 0,\n    bevel: 1,\n    round: 3\n};\n\n// Scaling factor to add precision to line texture V coordinate packed as normalized short\nconst v_scale_adjust = Geo.tile_scale;\n\nexport function buildPolylines (\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        texcoord_ratio,\n        scaling_index,\n        scaling_normalize,\n        join, cap,\n        miter_limit\n    }) {\n\n    var cornersOnCap = corners_for_cap[cap] || 0;         // default 'butt'\n    var trianglesOnJoin = triangles_for_join[join] || 0;  // default 'miter'\n\n    // Configure miter limit\n    if (trianglesOnJoin === 0) {\n        miter_limit = miter_limit || 3; // default miter limit\n        var miter_len_sq = miter_limit * miter_limit;\n    }\n\n    // Build variables\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        texcoord_ratio = texcoord_ratio || 1;\n        var [min_u, min_v, max_u, max_v] = texcoord_scale || default_uvs;\n    }\n\n    // Values that are constant for each line and are passed to helper functions\n    var context = {\n        vertex_data,\n        vertex_template,\n        half_width: 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        v_scale: 1 / ((width * texcoord_ratio) * v_scale_adjust), // scales line texture as a ratio of the line's width\n        total_dist: 0,\n        num_pairs: 0\n    };\n\n    for (var ln = 0; ln < lines.length; ln++) {\n        // Remove dupe points from lines\n        var line = dedupeLine(lines[ln], closed_polygon);\n        if (!line) {\n            continue; // skip if no valid line remaining\n        }\n\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(context);\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(outsideTile(line[i], line[lineSize-2], 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 (outsideTile(coordCurr, coordNext, tile_edge_tolerance)) {\n                        normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                        if (isPrev) {\n                            addVertexPair(\n                                coordCurr, normCurr,\n                                context.texcoords && Vector.length(Vector.sub(coordCurr, coordPrev)),\n                                context);\n                            context.num_pairs++;\n\n                            // Add vertices to buffer acording their index\n                            indexPairs(context);\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, context);\n                }\n\n                //  Miter limit: if miter join is too sharp, convert to bevel instead\n                if (trianglesOnJoin === 0 && Vector.lengthSq(normCurr) > miter_len_sq) {\n                    trianglesOnJoin = triangles_for_join['bevel']; // switch to bevel\n                }\n\n                // If it's a JOIN\n                if (trianglesOnJoin !== 0 && isPrev && isNext) {\n                    addJoin([coordPrev, coordCurr, coordNext],\n                            [normPrev,normCurr, normNext],\n                            trianglesOnJoin,\n                            context);\n                } else {\n                    addVertexPair(\n                        coordCurr, normCurr,\n                        context.texcoords && Vector.length(Vector.sub(coordCurr, coordPrev)),\n                        context);\n                }\n\n                if (isNext) {\n                   context.num_pairs++;\n                }\n\n                isPrev = true;\n            }\n        }\n\n        // Add vertices to buffer according to their index\n        indexPairs(context);\n\n         // If it's the END of a LINE\n        if(!closed_polygon) {\n            addCap(coordCurr, normCurr, cornersOnCap , false, context);\n        }\n    }\n}\n\n// Remove duplicate points from a line, creating a new line only when points must be removed\nfunction dedupeLine (line, closed) {\n    let i, dupes;\n\n    // Collect dupe points\n    for (i=0; i < line.length - 1; i++) {\n        if (line[i][0] === line[i+1][0] && line[i][1] === line[i+1][1]) {\n            dupes = dupes || [];\n            dupes.push(i);\n        }\n    }\n\n    // Remove dupe points\n    if (dupes) {\n        line = line.slice(0);\n        dupes.forEach(d => line.splice(d, 1));\n    }\n\n    // Line needs at least 2 points, polygon needs at least 3 (+1 to close)\n    if (!closed && line.length < 2 || closed && line.length < 4) {\n        return;\n    }\n    return line;\n}\n\n// Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertex(coord, normal, uv, { half_width, 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] * half_width,\n                       coord[1] + normal[1] * half_width]);\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, dist, context) {\n    if (context.texcoords) {\n        context.total_dist += dist * context.v_scale;\n        addVertex(coord, normal, [context.max_u, context.total_dist], context);\n        addVertex(coord, Vector.neg(normal), [context.min_u, context.total_dist], context);\n    }\n    else {\n        addVertex(coord, normal, null, context);\n        addVertex(coord, Vector.neg(normal), null, context);\n    }\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, context) {\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(context);\n\n    // Initial parameters\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n\n    // Calculate the angle between A and B\n    var angle_delta = Vector.angleBetween(nA, nB);\n\n    // Calculate the angle for each triangle\n    var angle_step = angle_delta/numTriangles;\n\n    // Joins that turn left or right behave diferently...\n    // triangles need to be rotated in diferent directions\n    if (!signed) {\n        angle_step *= -1;\n    }\n\n    if (context.texcoords) {\n        var uvCurr = Vector.set(uA);\n        var uv_delta = Vector.div(Vector.sub(uB,uA), numTriangles);\n    }\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, context);\n\n    //  Add first corner\n    addVertex(coord, normCurr, uA, context);\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_step);     //  Rotate the extrusion normal\n        if (context.texcoords) {\n            uvCurr = Vector.add(uvCurr,uv_delta);\n        }\n        addVertex(coord, normCurr, uvCurr, context);      //  Add computed corner\n    }\n\n    // Index the vertices\n    for (var i = 0; i < numTriangles; i++) {\n        if (signed) {\n            addIndex(i+2, context);\n            addIndex(0, context);\n            addIndex(i+1, context);\n        } else {\n            addIndex(i+1, context);\n            addIndex(0, context);\n            addIndex(i+2, context);\n        }\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n\n//  addBevel    A ----- B\n//             / \\ , . / \\\n//           /   /\\   /\\  \\\n//              /  \\ /   \\ \\\n//                / C \\\nfunction addBevel (coord, nA, nC, nB, uA, uC, uB, signed, context) {\n    // Add previous vertices to buffer and clear the buffers and index pairs\n    // because we are going to add more triangles.\n    indexPairs(context);\n\n    //  Add the FIRST and CENTER vertex\n    addVertex(coord, nC, uC, context);\n    addVertex(coord, nA, uA, context);\n    addVertex(coord, nB, uB, context);\n\n    if (signed) {\n        addIndex(2, context);\n        addIndex(0, context);\n        addIndex(1, context);\n    } else {\n        addIndex(1, context);\n        addIndex(0, context);\n        addIndex(2, context);\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n\n\n//  Tessalate a SQUARE geometry between A and B     + ........+\n//  and interpolating their UVs                     : \\  2  / :\n//                                                  : 1\\   /3 :\n//                                                  A -- C -- B\nfunction addSquare (coord, nA, nB, uA, uC, uB, signed, context) {\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(context);\n\n    // Initial parameters\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n    if (context.texcoords) {\n        var uvCurr = Vector.set(uA);\n        var uv_delta = Vector.div(Vector.sub(uB,uA), 4);\n    }\n\n    // First and last cap have different directions\n    var angle_step = 0.78539816339; // PI/4 = 45 degrees\n    if (!signed) {\n        angle_step *= -1;\n    }\n\n    //  Add the FIRST and CENTER vertex\n    //  The triangles will be add in a FAN style around it\n    //\n    //                       A -- C\n    addVertex(coord, zero_vec2, uC, context);\n\n    //  Add first corner     +\n    //                       :\n    //                       A -- C\n    addVertex(coord, normCurr, uA, context);\n\n    // Iterate through the rest of the coorners completing the triangles\n    // (except the corner 1 to save one triangle to be draw )\n    for (var t = 0; t < 4; t++) {\n\n        // 0     1     2\n        //  + ........+\n        //  : \\     / :\n        //  :  \\   /  :\n        //  A -- C -- B  3\n\n        normPrev = Vector.normalize(normCurr);\n        normCurr = Vector.rot( Vector.normalize(normCurr), angle_step);     //  Rotate the extrusion normal\n\n        if (t === 0 || t === 2) {\n            // In order to make this \"fan\" look like a square the mitters need to be streach\n            var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n            normCurr = Vector.mult(normCurr, scale*scale);\n        }\n\n        if (context.texcoords) {\n            uvCurr = Vector.add(uvCurr,uv_delta);\n        }\n\n        if (t !== 1) {\n            //  Add computed corner (except the corner 1)\n            addVertex(coord, normCurr, uvCurr, context);\n        }\n    }\n\n    for (var i = 0; i < 3; i++) {\n        if (signed) {\n            addIndex(i+2, context);\n            addIndex(0, context);\n            addIndex(i+1, context);\n        } else {\n            addIndex(i+1, context);\n            addIndex(0, context);\n            addIndex(i+2, context);\n        }\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.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, nTriangles, context) {\n    var signed = Vector.signed_area(coords[0], coords[1], coords[2]) > 0;\n    var nA = normals[0],              // normal to point A (aT)\n        nC = Vector.neg(normals[1]),  // normal to center (-vP)\n        nB = normals[2];              // normal to point B (bT)\n    var uA, uB, uC;\n\n    if (context.texcoords) {\n        context.total_dist += Vector.length(Vector.sub(coords[1], coords[0])) * context.v_scale;\n        uA = [context.max_u, context.total_dist];\n        uC = [context.min_u, context.total_dist];\n        uB = uA;\n    }\n\n    if (signed) {\n        addVertex(coords[1], nA, uA, context);\n        addVertex(coords[1], nC, uC, context);\n    } else {\n        nA = Vector.neg(normals[0]);\n        nC = normals[1];\n        nB = Vector.neg(normals[2]);\n\n        if (context.texcoords) {\n            uA = [context.min_u, context.total_dist];\n            uC = [context.max_u, context.total_dist];\n            uB = uA;\n        }\n        addVertex(coords[1], nC, uC, context);\n        addVertex(coords[1], nA, uA, context);\n    }\n\n    if (nTriangles === 1) {\n        addBevel(coords[1], nA, nC, nB, uA, uC, uB, signed, context);\n    } else if (nTriangles > 1){\n        addFan(coords[1], nA, nC, nB, uA, uC, uB, signed, nTriangles, context);\n    }\n\n    if (signed) {\n        addVertex(coords[1], nB, uB, context);\n        addVertex(coords[1], nC, uC, context);\n    } else {\n        addVertex(coords[1], nC, uC, context);\n        addVertex(coords[1], nB, uB, context);\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, context) {\n\n    if (numCorners < 1) {\n        return;\n    }\n\n    // UVs\n    var uvA, uvB, uvC;\n    if (context.texcoords) {\n        uvC = [context.min_u+(context.max_u-context.min_u)/2, context.total_dist];   // Center point UVs\n        uvA = [context.min_u, context.total_dist];                                   // Beginning angle UVs\n        uvB = [context.max_u, context.total_dist];                                   // Ending angle UVs\n    }\n\n    if ( numCorners === 2 ){\n        // If caps are set as squares\n        addSquare( coord,\n                   Vector.neg(normal), normal,\n                   uvA, uvC, uvB,\n                   isBeginning,\n                   context);\n    } else {\n        // If caps are set as round ( numCorners===3 )\n        addFan( coord,\n                Vector.neg(normal), zero_vec2, normal,\n                uvA, uvC, uvB,\n                isBeginning, numCorners*2, context);\n    }\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, half_width, 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 half_width 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] = half_width;\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 (context) {\n    // Add vertices to buffer acording their index\n    for (var i = 0; i < context.num_pairs; i++) {\n        addIndex(2*i+2, context);\n        addIndex(2*i+1, context);\n        addIndex(2*i+0, context);\n\n        addIndex(2*i+2, context);\n        addIndex(2*i+3, context);\n        addIndex(2*i+1, context);\n    }\n\n    context.num_pairs = 0;\n\n    // Clean the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n","import Utils from './utils/utils';\nimport ShaderProgram from './gl/shader_program';\nimport {mat4, mat3, vec3} from './utils/gl-matrix';\n\n// Abstract base class\nexport default class Camera {\n\n    constructor(name, view, options = {}) {\n        this.view = view;\n        this.position = options.position;\n        this.zoom = options.zoom;\n    }\n\n    // Create a camera by type name, factory-style\n    static create(name, view, config) {\n        switch (config.type) {\n            case 'isometric':\n                return new IsometricCamera(name, view, config);\n            case 'flat':\n                return new FlatCamera(name, view, config);\n            case 'perspective':\n            /* falls through */\n            default:\n                return new PerspectiveCamera(name, view, config);\n        }\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 pass for feature selection, etc.)\n    setupProgram(program) {\n    }\n\n    // Sync camera position/zoom to scene view\n    updateView () {\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.view.setView(view);\n        }\n    }\n\n    // Set model-view and normal matrices\n    setupMatrices (matrices, program) {\n        // Model view matrix - transform tile space into view space (meters, relative to camera)\n        mat4.multiply(matrices.model_view32, this.view_matrix, matrices.model);\n        program.uniform('Matrix4fv', 'u_modelView', false, matrices.model_view32);\n\n        // Normal matrices - transforms surface normals into view space\n        mat3.normalFromMat4(matrices.normal32, matrices.model_view32);\n        mat3.invert(matrices.inverse_normal32, matrices.normal32);\n        program.uniform('Matrix3fv', 'u_normalMatrix', false, matrices.normal32);\n        program.uniform('Matrix3fv', 'u_inverseNormalMatrix', false, matrices.inverse_normal32);\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, view, options = {}) {\n        super(name, view, 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.view_matrix = new Float64Array(16);\n        this.projection_matrix = 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.view.size.css.height * this.view.meters_per_pixel;\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.view.zoom, this.focal_length),\n            fov: Utils.interpolate(this.view.zoom, this.fov)\n         });\n\n        // View matrix\n        var position = [this.view.center.meters.x, this.view.center.meters.y, height];\n        this.position_meters = position;\n\n        // mat4.lookAt(this.view_matrix,\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.view_matrix,\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.projection_matrix, fov, this.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.view.size.css.width;\n        this.vanishing_point_skew[1] = this.vanishing_point[1] / this.view.size.css.height;\n\n        // Adjust projection matrix to include vanishing point skew\n        this.projection_matrix[8] = -this.vanishing_point_skew[0]; // z column of x row, e.g. amount z skews x\n        this.projection_matrix[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.projection_matrix, this.projection_matrix,\n            vec3.fromValues(\n                viewport_height/2 * this.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.projection_matrix, this.projection_matrix, 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.projection_matrix);\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, view, options = {}) {\n        super(name, view, 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.view_matrix = new Float64Array(16);\n        this.projection_matrix = 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.view.size.css.height * this.view.meters_per_pixel;\n        var position = [this.view.center.meters.x, this.view.center.meters.y, this.viewport_height];\n        this.position_meters = position;\n\n        // View\n        mat4.identity(this.view_matrix);\n        mat4.translate(this.view_matrix, this.view_matrix, vec3.fromValues(-position[0], -position[1], 0));\n\n        // Projection\n        mat4.identity(this.projection_matrix);\n\n        // apply isometric skew\n        this.projection_matrix[8] = this.axis.x / this.view.aspect; // z column of x row, e.g. amount z skews x\n        this.projection_matrix[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.projection_matrix, this.projection_matrix,\n            vec3.fromValues(\n                2 / this.view.size.meters.x,\n                2 / this.view.size.meters.y,\n                2 / this.view.size.meters.y\n            )\n        );\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projection_matrix);\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, view, options = {}) {\n        super(name, view, 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.default_source_max_zoom = 18;\nGeo.default_view_max_zoom = 20;\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\n\nlet meters_per_pixel = [];\nGeo.metersPerPixel = function (z) {\n    meters_per_pixel[z] = meters_per_pixel[z] || Geo.min_zoom_meters_per_pixel / Math.pow(2, z);\n    return meters_per_pixel[z];\n};\n\nlet meters_per_tile = [];\nGeo.metersPerTile = function (z) {\n    meters_per_tile[z] = meters_per_tile[z] || Geo.circumference_meters / Math.pow(2, z);\n    return meters_per_tile[z];\n};\n\n// Conversion functions based on an defined tile scale\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\nlet units_per_meter = [];\nGeo.unitsPerMeter = function (z) {\n    units_per_meter[z] = units_per_meter[z] || Geo.tile_scale / (Geo.tile_size * Geo.metersPerPixel(z));\n    return units_per_meter[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 == null) {\n        return; // skip if missing geometry (valid GeoJSON)\n    }\n\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    let area = Geo.signedPolygonAreaSum(ring);\n    if (area > 0) {\n        return 'CW';\n    }\n    else if (area < 0) {\n        return 'CCW';\n    }\n    // return undefined on zero area polygon\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    if (!fullscreen) {\n        Context.resize(gl, parseFloat(canvas.style.width), parseFloat(canvas.style.height), options.device_pixel_ratio);\n    }\n    else {\n        Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\n        window.addEventListener('resize', function () {\n            Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\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(width * device_pixel_ratio);\n    gl.canvas.height = Math.round(height * device_pixel_ratio);\n    gl.bindFramebuffer(gl.FRAMEBUFFER, null);\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        RenderState.defaults = {};\n        // Culling\n        RenderState.defaults.culling = true;\n        RenderState.defaults.culling_face = gl.BACK;\n\n        // Blending\n        RenderState.defaults.blending = false;\n        RenderState.defaults.blending_src = gl.ONE_MINUS_SRC_ALPHA;\n        RenderState.defaults.blending_dst = gl.ONE_MINUS_SRC_ALPHA;\n        RenderState.defaults.blending_src_alpha = gl.ONE;\n        RenderState.defaults.blending_dst_alpha = gl.ONE_MINUS_SRC_ALPHA;\n\n        // Depth test/write\n        RenderState.defaults.depth_write = true;\n        RenderState.defaults.depth_test = true;\n        RenderState.defaults.depth_func = gl.LESS;\n\n    \t// Culling\n    \tRenderState.culling = new RenderState(\n    \t\t{ cull: RenderState.defaults.culling, face: RenderState.defaults.culling_face },\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                blend: RenderState.defaults.blending,\n                src: RenderState.defaults.blending_src,\n                dst: RenderState.defaults.blending_dst,\n                src_alpha: RenderState.defaults.blending_src_alpha,\n                dst_alpha: RenderState.defaults.blending_dst_alpha\n            },\n            (value) => {\n    \t\t\tif (value.blend) {\n            \t\tgl.enable(gl.BLEND);\n\n                    if (value.src_alpha && value.dst_alpha) {\n                        gl.blendFuncSeparate(value.src, value.dst, value.src_alpha, value.dst_alpha);\n                    }\n                    else {\n                        gl.blendFunc(value.src, value.dst);\n                    }\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: RenderState.defaults.depth_write },\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: RenderState.defaults.depth_test, depth_func: RenderState.defaults.depth_func },\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","// 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        let precision = '';\n        let high = this.gl.getShaderPrecisionFormat(this.gl.FRAGMENT_SHADER, this.gl.HIGH_FLOAT);\n        if (high && high.precision > 0) {\n            precision = 'precision highp float;\\n';\n        }\n        else {\n            precision = 'precision mediump float;\\n';\n        }\n\n        defines['TANGRAM_VERTEX_SHADER'] = true;\n        defines['TANGRAM_FRAGMENT_SHADER'] = false;\n        this.computed_vertex_source =\n            header +\n            precision +\n            ShaderProgram.buildDefineString(defines) +\n            this.computed_vertex_source;\n\n        // Precision qualifier only valid in fragment shader\n        // NB: '#extension' statements added to fragment shader only, as IE11 throws error when they appear in\n        // vertex shader (even when guarded by #ifdef), and no WebGL extensions require '#extension' in vertex shaders\n        defines['TANGRAM_VERTEX_SHADER'] = false;\n        defines['TANGRAM_FRAGMENT_SHADER'] = true;\n        this.computed_fragment_source =\n            ShaderProgram.buildExtensionString(extensions) +\n            header +\n            precision +\n            ShaderProgram.buildDefineString(defines) +\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)) {\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)) {\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            log.warn(`Can't find texture '${texture_name}'`);\n            return;\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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\\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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\\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 += `#ifdef GL_${ext}\\n#extension GL_${ext} : enable\\n#endif\\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/accessors'] =\n\"#ifdef TANGRAM_VERTEX_SHADER\\n\" +\n\"\\n\" +\n\"// Vertex position in model space: [0, 1] range over the local tile\\n\" +\n\"// Note positions can be outside that range due to unclipped geometry, geometry higher than a unit cube, etc.\\n\" +\n\"vec4 modelPosition() {\\n\" +\n\"    return\\n\" +\n\"        vec4(\\n\" +\n\"            SHORT(a_position.xyz)                       // scale normalized short to full range\\n\" +\n\"            / TANGRAM_TILE_SCALE                        // scale coords to ~0-1 range\\n\" +\n\"            * exp2(u_tile_origin.z - u_tile_origin.w),  // adjust for tile overzooming\\n\" +\n\"        1.)\\n\" +\n\"        + vec4(0., 1., 0., 0.);\\n\" +\n\"        // NB: additional offset to account for unusual Tangram JS y coords,\\n\" +\n\"        // should be refactored to remove\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"// Position in model space as above, but according to tile coordinate (as opposed to style) zoom\\n\" +\n\"// e.g. unadjusted for tile overzooming\\n\" +\n\"vec4 modelPositionBaseZoom() {\\n\" +\n\"    return\\n\" +\n\"        vec4(\\n\" +\n\"            SHORT(a_position.xyz)   // scale normalized short to full range\\n\" +\n\"            / TANGRAM_TILE_SCALE,   // scale coords to ~0-1 range\\n\" +\n\"        1.)\\n\" +\n\"        + vec4(0., 1., 0., 0.);\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Vertex position in world coordinates, useful for 3d procedural textures, etc.\\n\" +\n\"vec4 worldPosition() {\\n\" +\n\"    return v_world_position;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"// Optionally wrap 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\"#ifdef TANGRAM_VERTEX_SHADER\\n\" +\n\"\\n\" +\n\"vec4 wrapWorldPosition(vec4 world_position) {\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"    vec2 anchor = u_tile_origin.xy - mod(u_tile_origin.xy, TANGRAM_WORLD_POSITION_WRAP);\\n\" +\n\"        world_position.xy -= anchor;\\n\" +\n\"    #endif\\n\" +\n\"    return world_position;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Normal in world space\\n\" +\n\"#if defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"\\n\" +\n\"vec3 worldNormal() {\\n\" +\n\"    return TANGRAM_NORMAL;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#elif defined(TANGRAM_FRAGMENT_SHADER)\\n\" +\n\"\\n\" +\n\"vec3 worldNormal() {\\n\" +\n\"    return u_inverseNormalMatrix * TANGRAM_NORMAL;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\";\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;\\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/rasters'] =\n\"// Uniforms defining raster textures and macros for accessing them\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_FRAGMENT_SHADER\\n\" +\n\"uniform sampler2D u_rasters[TANGRAM_NUM_RASTER_SOURCES];    // raster tile texture samplers\\n\" +\n\"uniform vec2 u_raster_sizes[TANGRAM_NUM_RASTER_SOURCES];    // raster tile texture sizes (width/height in pixels)\\n\" +\n\"uniform vec3 u_raster_offsets[TANGRAM_NUM_RASTER_SOURCES];  // raster tile texture UV starting offset for tile\\n\" +\n\"\\n\" +\n\"// Note: the raster accessors below are #defines rather than functions to\\n\" +\n\"// avoid issues with constant integer expressions for array indices\\n\" +\n\"\\n\" +\n\"// Adjusts UVs in model space to account for raster tile texture overzooming\\n\" +\n\"// (applies scale and offset adjustments)\\n\" +\n\"#define adjustRasterUV(raster_index, uv) \" +\n\"    ((uv) * u_raster_offsets[raster_index].z + u_raster_offsets[raster_index].xy)\\n\" +\n\"\\n\" +\n\"// Returns the UVs of the current model position for a raster sampler\\n\" +\n\"#define currentRasterUV(raster_index) \" +\n\"    (adjustRasterUV(raster_index, v_modelpos_base_zoom.xy))\\n\" +\n\"\\n\" +\n\"// Returns pixel location in raster tile texture at current model position\\n\" +\n\"#define currentRasterPixel(raster_index) \" +\n\"    (currentRasterUV(raster_index) * rasterPixelSize(raster_index))\\n\" +\n\"\\n\" +\n\"// Samples a raster tile texture for the current model position\\n\" +\n\"#define sampleRaster(raster_index) \" +\n\"    (texture2D(u_rasters[raster_index], currentRasterUV(raster_index)))\\n\" +\n\"\\n\" +\n\"// Samples a raster tile texture for a given pixel\\n\" +\n\"#define sampleRasterAtPixel(raster_index, pixel) \" +\n\"    (texture2D(u_rasters[raster_index], adjustRasterUV(raster_index, (pixel) / rasterPixelSize(raster_index))))\\n\" +\n\"\\n\" +\n\"// Returns size of raster sampler in pixels\\n\" +\n\"#define rasterPixelSize(raster_index) \" +\n\"    (u_raster_sizes[raster_index])\\n\" +\n\"\\n\" +\n\"#endif\\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/unpack'] =\n\"\\n\" +\n\"// Unpack normalized shorts back to their original integer values\\n\" +\n\"#define SHORT(x) (x * 32767.)\\n\" +\n\"#define UNSIGNED_SHORT(x) (x * 65535.)\\n\" +\n\"\\n\" +\n\"// Used for cases where an attribute is stored as a normalized int type,\\n\" +\n\"// but is a floating point value that needs a range greater than [0, 1] or [-1, 1].\\n\" +\n\"// The integer value is \\\"scaled\\\" to an 8.8 fixed point style integer before it is\\n\" +\n\"// normalized in the VBO. Used for cases where low precision is suitable for both\\n\" +\n\"// the integer and fractional portions of the number.\\n\" +\n\"// Examples are extrusion vectors for dynamic lines, and screen-space size for point sprites.\\n\" +\n\"#define SCALE_8(x) (x * 256.)\\n\" +\n\"\";\n\nshaderSources['styles/points/points_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec4 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL vec3(0., 0., 1.)\\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: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\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\"\\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\"    // 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(color.a - (smoothstep(0., TANGRAM_FADE_RANGE, (point_dist - TANGRAM_FADE_START)) / TANGRAM_FADE_RANGE), 0., color.a);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // If blending is off, use alpha discard as a lower-quality substitute\\n\" +\n\"    #if !defined(TANGRAM_BLEND_OVERLAY) && !defined(TANGRAM_BLEND_INLAY)\\n\" +\n\"        if (color.a < TANGRAM_ALPHA_DISCARD) {\\n\" +\n\"            discard;\\n\" +\n\"        }\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"\\n\" +\n\"    // Fade out when tile is zooming out, e.g. acting as proxy tiles\\n\" +\n\"    // NB: this is mostly done to compensate for text label collision happening at the label\\'s 1x zoom. As labels\\n\" +\n\"    // in proxy tiles are scaled down, they begin to overlap, and the fade is a simple way to ease the transition.\\n\" +\n\"    #ifdef TANGRAM_FADE_ON_ZOOM_OUT\\n\" +\n\"        color.a *= clamp(1. - TANGRAM_FADE_ON_ZOOM_OUT_RATE * (u_tile_origin.z - u_map_position.z), 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\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 vec4 u_tile_origin;\\n\" +\n\"uniform float u_tile_proxy_depth;\\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\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL vec3(0., 0., 1.)\\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: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: raster\\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\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\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(SHORT(a_position.xyz), 1.);\\n\" +\n\"\\n\" +\n\"    // Apply positioning and scaling in screen space\\n\" +\n\"    float zscale = fract(u_map_position.z) * (SCALE_8(a_shape.w) - 1.) + 1.;\\n\" +\n\"    // float zscale = log(fract(u_map_position.z) + 1.) / log(2.) * (a_shape.w - 1.) + 1.;\\n\" +\n\"    vec2 shape = SCALE_8(a_shape.xy) * 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(SHORT(offset), 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\"    v_world_position = wrapWorldPosition(v_world_position);\\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\"        // +1 is to keep all layers including proxies > 0\\n\" +\n\"        applyLayerOrder(SHORT(a_position.w) + u_tile_proxy_depth + 1., position);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Apply pixel offset in screen-space\\n\" +\n\"    // Multiply by 2 is because screen is 2 units wide Normalized Device Coords (and u_resolution device pixels wide)\\n\" +\n\"    // Device pixel ratio adjustment is because shape is in logical pixels\\n\" +\n\"    position.xy += shape * position.w * 2. * u_device_pixel_ratio / 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_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec4 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL v_normal\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"    varying vec4 v_modelpos_base_zoom;\\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: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"    vec3 normal = TANGRAM_NORMAL;\\n\" +\n\"\\n\" +\n\"    // Apply raster to vertex color\\n\" +\n\"    #ifdef TANGRAM_RASTER_TEXTURE_COLOR\\n\" +\n\"        color *= sampleRaster(0); // multiplied to tint texture color\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // First, get normal from raster tile (if applicable)\\n\" +\n\"    #ifdef TANGRAM_RASTER_TEXTURE_NORMAL\\n\" +\n\"        normal = normalize(sampleRaster(0).rgb * 2. - 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Second, alter normal with normal map texture (if applicable)\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT) && defined(TANGRAM_MATERIAL_NORMAL_TEXTURE)\\n\" +\n\"        calculateNormal(normal);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Normal modification applied here for fragment lighting or no lighting,\\n\" +\n\"    // and in vertex shader for vertex lighting\\n\" +\n\"    #if !defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Color modification before lighting is applied\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT)\\n\" +\n\"        // Calculate per-fragment lighting\\n\" +\n\"        color = calculateLighting(v_position.xyz - u_eye, normal, color);\\n\" +\n\"    #elif defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        // Apply lighting intensity interpolated from vertex shader\\n\" +\n\"        color *= v_lighting;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Post-processing effects (modify color after lighting)\\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 vec4 u_tile_origin;\\n\" +\n\"uniform float u_tile_proxy_depth;\\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\"uniform mat3 u_inverseNormalMatrix;\\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\"// Optional model position varying for tile coordinate zoom\\n\" +\n\"#ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"    varying vec4 v_modelpos_base_zoom;\\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: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\n\" +\n\"    // Texture UVs\\n\" +\n\"    #ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"        v_texcoord = a_texcoord;\\n\" +\n\"        #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"            v_texcoord.y *= TANGRAM_V_SCALE_ADJUST;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Pass model position to fragment shader\\n\" +\n\"    #ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"        v_modelpos_base_zoom = modelPositionBaseZoom();\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = vec4(SHORT(a_position.xyz), 1.);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"        vec2 extrude = SCALE_8(a_extrude.xy);\\n\" +\n\"        float width = SHORT(a_extrude.z);\\n\" +\n\"        float dwdz = SHORT(a_extrude.w);\\n\" +\n\"        float dz = clamp(u_map_position.z - u_tile_origin.z, 0., 1.);\\n\" +\n\"\\n\" +\n\"        // Interpolate between zoom levels\\n\" +\n\"        width += dwdz * dz;\\n\" +\n\"\\n\" +\n\"        // Scale pixel dimensions to be consistent in screen space\\n\" +\n\"        width *= exp2(-dz);\\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 = wrapWorldPosition(u_model * position);\\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\"    #if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        // Vertex lighting\\n\" +\n\"        vec3 normal = v_normal;\\n\" +\n\"\\n\" +\n\"        // Modify normal before lighting\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"        // Pass lighting intensity to fragment shader\\n\" +\n\"        v_lighting = calculateLighting(position.xyz - u_eye, normal, vec4(1.));\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Camera\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"\\n\" +\n\"    // +1 is to keep all layers including proxies > 0\\n\" +\n\"    applyLayerOrder(SHORT(a_position.w) + u_tile_proxy_depth + 1., position);\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nexport default shaderSources;\n","// Texture management\nimport Utils from '../utils/utils';\nimport subscribeMixin from '../utils/subscribe';\nimport WorkerBroker from '../utils/worker_broker';\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\n        this.name = name;\n        this.retain_count = 0;\n        this.source = null;\n        this.source_type = null;\n        this.config_type = null;\n        this.loading = null;    // a Promise object to track the loading state of this texture\n        this.loaded = false;    // successfully loaded as expected\n        this.filtering = options.filtering;\n        this.sprites = options.sprites;\n        this.texcoords = {};    // sprite UVs ([0, 1] range)\n        this.sizes = {};        // sprite sizes (pixel size)\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        // Destroy previous texture if present\n        if (Texture.textures[this.name]) {\n            // Preserve previous retain count\n            this.retain_count = Texture.textures[this.name].retain_count;\n            Texture.textures[this.name].retain_count = 0; // allow to be freed\n            Texture.textures[this.name].destroy();\n        }\n\n        // Cache texture instance and definition\n        Texture.textures[this.name] = this;\n        Texture.texture_configs[this.name] = Object.assign({ name }, options);\n\n        this.load(options);\n        log.trace(`creating Texture ${this.name}`);\n    }\n\n    // Destroy a single texture instance\n    destroy() {\n        if (this.retain_count > 0) {\n            log.error(`Texture '${this.name}': destroying texture with retain count of '${this.retain_count}'`);\n            return;\n        }\n\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        log.trace(`destroying Texture ${this.name}`);\n    }\n\n    retain () {\n        this.retain_count++;\n    }\n\n    release () {\n        if (this.retain_count <= 0) {\n            log.error(`Texture '${this.name}': releasing texture with retain count of '${this.retain_count}'`);\n        }\n\n        this.retain_count--;\n        if (this.retain_count <= 0) {\n            this.destroy();\n        }\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    load(options) {\n        if (!options) {\n            return this.loading || Promise.resolve(this);\n        }\n\n        this.loading = null;\n        if (typeof options.url === 'string') {\n            this.config_type = 'url';\n            this.setUrl(options.url, options);\n        } else if (options.element) {\n            this.config_type = 'element';\n            this.setElement(options.element, options);\n        } else if (options.data && options.width && options.height) {\n            this.config_type = 'data';\n            this.setData(options.width, options.height, options.data, options);\n        }\n\n        this.loading =\n            (this.loading && this.loading.then(() => { this.calculateSprites(); return this; })) ||\n            Promise.resolve(this);\n        return this.loading;\n    }\n\n    // Sets texture from an url\n    setUrl(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.url = Utils.cacheBusterForUrl(url); // save URL reference (will be overwritten when element is loaded below)\n        this.source = this.url;\n        this.source_type = 'url';\n\n        this.loading = new Promise((resolve, reject) => {\n            let image = new Image();\n            image.onload = () => {\n                try {\n                    this.setElement(image, options);\n                }\n                catch (e) {\n                    this.loaded = false;\n                    log.warn(`Texture '${this.name}': failed to load url: '${this.source}'`, e, options);\n                    Texture.trigger('warning', { message: `Failed to load texture from ${this.source}`, error: e, texture: options });\n                }\n\n                this.loaded = true;\n                resolve(this);\n            };\n            image.onerror = e => {\n                // Warn and resolve on error\n                this.loaded = false;\n                log.warn(`Texture '${this.name}': failed to load url: '${this.source}'`, e, options);\n                Texture.trigger('warning', { message: `Failed to load texture from ${this.source}`, error: e, texture: options });\n                resolve(this);\n            };\n            image.crossOrigin = 'anonymous';\n            image.src = this.source;\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\n        this.source = data;\n        this.source_type = 'data';\n\n        this.update(options);\n        this.setFiltering(options);\n\n        this.loaded = true;\n        this.loading = Promise.resolve(this);\n        return this.loading;\n    }\n\n    // Sets the texture to track a element (canvas/image)\n    setElement(element, options) {\n        let el = element;\n\n        // a string element is interpeted as a CSS selector\n        if (typeof element === 'string') {\n            element = document.querySelector(element);\n        }\n\n        if (element instanceof HTMLCanvasElement ||\n            element instanceof HTMLImageElement ||\n            element instanceof HTMLVideoElement) {\n            this.source = element;\n            this.source_type = 'element';\n\n            this.update(options);\n            this.setFiltering(options);\n        }\n        else {\n            this.loaded = false;\n            let msg = `the 'element' parameter (\\`element: ${JSON.stringify(el)}\\`) must be a CSS `;\n            msg += `selector string, or a <canvas>, <image> or <video> object`;\n            log.warn(`Texture '${this.name}': ${msg}`, options);\n            Texture.trigger('warning', { message: `Failed to load texture because ${msg}`, texture: options });\n        }\n\n        this.loaded = true;\n        this.loading = Promise.resolve(this);\n        return this.loading;\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 or Canvas element\n        if (this.source instanceof HTMLCanvasElement || this.source instanceof HTMLVideoElement ||\n            (this.source instanceof HTMLImageElement && this.source.complete)) {\n\n            this.width = this.source.width;\n            this.height = this.source.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.source);\n        }\n        // Raw image buffer\n        else if (this.source_type === 'data') {\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.source);\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Determines appropriate filtering mode\n    setFiltering(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        options.filtering = options.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            if (options.filtering === '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                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                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                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                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] = Texture.getTexcoordsForSprite(\n                    [sprite[0], sprite[1]],\n                    [sprite[2], sprite[3]],\n                    [this.width, this.height]\n                );\n\n                // Pixel size of sprite\n                this.sizes[s] = [sprite[2], sprite[3]];\n            }\n        }\n    }\n\n}\n\n\n// Static/class methods and state\n\nTexture.create = function (gl, name, options) {\n    return new Texture(gl, name, options);\n};\n\nTexture.retain = function (name) {\n    if (Texture.textures[name]) {\n        Texture.textures[name].retain();\n    }\n};\n\nTexture.release = function (name) {\n    if (Texture.textures[name]) {\n        Texture.textures[name].release();\n    }\n};\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            texture.destroy();\n        }\n    }\n};\n\n// Get sprite pixel size and UVs\nTexture.getSpriteInfo = function (texname, sprite) {\n    let texture = Texture.textures[texname];\n    return texture && { size: texture.sizes[sprite], texcoords: texture.texcoords[sprite] };\n};\n\n// Re-scale UVs from [0, 1] range to a smaller area within the image\nTexture.getTexcoordsForSprite = function (area_origin, area_size, tex_size) {\n    var area_origin_y = tex_size[1] - area_origin[1] - area_size[1];\n\n    return [\n        area_origin[0] / tex_size[0],\n        area_origin_y / tex_size[1],\n        (area_size[0] + area_origin[0]) / tex_size[0],\n        (area_size[1] + area_origin_y) / tex_size[1]\n    ];\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\n            // If texture already exists and definition hasn't changed, no need to re-create\n            // Note: to avoid flicker when other textures/scene items change\n            if (!Texture.changed(texname, config)) {\n                continue;\n            }\n\n            let texture = Texture.create(gl, texname, config);\n            loading.push(texture.loading);\n        }\n    }\n    return Promise.all(loading);\n};\n\n// Indicate if a texture definition would be a change from the current cache\nTexture.changed = function (name, config) {\n    let texture = Texture.textures[name];\n    if (texture) { // cached texture\n        // canvas/image-based textures are considered dynamic and always refresh\n        if (texture.config_type === 'element' || config.element != null) {\n            return true;\n        }\n\n        // compare definitions\n        if (JSON.stringify(Texture.texture_configs[name]) ===\n            JSON.stringify(Object.assign({ name }, config))) {\n            return false;\n        }\n    }\n    return true;\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                sizes: tex.sizes,\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// Report max texture size for a GL context\nTexture.getMaxTextureSize = function (gl) {\n    return gl.getParameter(gl.MAX_TEXTURE_SIZE);\n};\n\n// Global set of textures, by name\nTexture.textures = {};\nTexture.texture_configs = {};\nTexture.boundTexture = -1;\nTexture.activeUnit = -1;\n\nTexture.base_url = null; // optional base URL to add to textures\n\nWorkerBroker.addTarget('Texture', Texture);\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","// Manage rendering for primitives\nimport ShaderProgram from './shader_program';\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        return true;\n    }\n\n}\n","import 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","import 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 RepeatGroup from './repeat_group';\n\nimport log from 'loglevel';\n\nvar Collision;\n\nexport default Collision = {\n\n    tiles: {},\n\n    startTile (tile) {\n        let state = this.tiles[tile] = {\n            bboxes: {           // current set of placed bounding boxes\n                aabb: [],\n                obb: []\n            },\n            objects: {},        // objects to collide, grouped by priority, then by style\n            keep: {},           // objects that were kept after collision, grouped by style\n            styles: new Set()   // styles contributing collision objects\n        };\n\n        // Promise resolved when all registered styles have added objects\n        state.complete = new Promise((resolve, reject) => {\n            state.resolve = resolve;\n            state.reject = reject;\n        });\n    },\n\n    resetTile (tile) {\n        delete this.tiles[tile];\n    },\n\n    // Add a style to the pending set, collision will block on all styles submitting to collision set\n    addStyle (style, tile) {\n        this.tiles[tile].styles.add(style);\n    },\n\n    // Add collision objects for a style\n    collide (objects, style, tile) {\n        let state = this.tiles[tile];\n        if (!state) {\n            log.trace('Collision.collide() called with null tile', tile, this.tiles, style, objects);\n            return Promise.reject(Error('Collision.collide() called with null tile', tile, this.tiles, style, objects));\n        }\n\n        // Group by priority and style\n        let tile_objects = state.objects;\n        for (let i=0; i < objects.length; i++) {\n            let obj = objects[i];\n            let priority = obj.layout.priority;\n            tile_objects[priority] = tile_objects[priority] || {};\n            tile_objects[priority][style] = tile_objects[priority][style] || [];\n            tile_objects[priority][style].push(obj);\n        }\n\n        // Remove from pending style set, if no more styles, do collision & finish tile\n        state.styles.delete(style);\n        if (state.styles.size === 0) {\n            this.endTile(tile);\n        }\n\n        // Wait for objects to be added from all styles\n        return state.complete.then(() => {\n            return state.keep[style] || [];\n        });\n    },\n\n    // Test labels for collisions, higher to lower priority\n    // When two collide, discard the lower-priority label\n    endTile (tile) {\n        let state = this.tiles[tile];\n        let bboxes = state.bboxes;\n        let keep = state.keep;\n\n        RepeatGroup.clear(tile);\n\n        // Process labels by priority, then by style\n        let priorities = Object.keys(state.objects).sort((a, b) => a - b);\n        for (let priority of priorities) {\n            let style_objects = state.objects[priority];\n            if (!style_objects) { // no labels at this priority, skip to next\n                continue;\n            }\n\n            // For each style\n            for (let style in style_objects) {\n                let objects = style_objects[style];\n                keep[style] = keep[style] || [];\n\n                for (let i = 0; i < objects.length; i++) {\n                    let { label, layout } = objects[i]; // TODO: `label` should be generic\n\n                    // test the label for intersections with other labels in the tile\n                    if (!layout.collide || !label.discard(bboxes)) {\n                        // check for repeats\n                        let check = RepeatGroup.check(label, layout, tile);\n                        if (check) {\n                            // log.trace(`discard label '${label.text}', (one_per_group: ${check.one_per_group}), dist ${Math.sqrt(check.dist_sq)/layout.units_per_pixel} < ${Math.sqrt(check.repeat_dist_sq)/layout.units_per_pixel}`);\n                            continue;\n                        }\n                        // register as placed for future repeat culling\n                        RepeatGroup.add(label, layout, tile);\n\n                        label.add(bboxes); // add label to currently visible set\n                        keep[style].push(objects[i]);\n                    }\n                    // else if (layout.collide) {\n                    //     log.trace(`discard label '${label.text}' due to collision`);\n                    // }\n                }\n            }\n        }\n\n        delete this.tiles[tile];\n        state.resolve();\n    }\n\n};\n","import boxIntersect from 'box-intersect'; // https://github.com/mikolalysenko/box-intersect\nimport Utils from '../utils/utils';\nimport OBB from '../utils/obb';\n\n// import log from 'loglevel';\n\nexport default class Label {\n\n    constructor (size, options = {}) {\n        this.size = size;\n        this.options = options;\n        this.position = null;\n        this.aabb = null;\n        this.obb = null;\n    }\n\n    // check for overlaps with other labels in the tile\n    occluded (bboxes) {\n        let intersect = false;\n        let aabbs = bboxes.aabb;\n        let obbs = bboxes.obb;\n\n        // Broad phase\n        if (aabbs.length > 0) {\n            boxIntersect([this.aabb], aabbs, (i, j) => {\n                // log.trace('collision: broad phase collide', this.options.id, this, this.aabb, aabbs[j]);\n\n                // Skip narrow phase collision if no rotation\n                if (this.obb.angle === 0 && obbs[j].angle === 0) {\n                    // log.trace('collision: skip narrow phase collide because neither is rotated', this.options.id, this, this.obb, obbs[j]);\n                    intersect = true;\n                    return true;\n                }\n\n                // Narrow phase\n                if (OBB.intersect(this.obb, obbs[j])) {\n                    // log.trace('collision: narrow phase collide', this.options.id, this, this.obb, obbs[j]);\n                    intersect = true;\n                    return true;\n                }\n            });\n        }\n        return intersect;\n    }\n\n    // Add this label's bounding box to the provided set\n    add (bboxes) {\n        bboxes.aabb.push(this.aabb);\n        bboxes.obb.push(this.obb);\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    // Depends on whether label must fit in the tile bounds, and if so, can it be moved to fit there\n    discard (bboxes) {\n        // Should the label be culled if it can't fit inside the tile bounds?\n        if (this.options.cull_from_tile) {\n            let in_tile = this.inTileBounds();\n\n            // If it doesn't fit, should we try to move it into the tile bounds?\n            if (!in_tile && this.options.move_into_tile) {\n                // Can we fit the label into the tile?\n                if (!this.moveIntoTile()) {\n                    return true; // can't fit in tile, discard\n                }\n            } else if (!in_tile) {\n                return true; // out of tile bounds, discard\n            }\n        }\n\n        // If the label hasn't been discarded yet, check to see if it's occluded by other labels\n        return this.occluded(bboxes);\n    }\n}\n\nLabel.epsilon = 0.9999; // tolerance around collision boxes, prevent perfectly adjacent objects from colliding\n","import Vector from '../vector';\nimport Label from './label';\nimport OBB from '../utils/obb';\n\nexport default class LabelLine extends Label {\n\n    constructor (size, lines, options) {\n        super(size, options);\n\n        this.lines = lines;\n\n        // optionally limit the line segments that the label may be placed in, by specifying a segment index range\n        // used as a coarse subdivide for placing multiple labels per line geometry\n        this.segment_index = options.segment_start || 0;\n        this.segment_max = options.segment_end || this.lines.length;\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.updateBBoxes();\n    }\n\n    moveNextSegment () {\n        if (this.segment_index + 1 >= this.segment_max - 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 () {\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[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    updateBBoxes () {\n        let upp = this.options.units_per_pixel;\n        let width = (this.size[0] + this.options.buffer[0] * 2) * upp * Label.epsilon;\n        let height = (this.size[1] + this.options.buffer[1] * 2) * upp * Label.epsilon;\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        this.obb = new OBB(p[0], p[1], -this.angle, width, height);\n        this.aabb = this.obb.getExtent();\n    }\n\n    // Try to move the label into the tile bounds\n    // Returns true if label was moved into tile, false if it couldn't be moved\n    moveIntoTile () {\n        let in_tile = false;\n        let fits_to_segment = this.fitToSegment();\n\n        // Try line segments until we find one that fits the label (and is inside the tile)\n        while (!in_tile || !fits_to_segment) {\n            if (!this.moveNextSegment()) {\n                break; // we can't move further in this line\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 (bboxes) {\n        // First find a line segment that fits the label\n        if (this.lines && !this.fitToSegment()) {\n            while (!this.fitToSegment()) {\n                if (!this.moveNextSegment()) {\n                    return true;\n                }\n            }\n        }\n\n        // If label fits in line, run standard discard tests\n        return super.discard(bboxes);\n    }\n\n}\n","import Label from './label';\nimport Geo from '../geo';\nimport OBB from '../utils/obb';\nimport PointAnchor from '../styles/points/point_anchor';\n\nexport default class LabelPoint extends Label {\n\n    constructor (position, size, options) {\n        super(size, options);\n        this.position = [position[0], position[1]];\n        this.update();\n    }\n\n    update() {\n        this.options.offset = this.computeOffset();\n        this.updateBBoxes();\n    }\n\n    computeOffset () {\n        return PointAnchor.computeOffset(this.options.offset, this.size, this.options.anchor);\n    }\n\n    updateBBoxes () {\n        let width = (this.size[0] + this.options.buffer[0] * 2) * this.options.units_per_pixel * Label.epsilon;\n        let height = (this.size[1] + this.options.buffer[1] * 2) * this.options.units_per_pixel * Label.epsilon;\n\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        this.obb = new OBB(p[0], p[1], 0, width, height);\n        this.aabb = this.obb.getExtent();\n    }\n\n    // Try to move the label into the tile bounds\n    // Returns true if label was moved into tile, false if it couldn't be moved\n    moveIntoTile () {\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.updateBBoxes();\n        }\n\n        return this.inTileBounds();\n    }\n\n}\n","import Geo from '../geo';\n\nexport default class RepeatGroup {\n\n    constructor (key, repeat_dist, max_repeat_dist) {\n        this.key = key;\n        this.repeat_dist = repeat_dist;\n        this.repeat_dist_sq = this.repeat_dist * this.repeat_dist;\n        this.max_repeat_dist_sq = max_repeat_dist * max_repeat_dist;\n        this.one_per_group = (this.repeat_dist_sq >= this.max_repeat_dist_sq) ? true : false;\n        this.positions = [];\n    }\n\n    // Check an object to see if it's a repeat in this group\n    check (obj) {\n        // If only one object allowed per group, shortcut distance logic\n        if (this.one_per_group) {\n            if (this.positions.length > 0) {\n                // reported distance maxes out at threshold in this case\n                // (not true dist value since we skipped calculating it)\n                return {\n                    dist_sq: this.max_repeat_dist_sq,\n                    repeat_dist_sq: this.repeat_dist_sq,\n                    one_per_group: this.one_per_group\n                };\n            }\n            return; // no object for this group yet\n        }\n\n        // Check distance from new object to objects already in group\n        let p1 = obj.position;\n        for (let i=0; i < this.positions.length; i++) {\n            let p2 = this.positions[i];\n            let dx = p1[0] - p2[0];\n            let dy = p1[1] - p2[1];\n            let dist_sq = dx * dx + dy * dy;\n\n            // Found an existing object within allowed distance\n            if (dist_sq < this.repeat_dist_sq) {\n                return {\n                    dist_sq,\n                    repeat_dist_sq: this.repeat_dist_sq\n                };\n            }\n        }\n    }\n\n    // Add object to this group\n    add (obj) {\n        // only store object's position, to save space / prevent unnecessary references\n        if (obj && obj.position) {\n            this.positions.push(obj.position);\n        }\n    }\n\n    // Static methods are used to manage repeat groups, within and across tiles\n\n    // Reset all groups for this tile\n    static clear (tile) {\n        this.groups[tile] = {};\n    }\n\n    // Check an object to see if it's a repeat within its designated group\n    static check (obj, layout, tile) {\n        if (layout.repeat_distance && this.groups[tile][layout.repeat_group]) {\n            return this.groups[tile][layout.repeat_group].check(obj);\n        }\n    }\n\n    // Add an object to its designated group\n    static add (obj, layout, tile) {\n        if (layout.repeat_distance) {\n            if (this.groups[tile][layout.repeat_group] == null) {\n                this.groups[tile][layout.repeat_group] = new RepeatGroup(\n                    layout.repeat_group,\n                    layout.repeat_distance,\n                    RepeatGroup.max_repeat_dist\n                );\n            }\n            this.groups[tile][layout.repeat_group].add(obj);\n        }\n    }\n\n}\n\n// Current set of repeat groups, grouped and keyed by tile\nRepeatGroup.groups = {};\n\n// Max repeat dist: for groups with a repeat dist beyond this threshold, only one label\n// will be allowed per group, e.g. set to tile size for one-label-per-tile\nRepeatGroup.max_repeat_dist = Geo.tile_scale;\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 extendLeaflet(options);\n}\n\nfunction extendLeaflet(options) {\n\n    // If LeafletLayer is already defined when this is called just return that immediately\n    // e.g. if you call leafletLayer multiple times (which is valid)\n    if (typeof LeafletLayer !== 'undefined') {\n        return new LeafletLayer(options);\n    }\n\n    // Leaflet layer functionality is only defined in main thread\n    if (Utils.isMainThread) {\n\n        let L = options.leaflet || window.L;\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                options.wheelDebounceTime = options.wheelDebounceTime || 40;\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                this.debounceViewReset = Utils.debounce(() => {\n                    this._map.fire('zoomend');\n                    this._map.fire('moveend');\n                }, this.options.wheelDebounceTime);\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                    this.updateSize();\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.default_view_max_zoom);\n\n                    this.scene.view.setView(view);\n                    this.scene.immediateRedraw();\n                    this.reverseTransform();\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.view.startZoom();\n                    this._updating_tangram = false;\n                };\n                map.on('zoomstart', this.hooks.zoomstart);\n\n                this.hooks.dragstart = () => {\n                    this.scene.view.panning = true;\n                };\n                map.on('dragstart', this.hooks.dragstart);\n\n                this.hooks.dragend = () => {\n                    this.scene.view.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                // Setup feature selection\n                this.setupSelectionEventHandlers(map);\n                this.setSelectionEvents(this.options.events);\n\n                // Add GL canvas to layer container\n                this.scene.container = this.getContainer();\n\n                // Initial view\n                this.updateView();\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._updating_tangram = true;\n\n                    this.updateSize();\n                    this.updateView();\n                    this.reverseTransform();\n\n                    this._updating_tangram = false;\n\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                map.off('click', this.hooks.click);\n                map.off('mousemove', this.hooks.mousemove);\n                map.off('mouseout', this.hooks.mouseout);\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.view.continuous_zoom && map.scrollWheelZoom && this.options.modifyScrollWheel !== false) {\n                    let layer = this;\n                    let enabled = map.scrollWheelZoom.enabled();\n                    if (enabled) {\n                        map.scrollWheelZoom.disable(); // disable before modifying\n                    }\n\n                    // modify prototype and current instance, so add/remove hooks work on existing references\n                    L.Map.ScrollWheelZoom._onWheelScroll = map.scrollWheelZoom._onWheelScroll = function(e) {\n                        // modify to skip debounce, as it seems to cause animation-sync issues in Chrome\n                        // with Tangram continuous rendering\n                        this._delta += L.DomEvent.getWheelDelta(e);\n                        this._lastMousePos = this._map.mouseEventToContainerPoint(e);\n                        this._performZoom();\n                        L.DomEvent.stop(e);\n                    };\n\n                    L.Map.ScrollWheelZoom._performZoom = 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\n                        layer.debounceViewReset();\n                    };\n\n                    if (enabled) {\n                        map.scrollWheelZoom.enable(); // re-enable after modifying\n                    }\n                }\n            },\n\n            updateView: function () {\n                var view = this._map.getCenter();\n                view.zoom = Math.min(this._map.getZoom(), this._map.getMaxZoom() || Geo.default_view_max_zoom);\n                this.scene.view.setView(view);\n            },\n\n            updateSize: function () {\n                var size = this._map.getSize();\n                this.scene.resizeMap(size.x, size.y);\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.view.center.lat, this.scene.view.center.lng], this.scene.view.zoom, { animate: false });\n                this.reverseTransform();\n                this._updating_tangram = false;\n            },\n\n            render: function () {\n                if (!this.scene) {\n                    return;\n                }\n                this.scene.update();\n            },\n\n            // Reverse the CSS positioning Leaflet applies to the layer, since Tangram's WebGL canvas\n            // is expected to be 'absolutely' positioned.\n            reverseTransform: function () {\n                if (!this._map || !this.scene || !this.scene.container) {\n                    return;\n                }\n\n                var top_left = this._map.containerPointToLayerPoint([0, 0]);\n                L.DomUtil.setPosition(this.scene.container, top_left);\n            },\n\n            // Tie Leaflet event handlers to Tangram feature selection\n            setupSelectionEventHandlers: function (map) {\n                this._selection_events = {};\n\n                this.hooks.click = (event) => {\n                    if (typeof this._selection_events.click === 'function') {\n                        this.scene.getFeatureAt(event.containerPoint).\n                            then(selection => {\n                                let results = Object.assign({}, selection, { leaflet_event: event });\n                                this._selection_events.click(results);\n                            });\n                    }\n                };\n                map.on('click', this.hooks.click);\n\n                this.hooks.mousemove = (event) => {\n                    if (typeof this._selection_events.hover === 'function') {\n                        this.scene.getFeatureAt(event.containerPoint).\n                            then(selection => {\n                                let results = Object.assign({}, selection, { leaflet_event: event });\n                                this._selection_events.hover(results);\n                            });\n                    }\n                };\n                map.on('mousemove', this.hooks.mousemove);\n\n                this.hooks.mouseout = (event) => {\n                    // When mouse leaves map, send an additional selection event to indicate no feature is selected\n                    if (typeof this._selection_events.hover === 'function') {\n                        this._selection_events.hover({ changed: true, leaflet_event: event });\n                    }\n                };\n                map.on('mouseout', this.hooks.mouseout);\n            },\n\n            // Set user-defined handlers for feature selection events\n            // Currently only one handler can be defined for each event type\n            // Event types are: `click`, `hover` (leaflet `mousemove`)\n            setSelectionEvents: function (events) {\n                this._selection_events = Object.assign(this._selection_events, events);\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        return new LeafletLayer(options);\n    }\n}\n","import 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 (view, config) {\n        this.name = config.name;\n        this.view = view;\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 (view, config) {\n        if (Light.types[config.type]) {\n            return new Light.types[config.type](view, 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};\n            `;\n        let assign = `\n            ${this.name} = u_${this.name};\\n\n        `;\n\n        ShaderProgram.addBlock(Light.block, instance);\n        ShaderProgram.addBlock('setup', assign);\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(view, config) {\n        super(view, 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(view, config) {\n        super(view, 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 (view, config) {\n        super(view, config);\n        this.type = 'point';\n        this.struct_name = 'PointLight';\n\n        this.position = config.position || [0, 0, '100px'];\n        this.position_eye = []; // position in eyespace\n        this.origin = config.origin || 'ground';\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.view.camera.position_meters[0];\n            this.position_eye[1] = y - this.view.camera.position_meters[1];\n\n            this.position_eye[2] = StyleParser.convertUnits(this.position[2],\n                { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.zoom) });\n            this.position_eye[2] = this.position_eye[2] - this.view.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,\n                { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.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.view.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],\n                    { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.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],\n                    { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.zoom) }));\n        }\n    }\n}\nLight.types['point'] = PointLight;\n\n\nclass SpotLight extends PointLight {\n\n    constructor (view, config) {\n        super(view, 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","import 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        style.addShaderBlock('setup', '\\nmaterial = u_material;\\n', '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} from './leaflet_layer';\n\n// The scene worker is only activated when a worker thread is instantiated, but must always be loaded\nimport Scene from './scene';\nimport {SceneWorker} from './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 './sources/raster';\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 Collision from './labels/collision';\nimport FeatureSelection from './selection';\n\nimport yaml from 'js-yaml';\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    Scene,\n    SceneWorker,\n    WorkerBroker,\n    ruleCache,\n    StyleManager,\n    StyleParser,\n    Collision,\n    FeatureSelection\n};\n\n// Window can only be set in main thread\nif (Utils.isMainThread) {\n\n    window.Tangram = module.exports = {\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","import 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 {Style} from './styles/style';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport SceneLoader from './scene_loader';\nimport View from './view';\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 log from 'loglevel';\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';\nimport {RasterStyle} from './styles/raster/raster';\n\n// Add built-in rendering styles\nStyleManager.register(Polygons);\nStyleManager.register(Lines);\nStyleManager.register(Points);\nStyleManager.register(TextStyle);\nStyleManager.register(RasterStyle);\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 = null; // will be a promise that resolves when scene is loaded\n        this.sources = {};\n\n        this.view = new View(this, options);\n        this.tile_manager = TileManager;\n        this.tile_manager.init({ scene: this, view: this.view });\n        this.num_workers = options.numWorkers || 2;\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.render_count = 0;\n        this.last_render_count = 0;\n        this.render_count_changed = false;\n        this.frame = 0;\n        this.queue_screenshot = null;\n        this.selection = null;\n        this.resetTime();\n\n        this.container = options.container;\n\n        this.lights = null;\n        this.background = null;\n\n        // Listen to related objects\n        this.listeners = {\n            view: {\n                move: () => this.trigger('move')\n            }\n        };\n        this.view.subscribe(this.listeners.view);\n\n        this.updating = 0;\n        this.generation = 0; // an id that is incremented each time the scene config is invalidated\n        this.last_complete_generation = 0; // last generation id with a complete view\n        this.setupDebug();\n\n        this.logLevel = options.logLevel || 'warn';\n        log.setLevel(this.logLevel);\n    }\n\n    static create (config, options = {}) {\n        return new Scene(config, options);\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 this.initializing;\n        }\n\n        this.updating++;\n        this.initialized = false;\n\n        // Load scene definition (sources, styles, etc.), then create styles & workers\n        this.initializing = this.loadScene(config_source, config_path)\n            .then(() => this.createWorkers())\n            .then(() => {\n                this.createCanvas();\n                this.resetFeatureSelection();\n\n                if (!this.listeners.texture) {\n                    this.listeners.texture = {\n                        update: () => this.dirty = true,\n                        warning: (data) => this.trigger('warning', Object.assign({ type: 'textures' }, data))\n                    };\n                    Texture.subscribe(this.listeners.texture);\n                }\n\n                // Only retain visible tiles for rebuilding\n                this.tile_manager.pruneToVisibleTiles();\n                return this.updateConfig({ rebuild: true });\n            }).then(() => {\n                this.updating--;\n                this.initializing = null;\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                this.requestRedraw();\n        }).catch(error => {\n            this.initializing = null;\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        return this.initializing;\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        this.view.unsubscribe(this.listeners.view);\n        Texture.unsubscribe(this.listeners.texture);\n        this.listeners = 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.container.style.backgroundColor = 'transparent';\n        this.container.appendChild(this.canvas);\n\n        try {\n            this.gl = Context.getContext(this.canvas, {\n                alpha: true, premultipliedAlpha: true, // TODO: vary w/scene alpha\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, 'self.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        this.next_worker = 0;\n        return Promise.all(queue);\n    }\n\n    // Round robin selection of next worker\n    nextWorker() {\n        var worker = this.workers[this.next_worker];\n        this.next_worker = (this.next_worker + 1) % this.workers.length;\n        return worker;\n    }\n\n    // Scene is ready for rendering\n    ready() {\n        if (!this.view.ready() || Object.keys(this.sources).length === 0) {\n             return false;\n        }\n        return true;\n    }\n\n    // Resize the map when device pixel ratio changes, e.g. when switching between displays\n    updateDevicePixelRatio () {\n        if (Utils.updateDevicePixelRatio()) {\n            WorkerBroker.postMessage(this.workers, 'self.updateDevicePixelRatio', Utils.device_pixel_ratio)\n                .then(() => this.rebuild())\n                .then(() => this.resizeMap(this.view.size.css.width, this.view.size.css.height));\n        }\n    }\n\n    resizeMap(width, height) {\n        this.dirty = true;\n        this.view.setViewportSize(width, height);\n        if (this.gl) {\n            Context.resize(this.gl, width, height, Utils.device_pixel_ratio);\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        // Render on demand\n        var will_render = !(\n            this.dirty === false ||\n            this.initialized === false ||\n            this.updating > 0 ||\n            this.ready() === 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.updateDevicePixelRatio();\n        this.render();\n        this.updateViewComplete(); // fires event when rendered tile set or style changes\n        this.completeScreenshot(); // completes screenshot capture if requested\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        // Update styles, camera, lights\n        this.view.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.view.panning || this.view.zooming) {\n                this.selection.clearPendingRequests();\n                return;\n            }\n\n            this.selection.bind();                  // switch to FBO\n            this.renderPass(\n                'selection_program',                // render w/alternate program\n                { allow_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        this.render_count_changed = false;\n        if (this.render_count !== this.last_render_count) {\n            this.render_count_changed = true;\n\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_blend } = {}) {\n        // optionally force alpha off (e.g. for selection pass)\n        allow_blend = (allow_blend == null) ? true : allow_blend;\n\n        this.clearFrame({ clear_color: true, clear_depth: true });\n\n        // Sort styles by blend order\n        let styles = Object.keys(this.active_styles).\n            map(s => this.styles[s]).\n            sort(Style.blendOrderSort);\n\n        // Render styles\n        let count = 0; // how many primitives were rendered\n        let last_blend;\n        for (let style of styles) {\n            // Only update render state when blend mode changes\n            if (style.blend !== last_blend) {\n                let state = Object.assign({},\n                    Style.render_states[style.blend],       // render state for blend mode\n                    { blend: (allow_blend && style.blend) } // enable/disable blending (e.g. no blend for selection)\n                );\n                this.setRenderState(state);\n            }\n            count += this.renderStyle(style.name, program_key);\n            last_blend = style.blend;\n        }\n\n        return count;\n    }\n\n    renderStyle(style, program_key) {\n        let first_for_style = true;\n        let render_count = 0;\n\n        let program = this.styles[style][program_key];\n        if (!program || !program.compiled) {\n            return 0;\n        }\n\n        // Render tile GL geometries\n        for (let t in this.renderable_tiles) {\n            let tile = this.renderable_tiles[t];\n\n            if (tile.meshes[style] == null) {\n                continue;\n            }\n\n            // Style-specific state\n            // Only setup style if rendering 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('1f', 'u_time', this.animated ? (((+new Date()) - this.start_time) / 1000) : 0);\n                this.view.setupProgram(program);\n                for (let i in this.lights) {\n                    this.lights[i].setupProgram(program);\n                }\n            }\n\n            // Tile-specific state\n            this.view.setupTile(tile, program);\n\n            // Render tile\n            tile.meshes[style].render();\n            render_count += tile.meshes[style].geometry_count;\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, 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 : RenderState.defaults.depth_test;      // default true\n        depth_write = (depth_write === false) ? false : RenderState.defaults.depth_write;   // default true\n        cull_face = (cull_face === false) ? false : RenderState.defaults.culling;           // default true\n        blend = (blend != null) ? blend : RenderState.defaults.blending;                    // default false\n\n        // Reset frame state\n        let gl = this.gl;\n\n        RenderState.depth_test.set({ depth_test: depth_test, depth_func: RenderState.defaults.depth_func });\n        RenderState.depth_write.set({ depth_write: depth_write });\n        RenderState.culling.set({ cull: cull_face, face: RenderState.defaults.culling_face });\n\n        // Blending of alpha channel is modified to account for WebGL alpha behavior, see:\n        // http://webglfundamentals.org/webgl/lessons/webgl-and-alpha.html\n        // http://stackoverflow.com/a/11533416\n        if (blend) {\n            // Opaque: all source, no destination\n            if (blend === 'opaque') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.SRC_ALPHA, dst: gl.ZERO\n                });\n            }\n            // Traditional alpha blending\n            else if (blend === 'overlay' || blend === 'inlay') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n            // Additive blending\n            else if (blend === 'add') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.ONE, dst: gl.ONE,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n            // Multiplicative blending\n            else if (blend === 'multiply') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.ZERO, dst: gl.SRC_COLOR,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n        }\n        else {\n            RenderState.blending.set({ blend: false });\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.view.size.device.width,\n            y: pixel.y * Utils.device_pixel_ratio / this.view.size.device.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            then(selection => Object.assign(selection, { pixel })).\n            catch(error => Promise.resolve({ error }));\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(options) {\n        return this.rebuildGeometry(options);\n    }\n\n    // Rebuild all tiles\n    // sync: boolean of whether to sync the config object to the worker\n    // sources: optional array of data sources to selectively rebuild (by default all our rebuilt)\n    rebuildGeometry({ sync = true, sources = null } = {}) {\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            if (sync) {\n                this.syncConfigToWorker();\n                StyleManager.compile(this.updateActiveStyles(), this); // only recompile newly active styles\n            }\n            this.resetFeatureSelection();\n            this.resetTime();\n\n            // Rebuild visible tiles\n            this.tile_manager.pruneToVisibleTiles();\n            this.tile_manager.forEachTile(tile => {\n                if (!sources || sources.indexOf(tile.source.name) > -1) {\n                    this.tile_manager.buildTile(tile);\n                }\n            });\n            this.tile_manager.updateTilesForView(); // picks up additional tiles for any new/changed data sources\n            this.tile_manager.checkBuildQueue();    // resolve immediately if no tiles to 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    // TODO move to tile manager\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 = Utils.pathForURL(config_path || this.config_source);\n        }\n        else {\n            this.config_path = Utils.pathForURL(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    // Add source to a scene, arguments `name` and `config` need to be provided:\n    //  - If the name doesn't match a sources it will create it\n    //  - the `config` obj follow the YAML scene spec, ex: ```{type: 'TopoJSON', url: \"//vector.mapzen.com/osm/all/{z}/{x}/{y}.topojson\"]}```\n    //    that looks like:\n    //\n    //      scene.setDataSource(\"osm\", {type: 'TopoJSON', url: \"//vector.mapzen.com/osm/all/{z}/{x}/{y}.topojson\" });\n    //\n    //  - also can be pass a ```data``` obj: ```{type: 'GeoJSON', data: JSObj ]}```\n    //\n    //      var geojson_data = {};\n    //      ...\n    //      scene.setDataSource(\"dynamic_data\", {type: 'GeoJSON', data: geojson_data });\n    //\n    setDataSource (name, config) {\n        if (!name || !config || !config.type || (!config.url && !config.data)) {\n            log.error(\"No name provided or not a valid config:\", name, config);\n            return;\n        }\n\n        let load = (this.config.sources[name] == null);\n        let source = this.config.sources[name] = Object.assign({}, config);\n\n        if (source.data && typeof source.data === 'object') {\n            source.url = Utils.createObjectURL(new Blob([JSON.stringify(source.data)]));\n            delete source.data;\n        }\n\n        if (load) {\n            return this.updateConfig({ rebuild: { sources: [name] } });\n        } else {\n            return this.rebuild({ sources: [name] });\n        }\n    }\n\n    createDataSources() {\n        let reset = []; // sources to reset\n        let prev_source_names = Object.keys(this.sources);\n\n        for (var name in this.config.sources) {\n            let source = this.config.sources[name];\n            let prev_source = this.sources[name];\n\n            try {\n                this.sources[name] = DataSource.create(Object.assign({}, source, {name}), this.sources);\n                if (!this.sources[name]) {\n                    throw {};\n                }\n            }\n            catch(e) {\n                delete this.sources[name];\n                let message = `Could not create data source: ${e.message}`;\n                log.warn(`Scene: ${message}`, source);\n                this.trigger('warning', { type: 'sources', source, message });\n            }\n\n            // Data source changed?\n            if (DataSource.changed(this.sources[name], prev_source)) {\n                reset.push(name);\n            }\n        }\n\n        // Sources that were removed\n        for (let s of prev_source_names) {\n            if (!this.config.sources[s]) {\n                delete this.sources[s]; // TODO: remove from workers too?\n                reset.push(s);\n            }\n        }\n\n        // Remove tiles from sources that have changed\n        if (reset.length > 0) {\n            this.tile_manager.removeTiles(tile => {\n                return (reset.indexOf(tile.source.name) > -1);\n            });\n        }\n\n        // Mark sources that generate geometry tiles\n        // (all except those that are only raster sources attached to other sources)\n        for (let layer of Utils.values(this.config.layers)) {\n            if (layer.data && this.sources[layer.data.source]) {\n                this.sources[layer.data.source].geometry_tiles = true;\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        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 && rule.draw) {\n                for (let [name, group] of Utils.entries(rule.draw)) {\n                    // TODO: warn on non-object draw group\n                    if (group != null && 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    // Get active camera - for public API\n    getActiveCamera() {\n        return this.view.getActiveCamera();\n    }\n\n    // Set active camera - for public API\n    setActiveCamera(name) {\n        return this.view.setActiveCamera(name);\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.view, 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, 0]; // default background TODO: vary w/scene alpha\n        }\n\n        // if background is fully opaque, set canvas background to match\n        if (this.background.color[3] === 1) {\n            this.canvas.style.backgroundColor =\n                `rgba(${this.background.color.map(c => Math.floor(c * 255)).join(', ')})`;\n        }\n        else {\n            this.canvas.style.backgroundColor = 'transparent';\n        }\n    }\n\n    // Update scene config, and optionally rebuild geometry\n    // rebuild can be boolean, or an object containing rebuild options to passthrough\n    updateConfig({ rebuild } = {}) {\n        this.generation++;\n        this.updating++;\n        this.config.scene = this.config.scene || {};\n\n        StyleManager.init();\n        this.view.reset();\n        this.createLights();\n        this.createDataSources();\n        this.loadTextures();\n        this.setBackground();\n\n        // TODO: detect changes to styles? already (currently) need to recompile anyway when camera or lights change\n        this.updateStyles();\n\n        // Optionally rebuild geometry\n        let done = rebuild ?\n            this.rebuildGeometry(typeof rebuild === 'object' && rebuild) :\n            this.syncConfigToWorker(); // rebuildGeometry() also syncs config\n\n        // Finish by updating bounds and re-rendering\n        return done.then(() => {\n            this.updating--;\n            this.view.updateBounds();\n            this.requestRedraw();\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        return WorkerBroker.postMessage(this.workers, 'self.updateConfig', {\n            config: this.config_serialized,\n            generation: this.generation\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            WorkerBroker.postMessage(this.workers, 'self.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 WorkerBroker.postMessage(this.workers, 'self.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    // Fires event when rendered tile set or style changes\n    updateViewComplete () {\n        if ((this.render_count_changed || this.generation !== this.last_complete_generation) &&\n            !this.tile_manager.isLoadingVisibleTiles()) {\n            this.last_complete_generation = this.generation;\n            this.trigger('view_complete');\n        }\n    }\n\n    resetViewComplete () {\n        this.last_complete_generation = null;\n    }\n\n    // Take a screenshot\n    // Asynchronous because we have to wait for next render to capture buffer\n    // Returns a promise\n    screenshot () {\n        if (this.queue_screenshot != null) {\n            return this.queue_screenshot.promise; // only capture one screenshot at a time\n        }\n\n        this.requestRedraw();\n\n        // Will resolve once rendering is complete and render buffer is captured\n        this.queue_screenshot = {};\n        this.queue_screenshot.promise = new Promise((resolve, reject) => {\n            this.queue_screenshot.resolve = resolve;\n            this.queue_screenshot.reject = reject;\n        });\n        return this.queue_screenshot.promise;\n    }\n\n    // Called after rendering, captures render buffer and resolves promise with image data\n    completeScreenshot () {\n        if (this.queue_screenshot != null) {\n            // Get data URL, convert to blob\n            // Strip host/mimetype/etc., convert base64 to binary without UTF-8 mangling\n            // Adapted from: https://gist.github.com/unconed/4370822\n            var url = this.canvas.toDataURL('image/png');\n            var data = atob(url.slice(22));\n            var buffer = new Uint8Array(data.length);\n            for (var i = 0; i < data.length; ++i) {\n                buffer[i] = data.charCodeAt(i);\n            }\n            var blob = new Blob([buffer], { type: 'image/png' });\n\n            // Resolve with screenshot data\n            this.queue_screenshot.resolve({ url, blob });\n            this.queue_screenshot = null;\n        }\n    }\n\n\n    // Stats/debug/profiling methods\n\n    // Log messages pass through from web workers\n    workerLogMessage(event) {\n        let data = typeof event.data === 'string' ? JSON.parse(event.data) : event.data; // optional un-stringify\n        if (data.type !== 'log') {\n            return;\n        }\n\n        var { worker_id, level, msg } = 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        WorkerBroker.postMessage(this.workers, 'self.profile', name);\n    }\n\n    _profileEnd(name) {\n        console.profileEnd(`main thread: ${name}`);\n        WorkerBroker.postMessage(this.workers, 'self.profileEnd', name);\n    }\n\n    // Debug config and functions\n    setupDebug () {\n        let scene = this;\n        this.debug = {\n            profile: {\n                geometry_build: false\n            },\n\n            // Rebuild geometry a given # of times and print average, min, max timings\n            timeRebuild (num = 1, options = {}) {\n                let times = [];\n                let cycle = () => {\n                    let start = +new Date();\n                    scene.rebuild(options).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            // Return geometry counts of visible tiles, grouped by style name\n            geometryCountByStyle () {\n                let counts = {};\n                for (let tile of scene.tile_manager.getRenderableTiles()) {\n                    for (let style in tile.meshes) {\n                        counts[style] = counts[style] || 0;\n                        counts[style] += tile.meshes[style].geometry_count;\n                    }\n                }\n                return counts;\n            },\n\n            geometryCountByBaseStyle () {\n                let style_counts = scene.debug.geometryCountByStyle();\n                let counts = {};\n                for (let style in style_counts) {\n                    let base = scene.styles[style].built_in ? style : scene.styles[style].base;\n                    counts[base] = counts[base] || 0;\n                    counts[base] += style_counts[style];\n                }\n                return counts;\n            }\n        };\n    }\n\n}\n","import Utils from './utils/utils';\nimport GLSL from './gl/glsl';\nimport {StyleParser} from './styles/style_parser';\nimport mergeObjects from './utils/merge';\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 'import' scenes\n    // Optional *initial* path only (won't be passed to recursive 'import' 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            // accept single-string or array\n            if (typeof config.import === 'string') {\n                config.import = [config.import];\n            }\n\n            if (!Array.isArray(config.import)) {\n                SceneLoader.normalize(config, path);\n                return config;\n            }\n\n            // Collect URLs of scenes to import\n            let imports = [];\n            for (let url of config.import) {\n                imports.push(Utils.addBaseURL(url, path));\n            }\n            delete config.import; // don't want to merge this property\n\n            return Promise.\n                all(imports.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    // 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        // Move \"locally defined\" textures, e.g. those specified as strings or blocks,\n        // to the scene's top-level set of textures (config.textures). There are 3 such types of textures:\n        // - in a style's `texture` property (texture can be specified as string or object)\n        // - in a style's `material` properties (texture can be specified as string or object)\n        // - in a style's custom uniforms (`shaders.uniforms`) (texture can be specified as string only)\n        //\n        // For textures specified as strings, we first check to see if there is a texture already defined\n        // with that string name. If there IS, then no changes are made. If there is NOT, then the texture string\n        // is assumed to be a URL. A top-level `config.textures` object is created for the texture (with a private,\n        // synthetic texture name); the texture's URL will be expanded to include the current scene file's path below.\n        if (config.styles) {\n            for (let [style_name, style] of Utils.entries(config.styles)) {\n                // Style `texture`\n                if (style.texture) {\n                    let tex = style.texture;\n\n                    // Texture by URL (string-named texture not referencing existing texture definition)\n                    if (typeof tex === 'string' && !config.textures[tex]) {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = { url: tex };\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                    // Texture by object\n                    else if (typeof tex === 'object') {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = tex;\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                }\n\n                // Material\n                if (style.material) {\n                    for (let prop of ['emission', 'ambient', 'diffuse', 'specular', 'normal']) {\n                        // Material property has a texture\n                        if (style.material[prop] != null && style.material[prop].texture) {\n                            let tex = style.material[prop].texture;\n\n                            // Texture by URL (string-named texture not referencing existing texture definition)\n                            if (typeof tex === 'string' &&\n                                !config.textures[tex]) {\n                                let texture_name = '__' + style_name + '_material_' + prop;\n                                config.textures[texture_name] = { url: tex };\n                                style.material[prop].texture = texture_name; // point style to location of texture\n                            }\n                            // Texture by object\n                            else if (typeof tex === 'object') {\n                                let texture_name = '__' + style_name + '_material_' + prop;\n                                config.textures[texture_name] = tex;\n                                style.material[prop].texture = texture_name; // point style to location of texture\n                            }\n                        }\n                    }\n                }\n\n                // Shader uniforms\n                if (style.shaders && style.shaders.uniforms) {\n                    for (let {type, value, key, uniforms} of GLSL.parseUniforms(style.shaders.uniforms)) {\n                        // Texture by URL (string-named texture not referencing existing texture definition)\n                        if (type === 'sampler2D' && typeof value === 'string' && !config.textures[value]) {\n                            let texture_name = '__' + style_name + '_uniform_' + key;\n                            config.textures[texture_name] = { url: value };\n                            uniforms[key] = texture_name; // point style to location of texture\n                        }\n                    }\n\n                }\n            }\n        }\n\n        // Add current scene file base path to textures\n        // Only adds path for textures with relative URLs, so textures in imported scenes get the base\n        // path of their immediate scene file\n        if (config.textures) {\n            for (let texture of Utils.values(config.textures)) {\n                if (texture.url) {\n                    texture.url = Utils.addBaseURL(texture.url, path);\n                }\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        // Replace global scene properties\n        config = StyleParser.applyGlobalProperties(config);\n\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        config.layers = config.layers || {};\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 mergeObjects from './utils/merge';\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\nif (Utils.isWorkerThread) {\n\nObject.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: {},     // raw config (e.g. functions, etc. not expanded)\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        config = JSON.parse(config);\n\n        self.last_config = mergeObjects({}, self.config);\n        self.config = mergeObjects({}, config);\n        self.generation = generation;\n\n        // Data block functions are not context wrapped like the rest of the style functions are\n        // TODO: probably want a cleaner way to exclude these\n        for (let layer in config.layers) {\n            if (config.layers[layer]) {\n                config.layers[layer].data = Utils.stringsToFunctions(config.layers[layer].data);\n            }\n        }\n\n        // Expand global properties\n        self.global = Utils.stringsToFunctions(config.global);\n\n        // Create data sources\n        config.sources = Utils.stringsToFunctions(config.sources); // parse new sources\n        self.sources.tiles = {}; // clear previous sources\n        for (let name in config.sources) {\n            let source;\n            try {\n                source = DataSource.create(Object.assign({}, config.sources[name], {name}), self.sources.tiles);\n            }\n            catch(e) {\n                continue;\n            }\n\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        // Clear tile cache if data source config changed\n        if (!self.config.sources ||\n            !self.last_config.sources ||\n            Object.keys(self.config.sources).some(s => {\n                return JSON.stringify(self.config.sources[s]) !== JSON.stringify(self.last_config.sources[s]);\n            })) {\n            self.tiles = {};\n        }\n\n        // Expand styles\n        config.styles = Utils.stringsToFunctions(config.styles, StyleParser.wrapFunction);\n        self.styles = StyleManager.build(config.styles, { generation: self.generation, sources: self.sources.tiles });\n\n        // Parse each top-level layer as a separate rule tree\n        self.layers = Utils.stringsToFunctions(config.layers, StyleParser.wrapFunction);\n        self.rules = parseRules(self.layers);\n\n        // Sync tetxure info from main thread\n        self.syncing_textures = self.syncTextures(config.textures);\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.getTile(tile.key) != null) {\n            // Already loading?\n            if (self.getTile(tile.key).loading === true) {\n                return;\n            }\n        }\n\n        // Update tile cache\n        tile = self.tiles[tile.key] = Object.assign(self.getTile(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                        if (!self.getTile(tile.key)) {\n                            Utils.log('trace', `stop tile build after data source load because tile was removed: ${tile.key}`);\n                            return;\n                        }\n\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).then(keys => {\n                            resolve(WorkerBroker.returnWithTransferables({ 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}: ${tile.error} at: ${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).then(keys => {\n                    return WorkerBroker.returnWithTransferables({ tile: Tile.slice(tile, keys) });\n                });\n            }\n        });\n    },\n\n    // Load this tile's data source\n    loadTileSourceData (tile) {\n        if (self.sources.tiles[tile.source]) {\n            return self.sources.tiles[tile.source].load(tile);\n        }\n        else {\n            tile.source_data = { error: `Data source '${tile.source}' not found` };\n            return Promise.resolve(tile);\n        }\n    },\n\n    getTile(key) {\n        return self.tiles[key];\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, e.g. width/height, which we only know after the texture loads\n    syncTextures (tex_config) {\n        let textures = [];\n        if (tex_config) {\n            textures.push(...Object.keys(tex_config));\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    // Sync device pixel ratio from main thread\n    updateDevicePixelRatio (device_pixel_ratio) {\n        Utils.device_pixel_ratio = device_pixel_ratio;\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\nWorkerBroker.addTarget('self', self);\n\n}\n","import Texture from './gl/texture';\nimport WorkerBroker from './utils/worker_broker';\n\nimport log from 'loglevel';\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 = Texture.create( this.gl, 'selection_fbo', { filtering: 'nearest' });\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                reject\n            };\n        });\n    }\n\n    // Any pending selection requests\n    pendingRequests() {\n        return this.requests;\n    }\n\n    clearPendingRequests() {\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            // Reject request since it will never be fulfilled\n            // TODO: pass a reason for rejection?\n            request.reject({ request });\n            delete this.requests[r];\n        }\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                            'self.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            log.error(\"FeatureSelection.finishRead(): could not find message\", message);\n            return; // request was cleared before it returned\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 &&\n                JSON.stringify(feature) !== JSON.stringify(this.feature))) {\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        // Initialize tile-specific tracking info\n        if (!this.tiles[tile.key]) {\n            this.tiles[tile.key] = {\n                entries: [],                        // set of feature entries in this thread\n                tile: {                             // subset of tile properties to pass back with feature\n                    key: tile.key,\n                    coords: tile.coords,\n                    style_zoom: tile.style_zoom,\n                    source: tile.source,\n                    generation: tile.generation\n                }\n            };\n        }\n\n        this.tiles[tile.key].entries.push(key);\n\n        return this.map[key];\n    }\n\n    static makeColor(feature, tile, context) {\n        var selector = this.makeEntry(tile);\n        selector.feature = {\n            id: feature.id,\n            properties: feature.properties,\n            layers: context.layers,\n            tile: this.tiles[tile.key].tile\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 (this.tiles[key]) {\n            this.tiles[key].entries.forEach(k => delete this.map[k]);\n            this.map_size -= this.tiles[key].entries.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 (config, sources) {\n        this.config = config; // save original config\n        this.sources = sources; // full set of data sources TODO: centralize these like textures?\n        this.id = config.id;\n        this.name = config.name;\n        this.pad_scale = config.pad_scale || 0.0001; // scale tile up by small factor to cover seams\n        this.default_winding = null; // winding order will adapt to data source\n        this.rasters = // attached raster tile sources\n            Array.isArray(config.rasters) ? [...new Set(config.rasters)] : []; // de-dupe with set conversion\n\n        // Optional function to transform source data\n        this.transform = config.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 = config.extra_data;\n\n        // Optional additional scripts made available to the transform function\n        if (typeof importScripts === 'function' && config.scripts) {\n            config.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 = config.max_zoom || Geo.default_source_max_zoom;\n    }\n\n    // Create a tile source by type, factory-style\n    static create (source, sources) {\n        if (DataSource.types[source.type]) {\n            return new DataSource.types[source.type](source, sources);\n        }\n    }\n\n    // Check if a data source definition changed\n    static changed (source, prev_source) {\n        if (!source || !prev_source) {\n            return true;\n        }\n\n        let cur = Object.assign({}, source.config, { id: null }); // null out ids since we don't want to compare them\n        let prev = Object.assign({}, prev_source.config, { id: null });\n\n        return JSON.stringify(cur) !== JSON.stringify(prev);\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        let units_per_meter = Geo.unitsPerMeter(z);\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) * units_per_meter;\n                    coord[1] = (coord[1] - min.y) * units_per_meter * -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        dest.rasters = [...this.rasters]; // copy list of rasters to load for tile\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                        // Use first encountered polygon winding order as default for data source\n                        this.updateDefaultWinding(feature.geometry);\n                    });\n                }\n            }\n\n            dest.default_winding = this.default_winding || 'CCW';\n            return dest;\n        });\n    }\n\n    // Sub-classes must implement\n    _load(dest) {\n        throw new MethodNotImplemented('_load');\n    }\n\n    // Infer winding for data source from first ring of provided geometry\n    updateDefaultWinding (geom) {\n        if (this.default_winding == null) {\n            if (geom.type === 'Polygon') {\n                this.default_winding = Geo.ringWinding(geom.coordinates[0]);\n            }\n            else if (geom.type === 'MultiPolygon') {\n                this.default_winding = Geo.ringWinding(geom.coordinates[0][0]);\n            }\n        }\n        return this.default_winding;\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.url = Utils.addParamsToURL(source.url, source.url_params);\n        this.response_type = \"\"; // use to set explicit XHR type\n\n        if (this.url == null) {\n            throw Error('Network data source must provide a `url` property');\n        }\n    }\n\n    _load (dest) {\n        let url = this.formatUrl(this.url, 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 (url_template, 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(url_template, tile) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n        let url = url_template.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 {MVTSource} from './mvt';\nimport Geo from '../geo';\n\n// For tiling GeoJSON client-side\nimport geojsonvt from 'geojson-vt';\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    }\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                // GeoJSON feature\n                let f = {\n                    type: 'Feature',\n                    geometry: {},\n                    properties: feature.tags\n                };\n\n                if (feature.type === 1) {\n                    f.geometry.coordinates = feature.geometry.map(coord => [coord[0], coord[1]]);\n                    f.geometry.type = 'MultiPoint';\n                }\n                else if (feature.type === 2 || feature.type === 3) {\n                    f.geometry.coordinates = feature.geometry.map(ring =>\n                        ring.map(coord => [coord[0], coord[1]])\n                    );\n\n                    if (feature.type === 2) {\n                        f.geometry.type = 'MultiLineString';\n                    }\n                    else  {\n                        f.geometry = MVTSource.decodeMultiPolygon(f.geometry); // un-flatten rings\n                    }\n                }\n                else {\n                    continue;\n                }\n\n                collection.features.push(f);\n            }\n        }\n\n        return collection;\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\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, this.extra_data);\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\nDataSource.register(GeoJSONTileSource, 'GeoJSON');      // prefered shorter name\nDataSource.register(GeoJSONTileSource, 'GeoJSONTiles'); // for backwards-compatibility\n","import DataSource, {NetworkTileSource} from './data_source';\nimport Geo from '../geo';\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 = MVTSource.decodeMultiPolygon(geometry); // un-flatten rings\n                }\n\n                layer_geojson.features.push(feature_geojson);\n            }\n            layers[l] = layer_geojson;\n        }\n        return layers;\n    }\n\n    // Decode multipolygons, which are encoded as a single set of rings\n    // Winding order of first ring is assumed to indicate exterior ring,\n    // the opposite winding order indicates the start of a new polygon.\n    static decodeMultiPolygon (geom) {\n        let polys = [];\n        let poly = [];\n        let outer_winding;\n        for (let ring of geom.coordinates) {\n            let winding = Geo.ringWinding(ring);\n            if (winding == null) {\n                continue; // skip zero-area rings\n            }\n\n            outer_winding = outer_winding || winding; // assume first ring indicates outer ring winding\n\n            if (winding === outer_winding && 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\n        // Single or multi?\n        if (polys.length === 1) {\n            geom.type = 'Polygon';\n            geom.coordinates = polys[0];\n        }\n        else {\n            geom.type = 'MultiPolygon';\n            geom.coordinates = polys;\n        }\n\n        return geom;\n    }\n\n}\n\nDataSource.register(MVTSource, 'MVT');\n","import DataSource, {NetworkTileSource} from './data_source';\nimport Tile from '../tile';\nimport Geo from '../geo';\n\nexport class RasterTileSource extends NetworkTileSource {\n\n    constructor(source) {\n        super(source);\n\n        if (this.rasters.indexOf(this.name) === -1) {\n            this.rasters.unshift(this.name); // add this raster as the first\n        }\n        this.filtering = source.filtering; // optional texture filtering (nearest, linear, mipmap)\n\n        // save texture objects by tile key, so URL remains stable if tile is built multiple times,\n        // e.g. avoid re-loading the same tile texture under a different subdomain when using tile hosts\n        this.textures = {};\n    }\n\n    load(tile) {\n        tile.source_data = {};\n        tile.source_data.layers = {};\n        tile.pad_scale = this.pad_scale;\n        tile.rasters = [...this.rasters]; // copy list of rasters to load for tile\n\n        // Generate a single quad that fills the entire tile\n        let scale = Geo.tile_scale;\n        tile.source_data.layers = {\n            _default: {\n                type: 'FeatureCollection',\n                features: [{\n                    geometry: {\n                        type: 'Polygon',\n                        coordinates: [[\n                            [0, 0], [scale, 0],\n                            [scale, -scale], [0, -scale], [0, 0]\n                        ]]\n                    },\n                    properties: {}\n                }]\n            }\n        };\n\n        tile.default_winding = 'CW';\n        return Promise.resolve(tile);\n    }\n\n    // Return texture info for a raster tile\n    tileTexture (tile) {\n        let key = tile.coords.key;\n        if (!this.textures[key]) {\n            let coords = Tile.coordinateWithMaxZoom(tile.coords, this.max_zoom);\n            let url = this.formatUrl(this.url, { coords });\n            this.textures[key] = { url, filtering: this.filtering, coords };\n        }\n        return this.textures[key];\n    }\n\n}\n\nDataSource.register(RasterTileSource, 'Raster');\n","import DataSource from './data_source';\nimport {GeoJSONSource, GeoJSONTileSource} from './geojson';\n\nimport topojson from 'topojson';\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\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\nDataSource.register(TopoJSONTileSource, 'TopoJSON');        // prefered shorter name\nDataSource.register(TopoJSONTileSource, 'TopoJSONTiles');   // for backwards-compatibility\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 {buildPolylines} from '../../builders/polylines';\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            // Scaling factor to add precision to line texture V coordinate packed as normalized short\n            this.defines.TANGRAM_V_SCALE_ADJUST = Geo.tile_scale;\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        // Additional single-allocated object used for holding outline style as it is processed\n        // Separate from this.feature_style so that outline properties do not overwrite calculated\n        // inline properties (outline call is made *within* the inline call)\n        this.outline_feature_style = {};\n        this.inline_feature_style = this.feature_style; // save reference to main computed style object\n    },\n\n    // Calculate width at zoom given in `context`\n    calcWidth (width, context) {\n        return (width && StyleParser.cacheDistance(width, context)) || 0;\n    },\n\n    // Calculate width at next zoom (used for line width interpolation)\n    calcWidthNextZoom (width, context) {\n        context.zoom++;\n        let val = this.calcWidth(width, context);\n        context.zoom--;\n        return val;\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        // line width in meters\n        let width = this.calcWidth(rule_style.width, context);\n        if (width < 0) {\n            return; // skip lines with negative width\n        }\n        let next_width = this.calcWidthNextZoom(rule_style.next_width, context);\n\n        if ((width === 0 && next_width === 0) || next_width < 0) {\n            return; // skip lines that don't interpolate to a positive value at next zoom\n        }\n\n        // convert to units and relative change from previous zoom\n        // NB: multiply by 2 because a given width is twice as big in screen space at the next zoom\n        style.width = width * context.units_per_meter;\n        style.next_width = (next_width * 2) - width;\n        style.next_width *= context.units_per_meter;\n        style.next_width /= 2; // NB: divide by 2 because extrusion width is halved in builder - remove?\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return;\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 = StyleParser.evalProp(rule_style.extrude, context);\n        if (style.extrude) {\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.miter_limit = rule_style.miter_limit;\n        style.tile_edges = rule_style.tile_edges; // usually activated for debugging, or rare visualization needs\n\n        // Construct an outline style\n        // Reusable outline style object, marked as already wrapped in cache objects (preprocessed = true)\n        style.outline = style.outline || { width: {}, next_width: {}, preprocessed: true };\n\n        if (rule_style.outline && rule_style.outline.color && rule_style.outline.width) {\n            // outline width in meters\n            // NB: multiply by 2 because outline is applied on both sides of line\n            let outline_width = this.calcWidth(rule_style.outline.width, context) * 2;\n            let outline_next_width = this.calcWidthNextZoom(rule_style.outline.next_width, context) * 2;\n\n            if ((outline_width === 0 && outline_next_width === 0) || outline_width < 0 || outline_next_width < 0) {\n                // skip lines that don't interpolate between zero or greater width\n                style.outline.width.value = null;\n                style.outline.next_width.value = null;\n                style.outline.color = null;\n            }\n            else {\n                // Maintain consistent outline width around the line fill\n                style.outline.width.value = outline_width + 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.miter_limit = rule_style.outline.miter_limit || rule_style.miter_limit;\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        }\n        else {\n            style.outline.width.value = null;\n            style.outline.next_width.value = null;\n            style.outline.color = null;\n        }\n\n        return style;\n    },\n\n    _preprocess (draw) {\n        draw.color = StyleParser.colorCacheObject(draw.color);\n        draw.width = StyleParser.cacheObject(draw.width, StyleParser.cacheUnits);\n        draw.next_width = StyleParser.cacheObject(draw.width, StyleParser.cacheUnits); // width will be computed for next zoom\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n\n        if (draw.outline) {\n            draw.outline.color = StyleParser.colorCacheObject(draw.outline.color);\n            draw.outline.width = StyleParser.cacheObject(draw.outline.width, StyleParser.cacheUnits);\n            draw.outline.next_width = StyleParser.cacheObject(draw.outline.width, StyleParser.cacheUnits); // width re-computed for next zoom\n        }\n        return draw;\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++] = this.scaleOrder(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        // Outline (build first so that blended geometry without a depth test is drawn first/under the inner line)\n        this.feature_style = this.outline_feature_style; // swap in outline-specific style holder\n        if (style.outline && style.outline.color != null && style.outline.width.value != null) {\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        // Main line\n        this.feature_style = this.inline_feature_style; // restore calculated style for inline\n        let vertex_template = this.makeVertexTemplate(style);\n        buildPolylines(\n            lines,\n            style.width,\n            vertex_data,\n            vertex_template,\n            {\n                cap: style.cap,\n                join: style.join,\n                miter_limit: style.miter_limit,\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    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","// Sets of values to match for directional and corner anchors\nconst lefts = ['left', 'top-left', 'bottom-left'];\nconst rights = ['right', 'top-right', 'bottom-right'];\nconst tops = ['top', 'top-left', 'top-right'];\nconst bottoms = ['bottom', 'bottom-left', 'bottom-right'];\n\nvar PointAnchor;\n\nexport default PointAnchor = {\n\n    computeOffset (offset, size, anchor) {\n        if (!anchor || anchor === 'center') {\n            return offset;\n        }\n\n        let offset2 = [offset[0], offset[1]];\n\n        // An optional left/right offset\n        if (this.isLeftAnchor(anchor)) {\n            offset2[0] -= size[0] / 2;\n        }\n        else if (this.isRightAnchor(anchor)) {\n            offset2[0] += size[0] / 2;\n        }\n\n        // An optional top/bottom offset\n        if (this.isTopAnchor(anchor)) {\n            offset2[1] -= size[1] / 2;\n        }\n        else if (this.isBottomAnchor(anchor)) {\n            offset2[1] += size[1] / 2;\n        }\n\n        return offset2;\n    },\n\n    isLeftAnchor (anchor) {\n        return (lefts.indexOf(anchor) > -1);\n    },\n\n    isRightAnchor (anchor) {\n        return (rights.indexOf(anchor) > -1);\n    },\n\n    isTopAnchor (anchor) {\n        return (tops.indexOf(anchor) > -1);\n    },\n\n    isBottomAnchor (anchor) {\n        return (bottoms.indexOf(anchor) > -1);\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 {buildQuadsForPoints} from '../../builders/points';\nimport Texture from '../../gl/texture';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\nimport Vector from '../../vector';\nimport Collision from '../../labels/collision';\nimport LabelPoint from '../../labels/label_point';\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        this.queues = {};\n    },\n\n    reset () {\n        this.queues = {};\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, draw, context) {\n        let tile = context.tile;\n\n        // Called here because otherwise it will be delayed until the feature queue is parsed,\n        // and we want the preprocessing done before we evaluate text style below\n        draw = this.preprocess(draw);\n        if (!draw) {\n            return;\n        }\n\n        let style = {};\n        style.color = this.parseColor(draw.color, context);\n\n        // require color or texture\n        if (!style.color && !this.texture) {\n            return null;\n        }\n\n        let sprite = style.sprite = StyleParser.evalProp(draw.sprite, context);\n        style.sprite_default = draw.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        else if (sprite) {\n            log.warn(`Style: in style '${this.name}', sprite '${sprite}' was specified, but texture '${this.texture}' has no sprites`);\n            sprite = null;\n        }\n\n        // Sets texcoord scale if needed (e.g. for sprite sub-area)\n        let sprite_info;\n        if (this.texture && sprite) {\n            sprite_info = Texture.getSpriteInfo(this.texture, sprite);\n            style.texcoords = sprite_info.texcoords;\n        } else {\n            style.texcoords = null;\n        }\n\n        // points can be placed off the ground\n        style.z = (draw.z && StyleParser.cacheDistance(draw.z, context)) || StyleParser.defaults.z;\n\n        // point size defined explicitly, or defaults to sprite size, or generic fallback\n        style.size = draw.size;\n        if (!style.size) {\n            if (sprite_info) {\n                style.size = sprite_info.size;\n            }\n            else {\n                style.size = [16, 16];\n            }\n        }\n        else {\n            style.size = StyleParser.cacheProperty(style.size, context);\n        }\n\n        // size will be scaled to 16-bit signed int, so max allowed width + height of 256 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.angle = StyleParser.evalProp(draw.angle, context) || 0;\n\n        // polygons rendering as points will render at the polygon's centroid by default,\n        // but can be set to render at each individual polygon point instead\n        style.centroid = (draw.centroid != null) ? draw.centroid : true;\n\n        this.computeLayout(style, feature, draw, context, tile);\n\n        // Queue the feature for processing\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile);\n        }\n\n        if (!this.queues[tile.key]) {\n            this.queues[tile.key] = [];\n        }\n\n        this.queues[tile.key].push({\n            feature, draw, context, style\n        });\n\n        // Register with collision manager\n        Collision.addStyle(this.name, tile.key);\n    },\n\n    // Override\n    endData (tile) {\n        if (tile.canceled) {\n            Utils.log('trace', `Style ${this.name}: stop tile build because tile was canceled: ${tile.key}`);\n            return;\n        }\n\n        let queue = this.queues[tile.key];\n        this.queues[tile.key] = [];\n\n        // For each feature, create one or more point labels\n        let boxes = [];\n        queue.forEach(q => {\n            let style = q.style;\n            let feature = q.feature;\n            let geometry = feature.geometry;\n\n            let feature_labels = this.buildLabelsFromGeometry(style.size, geometry, style);\n            for (let i = 0; i < feature_labels.length; i++) {\n                let label = feature_labels[i];\n                boxes.push({\n                    feature,\n                    draw: q.draw,\n                    context: q.context,\n                    style,\n                    layout: style,\n                    label\n                });\n            }\n        });\n\n        // Submit point labels for collision, then build geometry for remaining ones\n        return Collision.collide(boxes, this.name, tile.key).then(boxes => {\n            boxes.forEach(q => {\n                this.feature_style = q.style;\n                this.feature_style.label = q.label;\n\n                Style.addFeature.call(this, q.feature, q.draw, q.context);\n            });\n\n            return Style.endData.call(this, tile);\n        });\n    },\n\n    _preprocess (draw) {\n        draw.color = StyleParser.colorCacheObject(draw.color);\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n\n        // Size (1d value or 2d array)\n        draw.size = StyleParser.cacheObject(draw.size, v => Array.isArray(v) ? v.map(parseFloat) : parseFloat(v));\n\n        // Offset (2d array)\n        draw.offset = StyleParser.cacheObject(draw.offset, v => (Array.isArray(v) && v.map(parseFloat)) || 0);\n\n        // Buffer (1d value or 2d array, expand 1d to 2d)\n        draw.buffer = StyleParser.cacheObject(draw.buffer, v => (Array.isArray(v) ? v : [v, v]).map(parseFloat) || 0);\n\n        return draw;\n    },\n\n    // Compute label layout-related properties\n    computeLayout (target, feature, draw, context, tile) {\n        let layout = target || {};\n        layout.id = feature;\n        layout.units_per_pixel = tile.units_per_pixel || 1;\n\n        // collision flag\n        layout.collide = (draw.collide === false) ? false : true;\n\n        // label anchors (point labels only)\n        // label position will be adjusted in the given direction, relative to its original point\n        // one of: left, right, top, bottom, top-left, top-right, bottom-left, bottom-right\n        layout.anchor = draw.anchor;\n\n        // label offset and buffer in pixel (applied in screen space)\n        layout.offset = StyleParser.cacheProperty(draw.offset, context) || StyleParser.zeroPair;\n        layout.buffer = StyleParser.cacheProperty(draw.buffer, context) || StyleParser.zeroPair;\n\n        // label priority (lower is higher)\n        let priority = draw.priority;\n        if (priority != null) {\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        layout.priority = priority;\n\n        return layout;\n    },\n\n    // Builds one or more point labels for a geometry\n    buildLabelsFromGeometry (size, geometry, options) {\n        let labels = [];\n\n        if (geometry.type === \"Point\") {\n            labels.push(new LabelPoint(geometry.coordinates, size, options));\n        }\n        else if (geometry.type === \"MultiPoint\") {\n            let points = geometry.coordinates;\n            for (let i = 0; i < points.length; ++i) {\n                let point = points[i];\n                labels.push(new LabelPoint(point, size, options));\n            }\n        }\n        else if (geometry.type === \"LineString\") {\n            // Point at each line vertex\n            let points = geometry.coordinates;\n            for (let i = 0; i < points.length; ++i) {\n                labels.push(new LabelPoint(points[i], size, options));\n            }\n        }\n        else if (geometry.type === \"MultiLineString\") {\n            // Point at each line vertex\n            let lines = geometry.coordinates;\n            for (let ln = 0; ln < lines.length; ln++) {\n                let points = lines[ln];\n                for (let i = 0; i < points.length; ++i) {\n                    labels.push(new LabelPoint(points[i], size, options));\n                }\n            }\n        }\n        else if (geometry.type === \"Polygon\") {\n            // Point at polygon centroid (of outer ring)\n            if (options.centroid) {\n                let centroid = Geo.centroid(geometry.coordinates[0]);\n                labels.push(new LabelPoint(centroid, size, options));\n            }\n            // Point at each polygon vertex (all rings)\n            else {\n                let rings = geometry.coordinates;\n                for (let ln = 0; ln < rings.length; ln++) {\n                    let points = rings[ln];\n                    for (let i = 0; i < points.length; ++i) {\n                        labels.push(new LabelPoint(points[i], size, options));\n                    }\n                }\n            }\n        }\n        else if (geometry.type === \"MultiPolygon\") {\n            let centroid = Geo.multiCentroid(geometry.coordinates);\n            labels.push(new LabelPoint(centroid, size, options));\n        }\n\n        return labels;\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', this.scaleOrder(style.order), { 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, offset, texcoord_scale, vertex_data, vertex_template) {\n        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,\n                angle: Utils.scaleInt16(angle, 360),\n                texcoord_scale: texcoord_scale,\n                texcoord_normalize: 65535\n            }\n        );\n    },\n\n    // Build quad for point sprite\n    build (style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let label = style.label;\n\n        this.buildQuad(\n            [label.position],               // position\n            style.size,                     // size in pixels\n            style.angle,                    // angle in degrees\n            label.options.offset,           // offset from center in pixels\n            style.texcoords,                // texture UVs\n            vertex_data, vertex_template    // VBO and data for current vertex\n        );\n    },\n\n    // Override to pass-through to generic point builder\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});\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 {buildPolygons, buildExtrudedPolygons} from '../../builders/polygons';\nimport Geo from '../../geo';\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 = StyleParser.evalProp(rule_style.extrude, context);\n        if (style.extrude) {\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.tile_edges = rule_style.tile_edges; // usually activated for debugging, or rare visualization needs\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 = StyleParser.colorCacheObject(draw.color);\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n        return draw;\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++] = this.scaleOrder(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, context) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let options = {\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            remove_tile_edges: !style.tile_edges,\n            tile_edge_tolerance: Geo.tile_scale * context.tile.pad_scale * 4,\n            winding: context.winding\n        };\n\n        // Extruded polygons (e.g. 3D buildings)\n        if (style.extrude && style.height) {\n            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                options\n            );\n        }\n        // Regular polygons\n        else {\n            buildPolygons(\n                polygons,\n                vertex_data, vertex_template,\n                options\n            );\n        }\n    }\n\n});\n","// Raster tile rendering style\n\nimport {StyleParser} from '../style_parser';\nimport {Polygons} from '../polygons/polygons';\n\nexport let RasterStyle = Object.create(Polygons);\n\nObject.assign(RasterStyle, {\n    name: 'raster',\n    super: Polygons,\n    built_in: true,\n    selection: false, // no feature selection by default\n\n    init() {\n        // Required for raster tiles\n        this.raster = this.raster || 'color';\n\n        this.super.init.apply(this, arguments);\n    },\n\n    _preprocess (draw) {\n        // Raster tiles default to white vertex color, as this color will tint the underlying texture\n        draw.color = draw.color || StyleParser.defaults.color;\n        return this.super._preprocess.apply(this, arguments);\n    }\n\n});\n","import {Styles} from './style_manager';\nimport mergeObjects from '../utils/merge';\nimport {match} from 'match-feature';\nimport log from 'loglevel';\n\nexport const whiteList = ['filter', 'draw', 'visible', 'data'];\n\nexport let ruleCache = {};\n\nfunction cacheKey (rules) {\n    if (rules.length > 1) {\n        var k = rules[0];\n        for (var i=1; i < rules.length; i++) {\n            k += '/' + rules[i];\n        }\n\n        return k;\n    }\n    return rules[0];\n}\n\n// Merge matching layer rule trees into a final draw group\nexport function mergeTrees(matchingTrees, group) {\n    let draws, treeDepth = 0;\n\n    let draw = {\n        visible: true // visible by default\n    };\n\n    // Find deepest tree\n    for (let 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 (let x=0; x < treeDepth; x++) {\n        // Pull out the requested draw group, for each tree, at this depth\n        draws = matchingTrees.map(tree => tree[x] && tree[x][group]);\n        if (draws.length === 0) {\n            continue;\n        }\n\n        // Sort by layer name before merging, so rules are applied deterministically\n        // when multiple rules modify the same properties\n        draws.sort((a, b) => (a && a.layer_name) > (b && b.layer_name) ? 1 : -1);\n\n        // Merge draw objects\n        mergeObjects(draw, ...draws);\n\n        // Remove layer names, they were only used transiently to sort and calculate final layer\n        // (final merged names will not be accurate since only one tree can win)\n        delete draw.layer_name;\n    }\n\n    // Short-circuit if not visible\n    if (draw.visible === false) {\n        return null;\n    }\n\n    return draw;\n}\n\n\nclass Rule {\n\n    constructor({name, parent, draw, visible, filter}) {\n        this.id = Rule.id++;\n        this.parent = parent;\n        this.name = name;\n        this.full_name = this.parent ? (this.parent.full_name + ':' + this.name) : this.name;\n        this.draw = draw;\n        this.filter = filter;\n        this.visible = visible !== undefined ? visible : (this.parent && this.parent.visible);\n\n        // Denormalize layer name to draw groups\n        if (this.draw) {\n            for (let group in this.draw) {\n                this.draw[group] = this.draw[group] || {};\n                this.draw[group].layer_name = this.full_name;\n            }\n        }\n\n        this.buildFilter();\n        this.buildDraw();\n    }\n\n    buildDraw() {\n        this.calculatedDraw = calculateDraw(this);\n    }\n\n    buildFilter() {\n        let type = typeof this.filter;\n        if (this.filter != null && type !== 'object' && type !== 'function') {\n            // Invalid filter\n            let msg = `Filter for layer ${this.full_name} is invalid, filter value must be an object or function, `;\n            msg += `but was set to \\`filter: ${this.filter}\\` instead`;\n            log.warn(msg);\n            return;\n        }\n\n        try {\n            this.buildZooms();\n            this.filter = this.filter && match(this.filter);\n        }\n        catch(e) {\n            // Invalid filter\n            let msg = `Filter for layer ${this.full_name} is invalid, \\`filter: ${JSON.stringify(this.filter)}\\` `;\n            msg += `failed with error ${e.message}, ${e.stack}`;\n            log.warn(msg);\n        }\n    }\n\n    // Zooms often cull large swaths of the layer rule tree, so they get special treatment and are checked first\n    buildZooms() {\n        let zoom = this.filter && this.filter.$zoom;\n        let ztype = typeof zoom;\n        if (zoom != null && ztype !== 'function') { // don't accelerate function-based filters\n            this.zooms = {};\n\n            if (ztype === 'number') {\n                this.zooms[zoom] = true;\n            }\n            else if (Array.isArray(zoom)) {\n                for (let z=0; z < zoom.length; z++) {\n                    this.zooms[zoom[z]] = true;\n                }\n            }\n            else if (ztype === 'object' && (zoom.min != null || zoom.max != null)) {\n                let zmin = zoom.min || 0;\n                let zmax = zoom.max || 25; // TODO: replace constant for max possible zoom\n                for (let z=zmin; z < zmax; z++) {\n                    this.zooms[z] = true;\n                }\n            }\n\n            delete this.filter.$zoom; // don't process zoom through usual generic filter logic\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}) {\n        super({name, parent, draw, visible, filter});\n    }\n\n}\n\nexport class RuleTree extends Rule {\n    constructor({name, parent, draw, visible, rules, filter}) {\n        super({name, parent, draw, visible, filter});\n        this.rules = rules || [];\n    }\n\n    addRule(rule) {\n        this.rules.push(rule);\n    }\n\n    buildDrawGroups(context) {\n        let rules = [], rule_ids = [];\n        //TODO, should this function take a RuleTree\n        matchFeature(context, [this], rules, rule_ids);\n\n        if (rules.length > 0) {\n            let cache_key = cacheKey(rule_ids);\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                // Find all the unique visible draw blocks for this rule tree\n                let draw_rules = rules.map(x => x && x.visible !== false && x.calculatedDraw);\n                let draw_keys = {};\n\n                for (let r=0; r < draw_rules.length; r++) {\n                    let rule = draw_rules[r];\n                    if (!rule) {\n                        continue;\n                    }\n                    for (let g=0; g < rule.length; g++) {\n                        let group = rule[g];\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);\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                        ruleCache[cache_key][draw_key].layers = rules.map(x => x && x.full_name);\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            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 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' && !Array.isArray(property)) {\n                parseRuleTree(key, property, r);\n            } else {\n                // Invalid layer\n                let msg = `Layer value must be an object: can't create layer '${key}: ${JSON.stringify(property)}'`;\n                msg += `, under parent layer '${r.full_name}'.`;\n\n                // If the parent is a style name, this may be an incorrectly nested layer\n                if (Styles[r.name]) {\n                    msg += ` The parent '${r.name}' is also the name of a style, did you mean to create a 'draw' group`;\n                    if (parent) {\n                        msg += ` under '${parent.name}'`;\n                    }\n                    msg += ` instead?`;\n                }\n                log.warn(msg);\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        if (rule) {\n            ruleTrees[key] = parseRuleTree(key, rule);\n        }\n    }\n\n    return ruleTrees;\n}\n\n\nfunction doesMatch(rule, context) {\n    // zoom pre-filter: skip rest of filter if out of rule zoom range\n    if (rule.zooms != null && !rule.zooms[context.zoom]) {\n        return false;\n    }\n\n    return ((typeof rule.filter === 'function' && rule.filter(context)) || (rule.filter == null));\n}\n\nexport function matchFeature(context, rules, collectedRules, collectedRulesIds) {\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\n        if (current instanceof RuleLeaf) {\n\n            if (doesMatch(current, context)) {\n                matched = true;\n                collectedRules.push(current);\n                collectedRulesIds.push(current.id);\n            }\n\n        } else if (current instanceof RuleTree) {\n            if (doesMatch(current, context)) {\n                matched = true;\n\n                childMatched = matchFeature(\n                    context,\n                    current.rules,\n                    collectedRules,\n                    collectedRulesIds\n                );\n\n                if (!childMatched) {\n                    collectedRules.push(current);\n                    collectedRulesIds.push(current.id);\n                }\n            }\n        }\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 Texture from '../gl/texture';\nimport Material from '../material';\nimport Light from '../light';\nimport {RasterTileSource} from '../sources/raster';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\nimport Utils from '../utils/utils';\nimport WorkerBroker from '../utils/worker_broker';\n\nimport log from 'loglevel';\n\n// Base class\n\nexport var Style = {\n    init ({ generation, sources = {} } = {}) {\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.sources = sources;                     // data sources for scene\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\n        // Provide a hook for this object to be called from worker threads\n        this.main_thread_target = 'Style-' + this.name;\n        if (Utils.isMainThread) {\n            WorkerBroker.addTarget(this.main_thread_target, this);\n        }\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        if (this.blend_order == null) { // controls order of rendering for styles w/non-opaque blending\n            this.blend_order = -1; // defaults to first\n        }\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        // Setup raster samplers if needed\n        this.setupRasters();\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.key] = {\n            vertex_data: null,\n            uniforms: {},\n            textures: []\n        };\n        return this.tile_data[tile.key];\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.key];\n        this.tile_data[tile.key] = null;\n\n        if (tile_data && tile_data.vertex_data && tile_data.vertex_data.vertex_count > 0) {\n            // Only keep final byte buffer\n            tile_data.vertex_data.end();\n            tile_data.vertex_data = tile_data.vertex_data.buffer;\n\n            // Load raster tiles passed from data source\n            // Blocks mesh completion to avoid flickering\n            return this.buildRasterTextures(tile, tile_data).then(() => tile_data);\n        }\n        else {\n            return Promise.resolve(null); // don't send tile data back if doesn't have geometry\n        }\n    },\n\n    // Has mesh data for a given tile?\n    hasDataForTile (tile_key) {\n        return this.tile_data[tile_key] != 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);\n        }\n\n        let style = this.parseFeature.apply(this, arguments); // allow subclasses to pass extra args\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            rule_style = this.preprocess(rule_style);\n            if (!rule_style) {\n                return;\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                selectable = StyleParser.evalProp(style.interactive, context);\n            }\n\n            // If feature is marked as selectable\n            if (selectable) {\n                style.selection_color = FeatureSelection.makeColor(feature, context.tile, context);\n            }\n            else {\n                style.selection_color = FeatureSelection.defaultColor;\n            }\n\n            // Subclass implementation\n            style = this._parseFeature.apply(this, arguments); // allow subclasses to pass extra args\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        return this.feature_style;\n    },\n\n    preprocess (rule_style) {\n        // Preprocess first time\n        if (!rule_style.preprocessed) {\n            rule_style = this._preprocess(rule_style); // optional subclass implementation\n            if (!rule_style) {\n                return;\n            }\n            rule_style.preprocessed = true;\n        }\n        return rule_style;\n    },\n\n    // optionally implemented by subclass\n    _preprocess (rule_style) {\n        return rule_style;\n    },\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    // Expand final precision for half-layers (for outlines)\n    scaleOrder (order) {\n        return order * 2;\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        this.max_texture_size = Texture.getMaxTextureSize(this.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 = Object.assign({}, 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    // Determines if 'raster' parameter is set to a valid value\n    hasRasters () {\n        return (['color', 'normal', 'custom'].indexOf(this.raster) > -1);\n    },\n\n    // Setup raster access in shaders\n    setupRasters () {\n        if (!this.hasRasters()) {\n            return;\n        }\n\n        // Enable raster textures and configure how first raster is applied\n        if (this.raster === 'color') {\n            this.defines.TANGRAM_RASTER_TEXTURE_COLOR = true;\n        }\n        else if (this.raster === 'normal') {\n            this.defines.TANGRAM_RASTER_TEXTURE_NORMAL = true;\n        }\n        // else custom raster (samplers will be made available but not automatically applied)\n\n        // A given style may be built with multiple data sources, each of which may attach\n        // a variable number of raster sources (0 to N, where N is the max number of raster sources\n        // defined for the scene). This means we don't know *which* or *how many* rasters will be\n        // bound now, at initial compile-time; we only know this at geometry build-time. To ensure\n        // that we can bind as many raster sources as needed, we declare our uniform arrays to hold\n        // the maximum number of possible sources. At render time, only the necessary number of rasters\n        // are bound (the remaining slots aren't intended to be accessed).\n        let num_raster_sources =\n            Object.keys(this.sources)\n            .filter(s => this.sources[s] instanceof RasterTileSource)\n            .length;\n\n        this.defines.TANGRAM_NUM_RASTER_SOURCES = `int(${num_raster_sources})`;\n        if (num_raster_sources > 0) {\n            // Use model position of tile's coordinate zoom for raster tile texture UVs\n            this.defines.TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING = true;\n\n            // Uniforms and macros for raster samplers\n            this.replaceShaderBlock('raster', shaderSources['gl/shaders/rasters'], 'Raster');\n        }\n    },\n\n    // Load raster tile textures and set uniforms\n    buildRasterTextures (tile, tile_data) {\n        if (!this.hasRasters()) {\n            return Promise.resolve(tile_data);\n        }\n\n        let configs = {}; // texture configs to pass to texture builder, keyed by texture name\n        let index = {};   // index into raster sampler array, keyed by texture name\n\n        // TODO: data source could retrieve raster texture URLs\n        tile.rasters.map(r => this.sources[r]).filter(x => x).forEach((source, i) => {\n            if (source instanceof RasterTileSource) {\n                let config = source.tileTexture(tile);\n                configs[config.url] = config;\n                index[config.url] = i;\n            }\n        });\n\n        if (Object.keys(configs).length === 0) {\n            return Promise.resolve(tile_data);\n        }\n\n        // Load textures on main thread and return when done\n        // We want to block the building of a raster tile mesh until its texture is loaded,\n        // to avoid flickering while loading (texture will render as black)\n        return WorkerBroker.postMessage(this.main_thread_target+'.loadTextures', configs)\n            .then(textures => {\n                if (!textures || textures.length < 1) {\n                    // TODO: warning\n                    return tile_data;\n                }\n\n                // Set texture uniforms (returned after loading from main thread)\n                tile_data.uniforms = tile_data.uniforms || {};\n                tile_data.textures = tile_data.textures || [];\n\n                let u_samplers = tile_data.uniforms['u_rasters'] = [];\n                let u_sizes = tile_data.uniforms['u_raster_sizes'] = [];\n                let u_offsets = tile_data.uniforms['u_raster_offsets'] = [];\n\n                for (let [tname, twidth, theight] of textures) {\n                    let i = index[tname];\n                    let raster_coords = configs[tname].coords; // tile coords of raster tile\n\n                    u_samplers[i] = tname;\n                    tile_data.textures.push(tname);\n\n                    u_sizes[i] = [twidth, theight];\n\n                    // Tile geometry may be at a higher zoom than the raster tile texture,\n                    // (e.g. an overzoomed raster tile), in which case we need to adjust the\n                    // raster texture UVs to offset to the appropriate starting point for\n                    // this geometry tile.\n                    if (tile.coords.z > raster_coords.z) {\n                        let dz = tile.coords.z - raster_coords.z; // # of levels raster source is overzoomed\n                        let dz2 = Math.pow(2, dz);\n                        u_offsets[i] = [\n                            (tile.coords.x % dz2) / dz2,\n                            (dz2 - 1 - (tile.coords.y % dz2)) / dz2, // GL texture coords are +Y up\n                            1 / dz2\n                        ];\n                    }\n                    else {\n                        u_offsets[i] = [0, 0, 1];\n                    }\n                }\n\n                return tile_data;\n            }\n        );\n    },\n\n    // Called on main thread\n    loadTextures (textures) {\n        // NB: only return name and size of textures loaded, because we can't send actual texture objects to worker\n        return Texture.createFromObject(this.gl, textures)\n            .then(() => {\n                return Promise.all(Object.keys(textures).map(t => {\n                    return Texture.textures[t] && Texture.textures[t].load();\n                }).filter(x => x));\n            })\n            .then(textures => {\n                textures.forEach(t => t.retain());\n                return textures.map(t => [t.name, t.width, t.height]);\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    // Render state settings by blend mode\n    render_states: {\n        opaque: { depth_test: true, depth_write: true },\n        add: { depth_test: true, depth_write: false },\n        multiply: { depth_test: true, depth_write: false },\n        inlay: { depth_test: true, depth_write: false },\n        overlay: { depth_test: false, depth_write: false }\n    },\n\n    // Default sort order for blend modes\n    default_blend_orders: {\n        opaque: 0,\n        add: 1,\n        multiply: 2,\n        inlay: 3,\n        overlay: 4\n    },\n\n    // Comparison function for sorting styles by blend\n    blendOrderSort (a, b) {\n        // opaque always comes first\n        if (a.blend === 'opaque' || b.blend === 'opaque') {\n            if (a.blend === 'opaque' && b.blend === 'opaque') { // if both are opaque\n                return a.name < b.name ? -1 : 1; // use name as tie breaker\n            }\n            else if (a.blend === 'opaque') {\n                return -1; // only `a` was opaque\n            }\n            else {\n                return 1; // only `b` was opaque\n            }\n        }\n\n        // use explicit blend order if possible\n        if (a.blend_order < b.blend_order) {\n            return -1;\n        }\n        else if (a.blend_order > b.blend_order) {\n            return 1;\n        }\n\n        // if blend orders are equal, use default order by blend mode\n        if (Style.default_blend_orders[a.blend] < Style.default_blend_orders[b.blend]) {\n            return -1;\n        }\n        else if (Style.default_blend_orders[a.blend] > Style.default_blend_orders[b.blend]) {\n            return 1;\n        }\n\n        return a.name < b.name ? -1 : 1; // use name as tie breaker\n    },\n\n    update () {\n        // Style-specific animation\n        // if (typeof this.animation === 'function') {\n        //     this.animation();\n        // }\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 '../utils/merge';\nimport Geo from '../geo';\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    ShaderProgram.removeBlock('global');\n    ShaderProgram.removeBlock('setup');\n\n    // Unpacking functions (for normalized vertex attributes)\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/unpack']);\n\n    // Model and world position accessors\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/accessors']);\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    // Feature selection vertex shader support\n    ShaderProgram.replaceBlock('setup', shaderSources['gl/shaders/selection_vertex']);\n\n    // Minimum value for float comparisons\n    ShaderProgram.defines.TANGRAM_EPSILON = 0.00001;\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    // Internal tile scale\n    ShaderProgram.defines.TANGRAM_TILE_SCALE = `vec3(${Geo.tile_scale}., ${Geo.tile_scale}., u_meters_per_pixel * ${Geo.tile_size}.)`;\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\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    style.mixed = {};\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 && x !== style); // TODO: warning on trying to mix into self\n\n        // Track which styles were mixed into this one\n        for (let s of sources) {\n            style.mixed[s.name] = true;\n        }\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    style.raster = sources.map(x => x.raster).filter(x => x != null).pop();\n    if (sources.some(x => x.hasOwnProperty('blend') && x.blend)) {\n        // only mix blend if explicitly set, otherwise let base style choose blending mode\n        // hasOwnProperty check gives preference to base style prototype\n        style.blend = sources.map(x => x.hasOwnProperty('blend') && x.blend).filter(x => x).pop();\n    }\n    style.blend_order = sources.map(x => x.blend_order).filter(x => x != null).pop();\n\n    // Merges - property-specific rules for merging values\n    style.defines = Object.assign({}, ...sources.map(x => x.defines).filter(x => x)); // internal defines (not user-defined)\n    style.material = Object.assign({}, ...sources.map(x => x.material).filter(x => x));\n\n    // Mix shader properties\n    StyleManager.mixShaders(style, styles, sources);\n    return style;\n};\n\n// Mix the propertes in the \"shaders\" block\nStyleManager.mixShaders = function (style, styles, sources) {\n    let shaders = {}; // newly mixed shaders properties\n    let shader_merges = sources.map(x => x.shaders).filter(x => x); // just the source styles with shader properties\n\n    // Defines\n    shaders.defines = Object.assign({}, ...shader_merges.map(x => x.defines).filter(x => x));\n\n    // Uniforms\n    shaders.uniforms = {};  // uniforms for this style, both explicitly defined, and mixed from other styles\n    shaders._uniforms = (style.shaders && style.shaders.uniforms) || {}; // uniforms explicitly defined by *this* style\n    shaders._uniform_scopes = {}; // tracks which style each uniform originated from (this one, or ancestor)\n\n    // Mix in uniforms from ancestors, providing means to access\n    sources\n        .filter(x => x.shaders && x.shaders.uniforms)\n        .forEach(x => {\n            for (let u in x.shaders.uniforms) {\n                shaders._uniform_scopes[u] = x.name;\n\n                // Define getter and setter for this uniform\n                // Getter returns value for this style if present, otherwise asks appropriate ancestor for it\n                // Setter sets the value for this style (whether previously present in this style or not)\n                // Mimics JS prototype/hasOwnProperty behavior, but with multiple ancestors (via mixins)\n                Object.defineProperty(shaders.uniforms, u, {\n                    enumerable: true,\n                    configurable: true,\n                    get: function () {\n                        // Uniform is explicitly defined on this style\n                        if (shaders._uniforms[u] !== undefined) {\n                            return shaders._uniforms[u];\n                        }\n                        // Uniform was mixed from another style, forward request there\n                        // Identify check is needed to prevent infinite recursion if a previously defined uniform\n                        // is set to undefined\n                        else if (styles[shaders._uniform_scopes[u]].shaders.uniforms !== shaders.uniforms) {\n                            return styles[shaders._uniform_scopes[u]].shaders.uniforms[u];\n                        }\n                    },\n                    set: function (v) {\n                        shaders._uniforms[u] = v;\n                    }\n                });\n            }\n        });\n\n    // Extensions: build a list of unique extensions\n    shaders.extensions = Object.keys(shader_merges\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    // Shader blocks\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    let mixed = {}; // all scopes mixed so far\n    for (let source of shader_merges) {\n        if (!source.blocks) {\n            continue;\n        }\n\n        shaders.blocks = shaders.blocks || {};\n        shaders.block_scopes = shaders.block_scopes || {};\n        let mixed_source = {}; // scopes mixed for this source style\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            // standardize on arrays (block can be single or multi-value)\n            block = Array.isArray(block) ? block : [block];\n            block_scope = Array.isArray(block_scope) ? block_scope : [block_scope];\n\n            for (let b=0; b < block.length; b++) {\n                // Skip blocks we've already mixed in from the same scope\n                // Repeating scope indicates a diamond pattern where a style is being mixed multiple times\n                if (mixed[block_scope[b]]) {\n                    continue;\n                }\n                mixed_source[block_scope[b]] = true;\n\n                shaders.blocks[t].push(block[b]);\n                shaders.block_scopes[t].push(block_scope[b]);\n            }\n        }\n\n        // Add styles mixed in from this source - they could be multi-level ancestors,\n        // beyond the first-level \"parents\" defined in this style's `mix` list\n        Object.assign(mixed, mixed_source);\n    }\n\n    Object.assign(style.mixed, mixed); // add all newly mixed styles\n\n    style.shaders = shaders; // assign back to style\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\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_key) {\n    let styles = [];\n    for (let s in Styles) {\n        if (Styles[s].hasDataForTile(tile_key)) {\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';\n\nexport var StyleParser = {};\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// - global: user-defined properties on the `global` object in the scene file\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\nStyleParser.wrapFunction = function (func) {\n    var f = `function(context) {\n                var feature = context.feature.properties;\n                var global = context.global;\n                var $zoom = context.zoom;\n                var $layer = context.layer;\n                var $geometry = context.geometry;\n                var $meters_per_pixel = context.meters_per_pixel;\n\n                var val = (${func}());\n\n                if (typeof val === 'number' && isNaN(val)) {\n                    val = null; // convert NaNs to nulls\n                }\n\n                return val;\n            }`;\n    return f;\n};\n\n\n// Style parsing\n\nStyleParser.zeroPair = Object.freeze([0, 0]); // single allocation for zero values that won't be modified\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// Style macros\nStyleParser.macros = {\n    // pseudo-random color by geometry id\n    'Style.color.pseudoRandomColor': function() {\n        return [\n            0.7 * (parseInt(feature.id, 16) / 100 % 1),     // jshint ignore:line\n            0.7 * (parseInt(feature.id, 16) / 10000 % 1),   // jshint ignore:line\n            0.7 * (parseInt(feature.id, 16) / 1000000 % 1), // jshint ignore:line\n            1\n        ];\n    },\n\n    // random color\n    'Style.color.randomColor': function() {\n        return [0.7 * Math.random(), 0.7 * Math.random(), 0.7 * Math.random(), 1];\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, global) {\n    return {\n        feature,\n        tile,\n        global,\n        zoom: tile.style_zoom,\n        geometry: Geo.geometryType(feature.geometry.type),\n        meters_per_pixel: tile.meters_per_pixel,\n        units_per_meter: tile.units_per_meter\n    };\n};\n\n// Build a style param cache object\n// `value` is raw value, cache methods will add other properties as needed\n// `transform` is optional transform function to run on values (except function values)\nStyleParser.cacheObject = function (obj, transform = null) {\n    if (obj == null) {\n        return;\n    }\n\n    if (obj.value) {\n        return { value: obj.value, zoom: (obj.zoom ? {} : null) }; // clone existing cache object\n    }\n\n    let c = { value: obj };\n\n    if (typeof transform === 'function') {\n        if (Array.isArray(c.value) && Array.isArray(c.value[0])) { // zoom stops\n            c.value = c.value.map(v => [v[0], transform(v[1])]);\n            c.zoom = {}; // will hold values interpolated by zoom\n        }\n        else if (typeof c.value !== 'function') { // don't transform functions\n            c.value = transform(c.value); // single value\n        }\n    }\n\n    return c;\n};\n\n// Convert old-style color macro into a function\n// TODO: deprecate this macro syntax\nStyleParser.colorCacheObject = function (obj) {\n    return StyleParser.cacheObject(obj, v => {\n        if (v === 'Style.color.pseudoRandomColor') {\n            return Utils.stringToFunction(StyleParser.wrapFunction(StyleParser.macros['Style.color.pseudoRandomColor']));\n        }\n        else if (v === 'Style.color.randomColor') {\n            return StyleParser.macros['Style.color.randomColor'];\n        }\n\n        return v;\n    });\n};\n\n// Interpolation and caching for a generic property (not a color or distance)\n// { value: original, static: val, zoom: { 1: val1, 2: val2, ... }, dynamic: function(){...} }\nStyleParser.cacheProperty = function(val, context) {\n    if (val == null) {\n        return;\n    }\n    else if (val.dynamic) { // function, compute each time (no caching)\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.static) { // single static value\n        return val.static;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) { // interpolated, cached\n        return val.zoom[context.zoom];\n    }\n    else { // not yet evaulated for cache\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 if (Array.isArray(val.value) && Array.isArray(val.value[0])) {\n            // Calculate value for current zoom\n            val.zoom = val.zoom || {};\n            val.zoom = {};\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value);\n            return val.zoom[context.zoom];\n        }\n        // Single static value\n        else {\n            val.static = val.value;\n            return val.static;\n        }\n    }\n};\n\nStyleParser.convertUnits = function(val, context) {\n    // pre-parsed units\n    if (val.val != null) {\n        if (val.units === 'px') { // convert from pixels\n            return val.val * Geo.metersPerPixel(context.zoom);\n        }\n        return val.val;\n    }\n    // un-parsed unit string\n    else 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        if (units === 'px') { // convert from pixels\n            val *= Geo.metersPerPixel(context.zoom);\n        }\n    }\n    // multiple values or stops\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 => [v[0], StyleParser.convertUnits(v[1], context)]);\n        }\n        // Array of values\n        else {\n            return val.map(v => StyleParser.convertUnits(v, context));\n        }\n    }\n    return val;\n};\n\n// Pre-parse units from string values\nStyleParser.cacheUnits = function (val) {\n    var obj = { val: parseFloat(val) };\n    if (obj.val !== 0 && typeof val === 'string' && val.trim().slice(-2) === 'px') {\n        obj.units = 'px';\n    }\n    return obj;\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) {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) {\n        return val.zoom[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 if (val.zoom) {\n            // Calculate value for current zoom\n            // Do final unit conversion as late as possible, when interpolation values have been determined\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value,\n                v => StyleParser.convertUnits(v, context));\n\n            return val.zoom[context.zoom];\n        }\n        else {\n            return StyleParser.convertUnits(val.value, context);\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    }\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\n        if (typeof v === 'string') {\n            v = StyleParser.colorForString(v);\n        }\n\n        if (v && v[3] == null) {\n            v[3] = 1; // default alpha\n        }\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\n            if (typeof v === 'string') {\n                v = StyleParser.colorForString(v);\n            }\n\n            if (v && v[3] == null) {\n                v[3] = 1; // default alpha\n            }\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 (val.zoom) {\n            // Parse any string colors inside stops, the first time we encounter this property\n            if (!val.zoom_preprocessed) {\n                for (let i=0; i < val.value.length; i++) {\n                    let v = val.value[i];\n                    if (v && typeof v[1] === 'string') {\n                        v[1] = StyleParser.colorForString(v[1]);\n                    }\n                }\n                val.zoom_preprocessed = true;\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            if (val.static && val.static[3] == null) {\n                val.static[3] = 1; // default alpha\n            }\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 = StyleParser.colorForString(val);\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                v[1] = StyleParser.colorForString(v[1]);\n            }\n        }\n\n        if (context.zoom) {\n            val = Utils.interpolate(context.zoom, val);\n        }\n    }\n\n    // Defaults\n    if (val) {\n        // alpha\n        if (val[3] == null) {\n            val[3] = 1;\n        }\n    }\n    else {\n        val = [0, 0, 0, 1];\n    }\n\n    return val;\n};\n\nStyleParser.calculateOrder = function(order, context) {\n    // Computed order\n    if (typeof order === 'function') {\n        order = order(context);\n    }\n    else if (typeof order === 'string') {\n        // Order tied to feature property\n        if (context.feature.properties[order]) {\n            order = context.feature.properties[order];\n        }\n        // Explicit order value\n        else {\n            order = parseFloat(order);\n        }\n    }\n\n    return order;\n};\n\n// Evaluate a function-based property, or pass-through static value\nStyleParser.evalProp = function(prop, context) {\n    if (typeof prop === 'function') {\n        return prop(context);\n    }\n    return prop;\n};\n\n// Substitutes global scene properties (those defined in the `config.global` object) for any style values\n// of the form `global.`, for example `color: global.park_color` would be replaced with the value (if any)\n// defined for the `park_color` property in `config.global.park_color`.\nStyleParser.applyGlobalProperties = function (config) {\n    if (!config.global || Object.keys(config.global).length === 0) {\n        return config; // no global properties to transform\n    }\n\n    const separator = ':';\n    const props = flattenProperties(config.global, separator);\n\n    function applyProps (obj) {\n        // Convert string\n        if (typeof obj === 'string') {\n            let key = (obj.slice(0, 7) === 'global.') && (obj.slice(7).replace(/\\./g, separator));\n            if (key && props[key]) {\n                obj = props[key];\n            }\n        }\n        // Loop through object properties\n        else if (typeof obj === 'object') {\n            for (let p in obj) {\n                obj[p] = applyProps(obj[p]);\n            }\n        }\n        return obj;\n    }\n\n    return applyProps(config);\n};\n\n// Flatten nested properties for simpler string look-ups\n// e.g. global.background.color -> 'global:background:color'\nfunction flattenProperties (obj, separator = ':', prefix = null, props = {}) {\n    prefix = prefix ? (prefix + separator) : '';\n\n    for (let p in obj) {\n        let key = prefix + p;\n        let val = obj[p];\n        props[key] = val;\n\n        if (typeof val === 'object' && !Array.isArray(val)) {\n            flattenProperties(val, separator, key, props);\n        }\n    }\n    return props;\n}\n","import Utils from '../../utils/utils';\nimport Texture from '../../gl/texture';\n\nexport default class CanvasText {\n\n    constructor () {\n        this.canvas = document.createElement('canvas');\n        this.canvas.style.backgroundColor = 'transparent'; // render text on transparent background\n        this.context = this.canvas.getContext('2d');\n    }\n\n    resize (width, height) {\n        this.canvas.width = width;\n        this.canvas.height = height;\n        this.context.clearRect(0, 0, width, height);\n    }\n\n    // Set font style params for canvas drawing\n    setFont ({ font_css, fill, stroke, stroke_width, px_size }) {\n        this.px_size = px_size;\n        this.text_buffer = 8; // pixel padding around text\n        let ctx = this.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    textSizes (texts) {\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_settings = text_infos[text].text_settings;\n                // update text sizes\n                this.setFont(text_settings); // TODO: only set once above\n                Object.assign(\n                    text_infos[text],\n                    this.textSize(\n                        text,\n                        text_settings.transform,\n                        text_settings.text_wrap\n                    )\n                );\n            }\n        }\n\n        return texts;\n    }\n\n    // Computes width and height of text based on current font style\n    // Includes word wrapping, returns size info for whole text block and individual lines\n    textSize (text, transform, text_wrap) {\n        let str = this.applyTextTransform(text, transform);\n        let ctx = this.context;\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n        let leading = 2 * Utils.device_pixel_ratio; // make configurable and/or use Canvas TextMetrics when available\n        let line_height = this.px_size + leading; // px_size already in device pixels\n\n        // Word wrapping\n        // Line breaks can be caused by:\n        //  - implicit line break when a maximum character threshold is exceeded per line (text_wrap)\n        //  - explicit line break in the label text (\\n)\n        let words;\n        if (typeof text_wrap === 'number') {\n            words = str.split(' '); // split words on spaces\n        }\n        else {\n            words = [str]; // no max line word wrapping (but new lines will still be in effect)\n        }\n        let new_line_template = { width: 0, chars: 0, text: '' };\n        let line = Object.assign({}, new_line_template); // current line\n        let lines = []; // completed lines\n        let max_width = 0; // max width to fit all lines\n\n        // add current line buffer to completed lines, optionally start new line\n        function addLine (new_line) {\n            line.text = line.text.trim();\n            if (line.text.length > 0) {\n                line.width = ctx.measureText(line.text).width;\n                max_width = Math.max(max_width, Math.ceil(line.width));\n                lines.push(line);\n            }\n            if (new_line) {\n                line = Object.assign({}, new_line_template);\n            }\n        }\n\n        // First iterate on space-break groups (will be one if max line length off), then iterate on line-break groups\n        for (let w=0; w < words.length; w++) {\n            let breaks = words[w].split('\\n'); // split on line breaks\n\n            for (let n=0; n < breaks.length; n++) {\n                let word = breaks[n];\n\n                // if adding current word would overflow, add a new line instead\n                if (line.chars + word.length > text_wrap && line.chars > 0) {\n                    addLine(true);\n                }\n\n                // add current word (plus space)\n                line.chars += word.length + 1;\n                line.text += word + ' ';\n\n                // if line breaks present, add new line (unless on last line)\n                if (breaks.length > 1 && n < breaks.length - 1) {\n                    addLine(true);\n                }\n            }\n        }\n        addLine(false);\n\n        // Final dimensions of text\n        let height = lines.length * line_height;\n\n        let collision_size = [\n            max_width / Utils.device_pixel_ratio,\n            height / Utils.device_pixel_ratio\n        ];\n\n        let texture_size = [\n            max_width + buffer * 2,\n            height + buffer * 2\n        ];\n\n        let logical_size = texture_size.map(v => v / Utils.device_pixel_ratio);\n\n        // Returns lines (w/per-line info for drawing) and text's overall bounding box + canvas size\n        return {\n            lines,\n            size: { collision_size, texture_size, logical_size, line_height }\n        };\n    }\n\n    // Draw one or more lines of text at specified location, adjusting for buffer and baseline\n    drawText (lines, [x, y], size, { stroke, transform, align }) {\n        align = align || 'center';\n\n        for (let line_num=0; line_num < lines.length; line_num++) {\n            let line = lines[line_num];\n            let str = this.applyTextTransform(line.text, transform);\n            let buffer = this.text_buffer * Utils.device_pixel_ratio;\n            let texture_size = size.texture_size;\n            let line_height = size.line_height;\n\n            // Text alignment\n            let tx;\n            if (align === 'left') {\n                tx = x + buffer;\n            }\n            else if (align === 'center') {\n                tx = x + texture_size[0]/2 - line.width/2;\n            }\n            else if (align === 'right') {\n                tx = x + texture_size[0] - line.width - buffer;\n            }\n\n            // In the absence of better Canvas TextMetrics (not supported by browsers yet),\n            // 0.75 buffer produces a better approximate vertical centering of text\n            let ty = y + buffer * 0.75 + (line_num + 1) * line_height;\n\n            if (stroke) {\n                this.context.strokeText(str, tx, ty);\n            }\n            this.context.fillText(str, tx, ty);\n        }\n    }\n\n    rasterize (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(info.text_settings); // TODO: only set once above\n                this.drawText(info.lines, info.position, info.size, {\n                    stroke: info.text_settings.stroke,\n                    transform: info.text_settings.transform,\n                    align: info.text_settings.align\n                });\n\n                info.texcoords = Texture.getTexcoordsForSprite(\n                    info.position,\n                    info.size.texture_size,\n                    texture_size\n                );\n            }\n        }\n    }\n\n    // Place text labels within an atlas of the given max size\n    setTextureTextPositions (texts, max_texture_size) {\n        // Find widest label\n        let widest = 0;\n        for (let style in texts) {\n            let text_infos = texts[style];\n            for (let text in text_infos) {\n                let size = text_infos[text].size.texture_size;\n                if (size[0] > widest) {\n                    widest = size[0];\n                }\n            }\n        }\n\n        // Layout labels, stacked in columns\n        let cx = 0, cy = 0; // current x/y position in atlas\n        let height = 0;     // overall atlas height\n        for (let style in texts) {\n            let text_infos = texts[style];\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                let size = text_info.size.texture_size;\n                if (cy + size[1] < max_texture_size) {\n                    text_info.position = [cx, cy]; // add label to current column\n                    cy += size[1];\n                    if (cy > height) {\n                        height = cy;\n                    }\n                }\n                else { // start new column if taller than texture\n                    cx += widest;\n                    cy = 0;\n                    text_info.position = [cx, cy];\n                }\n            }\n        }\n\n        return [cx + widest, height]; // overall atlas size\n    }\n\n    // Called before rasterization\n    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    // Convert font CSS-style size ('12px', '14pt', '1.5em', etc.) to pixel size (adjusted for device pixel ratio)\n    // Defaults units to pixels if not specified\n    static fontPixelSize (size) {\n        if (size == null) {\n            return;\n        }\n        size = (typeof size === 'string') ? size : String(size); // need a string for regex\n\n        let [, px_size, units] = size.match(CanvasText.font_size_re) || [];\n        units = units || 'px';\n\n        if (units === \"em\") {\n            px_size *= 16;\n        } else if (units === \"pt\") {\n            px_size /= 0.75;\n        } else if (units === \"%\") {\n            px_size /= 6.25;\n        }\n\n        px_size = parseFloat(px_size);\n        px_size *= Utils.device_pixel_ratio;\n        return px_size;\n    }\n\n}\n\n// Extract font size and units\nCanvasText.font_size_re = /((?:[0-9]*\\.)?[0-9]+)\\s*(px|pt|em|%)?/;\n","// Text rendering style\n\nimport Texture from '../../gl/texture';\nimport WorkerBroker from '../../utils/worker_broker';\nimport Utils from '../../utils/utils';\nimport Geo from '../../geo';\nimport {Style} from '../style';\nimport {Points} from '../points/points';\nimport CanvasText from './canvas_text';\nimport Collision from '../../labels/collision';\nimport LabelPoint from '../../labels/label_point';\nimport LabelLine from '../../labels/label_line';\nimport TextSettings from './text_settings';\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        this.super.init.apply(this, arguments);\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        this.defines.TANGRAM_UNMULTIPLY_ALPHA = true;\n\n        // Fade out text when tile is zooming out, e.g. acting as proxy tiles\n        this.defines.TANGRAM_FADE_ON_ZOOM_OUT = true;\n        this.defines.TANGRAM_FADE_ON_ZOOM_OUT_RATE = 2; // fade at 2x, e.g. fully transparent at 0.5 zoom level away\n\n        this.reset();\n    },\n\n    reset() {\n        this.super.reset.call(this);\n        if (Utils.isMainThread) {\n            this.canvas = new CanvasText();\n        }\n        else if (Utils.isWorkerThread) {\n            this.texts = {}; // unique texts, grouped by tile, by style\n        }\n    },\n\n    // Called on worker thread to release tile-specific resources\n    freeTile (tile) {\n        delete this.texts[tile.key];\n    },\n\n    // Free tile-specific resources before finshing style construction\n    finishTile(tile) {\n        this.freeTile(tile);\n        return Style.endData.call(this, tile);\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, draw, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        // Called here because otherwise it will be delayed until the feature queue is parsed,\n        // and we want the preprocessing done before we evaluate text style below\n        draw = this.preprocess(draw);\n        if (!draw) {\n            return;\n        }\n\n        // Compute label text\n        let text = this.parseTextSource(feature, draw, context);\n        if (text == null) {\n            return; // no text for this feature\n        }\n\n        // Compute text style and layout settings for this feature label\n        let layout = this.computeLayout({}, feature, draw, context, tile, text);\n        let text_settings = TextSettings.compute(feature, draw, context);\n        let text_settings_key = TextSettings.key(text_settings);\n\n        // first label in tile, or with this style?\n        this.texts[tile.key] = this.texts[tile.key] || {};\n        this.texts[tile.key][text_settings_key] = this.texts[tile.key][text_settings_key] || {};\n\n        // unique text strings, grouped by text drawing style\n        if (!this.texts[tile.key][text_settings_key][text]) {\n            // first label with this text/style/tile combination, make a new label entry\n            this.texts[tile.key][text_settings_key][text] = {\n                text_settings,\n                ref: 0 // # of times this text/style combo appears in tile\n            };\n        }\n\n        // Queue the feature for processing\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile);\n        }\n\n        if (!this.queues[tile.key]) {\n            this.queues[tile.key] = [];\n        }\n\n        this.queues[tile.key].push({\n            feature, draw, context,\n            text, text_settings_key, layout\n        });\n\n        // Register with collision manager\n        Collision.addStyle(this.name, tile.key);\n    },\n\n    // Override\n    endData (tile) {\n        let queue = this.queues[tile.key];\n        this.queues[tile.key] = [];\n\n        if (Object.keys(this.texts[tile.key]||{}).length === 0) {\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+'.calcTextSizes', this.texts[tile.key]).then(texts => {\n            if (tile.canceled) {\n                Utils.log('trace', `Style ${this.name}: stop tile build because tile was canceled: ${tile.key}, post-calcTextSizes()`);\n                return;\n            }\n\n            if (!texts) {\n                Collision.collide({}, this.name, tile.key);\n                return this.finishTile(tile);\n            }\n            this.texts[tile.key] = texts;\n\n            let labels = this.createLabels(tile.key, queue);\n\n            return Collision.collide(labels, this.name, tile.key).then(labels => {\n                if (tile.canceled) {\n                    Utils.log('trace', `stop tile build because tile was canceled: ${tile.key}, post-collide()`);\n                    return;\n                }\n\n                if (labels.length === 0) {\n                    return this.finishTile(tile); // no labels visible for this tile\n                }\n\n                this.cullTextStyles(texts, labels);\n\n                // second call to main thread, for rasterizing the set of texts\n                return WorkerBroker.postMessage(this.main_thread_target+'.rasterizeTexts', tile.key, texts).then(({ texts, texture }) => {\n                    if (texts) {\n                        this.texts[tile.key] = texts;\n\n                        // Build queued features\n                        labels.forEach(q => {\n                            let text_settings_key = q.text_settings_key;\n                            let text_info = this.texts[tile.key] && this.texts[tile.key][text_settings_key] && this.texts[tile.key][text_settings_key][q.text];\n\n                            // setup styling object expected by Style class\n                            let style = this.feature_style;\n                            style.label = q.label;\n                            style.size = text_info.size.logical_size;\n                            style.angle = Utils.radToDeg(q.label.angle) || 0;\n                            style.texcoords = text_info.texcoords;\n\n                            Style.addFeature.call(this, q.feature, q.draw, q.context);\n                        });\n                    }\n\n                    return this.finishTile(tile).then(tile_data => {\n                        // Attach tile-specific label atlas to mesh as a texture uniform\n                        if (texture && tile_data) {\n                            tile_data.uniforms.u_texture = texture;\n                            tile_data.textures.push(texture); // assign texture ownership to tile\n                            return tile_data;\n                        }\n                    });\n                });\n            });\n        });\n    },\n\n    createLabels (tile_key, feature_queue) {\n        let labels = [];\n\n        for (let f=0; f < feature_queue.length; f++) {\n            let { feature, draw, context, text, text_settings_key, layout } = feature_queue[f];\n            let text_info = this.texts[tile_key][text_settings_key][text];\n\n            let feature_labels = this.buildLabelsFromGeometry(text_info.size.collision_size, feature.geometry, layout);\n            for (let i = 0; i < feature_labels.length; i++) {\n                let label = feature_labels[i];\n                labels.push({\n                    feature, draw, context,\n                    text, text_settings_key, layout, label\n                });\n            }\n        }\n\n        return labels;\n    },\n\n    // Remove unused text/style combinations to avoid unnecessary rasterization\n    cullTextStyles(texts, labels) {\n        // Count how many times each text/style combination is used\n        for (let i=0; i < labels.length; i++) {\n            texts[labels[i].text_settings_key][labels[i].text].ref++;\n        }\n\n        // Remove text/style combinations that have no visible labels\n        for (let style in texts) {\n            for (let text in texts[style]) {\n                // no labels for this text\n                if (texts[style][text].ref < 1) {\n                    // console.log(`drop label text ${text} in style ${style}`);\n                    delete texts[style][text];\n                }\n            }\n        }\n\n        for (let style in texts) {\n            // no labels for this style\n            if (Object.keys(texts[style]).length === 0) {\n                // console.log(`drop label text style ${style}`);\n                delete texts[style];\n            }\n        }\n    },\n\n    // Called on main thread from worker, to compute the size of each text string,\n    // were it to be rendered. This info is then used to perform initial label culling, *before*\n    // labels are actually rendered.\n    calcTextSizes (texts) {\n        return this.canvas.textSizes(texts);\n    },\n\n    // Called on main thread from worker, to create atlas of labels for a tile\n    rasterizeTexts (tile_key, texts) {\n        let canvas = new CanvasText();\n        let texture_size = canvas.setTextureTextPositions(texts, this.max_texture_size);\n        log.trace(`text summary for tile ${tile_key}: fits in ${texture_size[0]}x${texture_size[1]}px`);\n\n        // fits in max texture size?\n        if (texture_size[0] < this.max_texture_size && texture_size[1] < this.max_texture_size) {\n            // update canvas size & rasterize all the text strings we need\n            canvas.resize(...texture_size);\n            canvas.rasterize(texts, texture_size);\n        }\n        else {\n            log.error([\n                `Label atlas for tile ${tile_key} is ${texture_size[0]}x${texture_size[1]}px, `,\n                `but max GL texture size is ${this.max_texture_size}x${this.max_texture_size}px`].join(''));\n        }\n\n        // create a texture\n        let t = 'labels-' + tile_key + '-' + (TextStyle.texture_id++);\n        Texture.create(this.gl, t, {\n            element: canvas.canvas,\n            filtering: 'linear',\n            UNPACK_PREMULTIPLY_ALPHA_WEBGL: true\n        });\n        Texture.retain(t);\n\n        return { texts, texture: t }; // texture is returned by name (not instance)\n    },\n\n    // Sets up caching for draw rule properties\n    _preprocess (draw) {\n        if (!draw.font) {\n            return;\n        }\n\n        // Colors\n        draw.font.fill = StyleParser.cacheObject(draw.font.fill);\n        if (draw.font.stroke) {\n            draw.font.stroke.color = StyleParser.cacheObject(draw.font.stroke.color);\n        }\n\n        // Convert font and text stroke sizes\n        draw.font.px_size = StyleParser.cacheObject(draw.font.size, CanvasText.fontPixelSize);\n        if (draw.font.stroke && draw.font.stroke.width != null) {\n            draw.font.stroke.width = StyleParser.cacheObject(draw.font.stroke.width, parseFloat);\n        }\n\n        // Offset (2d array)\n        draw.offset = StyleParser.cacheObject(draw.offset, v => (Array.isArray(v) && v.map(parseFloat)) || 0);\n\n        // Buffer (1d value or or 2d array)\n        draw.buffer = StyleParser.cacheObject(draw.buffer, v => (Array.isArray(v) ? v : [v, v]).map(parseFloat) || 0);\n\n        // Repeat rules\n        draw.repeat_distance = StyleParser.cacheObject(draw.repeat_distance, parseFloat);\n\n        return draw;\n    },\n\n    // Compute the label text, default is value of feature.properties.name\n    // - String value indicates a feature property look-up, e.g. `short_name` means use feature.properties.short_name\n    // - Function will use the return value as the label text (for custom labels)\n    // - Array (of strings and/or functions) defines a list of fallbacks, evaluated according to the above rules,\n    //   with the first non-null value used as the label text\n    //   e.g. `[name:es, name:en, name]` prefers Spanish names, followed by English, and last the default local name\n    parseTextSource (feature, draw, context) {\n        let text;\n        let source = draw.text_source || 'name';\n\n        if (Array.isArray(source)) {\n            for (let s=0; s < source.length; s++) {\n                if (typeof source[s] === 'string') {\n                    text = feature.properties[source[s]];\n                } else if (typeof source[s] === 'function') {\n                    text = source[s](context);\n                }\n\n                if (text) {\n                    break; // stop if we found a text property\n                }\n            }\n        }\n        else if (typeof source === 'string') {\n            text = feature.properties[source];\n        } else if (typeof source === 'function') {\n            text = source(context);\n        }\n        return text;\n    },\n\n    // Additional text-specific layout settings\n    computeLayout (target, feature, draw, context, tile, text) {\n        let layout = target || {};\n\n        // common settings w/points\n        layout = Points.computeLayout(layout, feature, draw, context, tile);\n\n        // tile boundary handling\n        layout.cull_from_tile = (draw.cull_from_tile != null) ? draw.cull_from_tile : true;\n        layout.move_into_tile = (draw.move_into_tile != null) ? draw.move_into_tile : true;\n\n        // label line exceed percentage\n        if (draw.line_exceed && draw.line_exceed.substr(-1) === '%') {\n            layout.line_exceed = parseFloat(draw.line_exceed.substr(0,draw.line_exceed.length-1));\n        }\n        else {\n            layout.line_exceed = 80;\n        }\n\n        // repeat minimum distance\n        layout.repeat_distance = StyleParser.cacheProperty(draw.repeat_distance, context);\n        if (layout.repeat_distance == null) {\n            layout.repeat_distance = Geo.tile_size;\n        }\n        layout.repeat_distance *= layout.units_per_pixel;\n\n        // repeat group key\n        if (typeof draw.repeat_group === 'function') {\n            layout.repeat_group = draw.repeat_group(context);\n        }\n        else if (typeof draw.repeat_group === 'string') {\n            layout.repeat_group = draw.repeat_group;\n        }\n        else {\n            layout.repeat_group = draw.key; // default to unique set of matching layers\n        }\n        layout.repeat_group += '/' + text;\n\n        // Max number of subdivisions to try\n        layout.subdiv = tile.overzoom2;\n\n        return layout;\n    },\n\n    // Builds one or more labels for a geometry\n    buildLabelsFromGeometry (size, geometry, options) {\n        let labels = [];\n\n        if (geometry.type === \"LineString\") {\n            this.buildLineLabels(size, geometry.coordinates, options, labels);\n        } else if (geometry.type === \"MultiLineString\") {\n            let lines = geometry.coordinates;\n            for (let i = 0; i < lines.length; ++i) {\n                this.buildLineLabels(size, lines[i], options, labels);\n            }\n        } else if (geometry.type === \"Point\") {\n            labels.push(new LabelPoint(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                labels.push(new LabelPoint(points[i], size, options));\n            }\n        } else if (geometry.type === \"Polygon\") {\n            let centroid = Geo.centroid(geometry.coordinates[0]);\n            labels.push(new LabelPoint(centroid, size, options));\n        } else if (geometry.type === \"MultiPolygon\") {\n            let centroid = Geo.multiCentroid(geometry.coordinates);\n            labels.push(new LabelPoint(centroid, size, options));\n        }\n\n        return labels;\n    },\n\n    // Build one or more labels for a line geometry\n    buildLineLabels (size, line, options, labels) {\n        let subdiv = Math.min(options.subdiv, line.length - 1);\n        if (subdiv > 1) {\n            // Create multiple labels for line, with each allotted a range of segments\n            // in which it will attempt to place\n            let seg_per_div = (line.length - 1) / subdiv;\n            for (let i=0; i < subdiv; i++) {\n                options.segment_start = Math.floor(i * seg_per_div);\n                options.segment_end = Math.floor((i+1) * seg_per_div);\n                labels.push(new LabelLine(size, line, options));\n            }\n            options.segment_start = null;\n            options.segment_end = null;\n        }\n        else {\n            labels.push(new LabelLine(size, line, options));\n        }\n    }\n\n});\n\nTextStyle.texture_id = 0; // namespaces per-tile label textures\n","import Utils from '../../utils/utils';\nimport Geo from '../../geo';\nimport {StyleParser} from '../style_parser';\nimport PointAnchor from '../points/point_anchor';\n\nvar TextSettings;\n\nexport default TextSettings = {\n\n    // A key for grouping all labels of the same text style (e.g. same Canvas state, to minimize state changes)\n    key (settings) {\n        return [\n            settings.style,\n            settings.weight,\n            settings.family,\n            settings.px_size,\n            settings.fill,\n            settings.stroke,\n            settings.stroke_width,\n            settings.transform,\n            settings.text_wrap,\n            settings.align\n        ].join('/');\n    },\n\n    defaults: {\n        style: 'normal',\n        weight: null,\n        size: '12px',\n        px_size: 12,\n        family: 'Helvetica',\n        fill: 'white',\n        text_wrap: 15,\n        align: 'center'\n    },\n\n    compute (feature, draw, context) {\n        let style = {};\n\n        draw.font = draw.font || this.defaults;\n\n        // Use fill if specified, or default\n        style.fill = (draw.font.fill && Utils.toCSSColor(StyleParser.cacheColor(draw.font.fill, context))) || this.defaults.fill;\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 = draw.font.style || this.defaults.style;\n        style.weight = draw.font.weight || this.defaults.weight;\n        if (draw.font.family) {\n            style.family = draw.font.family;\n            if (style.family !== this.defaults.family) {\n                style.family += ', ' + this.defaults.family;\n            }\n        }\n        else {\n            style.family = this.defaults.family;\n        }\n\n        style.transform = draw.font.transform;\n\n        // original size (not currently used, but useful for debugging)\n        style.size = draw.font.size || this.defaults.size;\n\n        // calculated pixel size\n        style.px_size = StyleParser.cacheProperty(draw.font.px_size, context) || this.defaults.px_size;\n\n        // Use stroke if specified\n        if (draw.font.stroke && draw.font.stroke.color) {\n            style.stroke = Utils.toCSSColor(StyleParser.cacheColor(draw.font.stroke.color, context) || this.defaults.stroke);\n            style.stroke_width = StyleParser.cacheProperty(draw.font.stroke.width, context) || this.defaults.stroke_width;\n            style.stroke_width *= Utils.device_pixel_ratio;\n        }\n\n        style.font_css = this.fontCSS(style);\n\n        // Word wrap and text alignment\n        // Not a font properties, but affect atlas of unique text textures\n        let text_wrap = draw.text_wrap; // use explicitly set value\n        if (text_wrap == null && Geo.geometryType(feature.geometry.type) !== 'line') {\n            // point labels (for point and polygon features) have word wrap on w/default max length,\n            // line labels default off\n            text_wrap = true;\n        }\n\n        // setting to 'true' causes default wrap value to be used\n        if (text_wrap === true) {\n            text_wrap = this.defaults.text_wrap;\n        }\n        style.text_wrap = text_wrap;\n\n        // default alignment to match anchor\n        if (!draw.align && draw.anchor && draw.anchor !== 'center') {\n            if (PointAnchor.isLeftAnchor(draw.anchor)) {\n                draw.align = 'right';\n            }\n            else if (PointAnchor.isRightAnchor(draw.anchor)) {\n                draw.align = 'left';\n            }\n        }\n\n        style.align = draw.align || this.defaults.align;\n\n        return style;\n    },\n\n    // Build CSS-style font string (to set Canvas draw state)\n    fontCSS ({ style, weight, px_size, family }) {\n        return [style, weight, px_size + 'px', family]\n            .filter(x => x) // remove null props\n            .join(' ');\n    }\n\n};\n","import Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport Collision from './labels/collision';\nimport WorkerBroker from './utils/worker_broker';\nimport Texture from './gl/texture';\n\nimport {mat4, vec3} from './utils/gl-matrix';\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, style_zoom, source, worker, view }) {\n        this.worker = worker;\n        this.view = view;\n        this.source = source;\n        this.generation = null;\n\n        this.visible = false;\n        this.proxy = null;\n        this.proxy_depth = 0;\n        this.loading = false;\n        this.loaded = false;\n        this.error = null;\n        this.debug = {};\n\n        this.coords = Tile.coordinateWithMaxZoom(coords, this.source.max_zoom);\n        this.style_zoom = style_zoom; // zoom level to be used for styling\n        this.overzoom = Math.max(this.style_zoom - this.coords.z, 0); // number of levels of overzooming\n        this.overzoom2 = Math.pow(2, this.overzoom);\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        this.center_dist = 0;\n\n        // Units per pixel needs to account for over-zooming\n        this.units_per_pixel = Geo.units_per_pixel / this.overzoom2;\n\n        this.meters_per_pixel = Geo.metersPerPixel(this.coords.z);\n        this.units_per_meter = Geo.unitsPerMeter(this.coords.z);\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 coord(c) {\n        return {x: c.x, y: c.y, z: c.z, key: Tile.coordKey(c)};\n    }\n\n    static coordKey({x, y, z}) {\n        return x + '/' + y + '/' + z;\n    }\n\n    static key (coords, source, style_zoom) {\n        coords = Tile.coordinateWithMaxZoom(coords, source.max_zoom);\n        if (coords.y < 0 || coords.y >= (1 << coords.z) || coords.z < 0) {\n            return; // cull tiles out of range (x will wrap)\n        }\n        return [source.name, style_zoom, coords.x, coords.y, coords.z].join('/');\n    }\n\n    static coordinateAtZoom({x, y, z, key}, 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            z = zoom;\n        }\n        return Tile.coord({x, y, z});\n    }\n\n    static coordinateWithMaxZoom({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 Tile.coord({x, y, z});\n    }\n\n    static childrenForCoordinate({x, y, z, key}) {\n        if (!Tile.coord_children[key]) {\n            z++;\n            x *= 2;\n            y *= 2;\n            Tile.coord_children[key] = [\n                Tile.coord({x, y,      z}), Tile.coord({x: x+1, y,      z}),\n                Tile.coord({x, y: y+1, z}), Tile.coord({x: x+1, y: y+1, z})\n            ];\n        }\n        return Tile.coord_children[key];\n    }\n\n    static isDescendant(parent, descendant) {\n        if (descendant.z > parent.z) {\n            let {x, y} = Tile.coordinateAtZoom(descendant, parent.z);\n            return (parent.x === x && parent.y === y);\n        }\n        return false;\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    // Free resources owned by tile\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                Texture.release(t);\n            }\n        }\n\n        this.meshes = {};\n        this.textures = [];\n    }\n\n    destroy() {\n        this.workerMessage('self.removeTile', this.key);\n        this.freeResources();\n        this.worker = null;\n    }\n\n    buildAsMessage() {\n        return {\n            key: this.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            meters_per_pixel: this.meters_per_pixel,\n            units_per_meter: this.units_per_meter,\n            style_zoom: this.style_zoom,\n            overzoom: this.overzoom,\n            overzoom2: this.overzoom2,\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('self.buildTile', { tile: this.buildAsMessage() }).catch(e => { throw e; });\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            tile.canceled = true;\n            if (tile.source_data && tile.source_data.request) {\n                tile.source_data.request.abort();\n            }\n            Tile.abortBuild(tile);\n        }\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, global }) {\n        tile.debug.rendering = +new Date();\n        tile.debug.features = 0;\n\n        let data = tile.source_data;\n\n        Collision.startTile(tile.key);\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 || !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\n            // Render features in layer\n            for (let s=0; s < source_layers.length; s++) {\n                let source_layer = source_layers[s];\n                let geom = source_layer.geom;\n                if (!geom) {\n                    continue;\n                }\n\n                for (let f = 0; f < geom.features.length; f++) {\n                    let feature = geom.features[f];\n                    if (feature.geometry == null) {\n                        continue; // skip features w/o geometry (valid GeoJSON)\n                    }\n\n                    let context = StyleParser.getFeatureParseContext(feature, tile, global);\n                    context.winding = tile.default_winding;\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.layers = group.layers;  // add matching draw layers\n\n                        style.addFeature(feature, group, context);\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 s=0; s < tile_styles.length; s++) {\n            let style_name = tile_styles[s];\n            let style = styles[style_name];\n            queue.push(style.endData(tile).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            Collision.resetTile(tile.key);\n\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        // Debug\n        this.debug.geometries = 0;\n        this.debug.buffer_size = 0;\n\n        // Create VBOs\n        let meshes = {}, textures = []; // new resources, to be swapped in\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                        break;\n                    }\n                    meshes[s] = styles[s].makeMesh(mesh_data[s].vertex_data, mesh_data[s]);\n                    this.debug.geometries += meshes[s].geometry_count;\n                }\n\n                // Assign texture ownership to tiles\n                // Note that it's valid for a single texture to be referenced from multiple styles\n                // (e.g. same raster texture attached to multiple sources). This means the same\n                // texture may be added to the tile's texture list more than once, which ensures\n                // that it is properly released (to match its retain count).\n                if (mesh_data[s].textures) {\n                    mesh_data[s].textures.forEach(t => {\n                        textures.push(t);\n                    });\n                }\n            }\n        }\n        delete this.mesh_data; // TODO: might want to preserve this for rebuilding geometries when styles/etc. change?\n\n        // Swap in new data, free old data\n        this.freeResources();\n        this.meshes = meshes;\n        this.textures = textures;\n\n        this.debug.geom_ratio = (this.debug.geometries / this.debug.features).toFixed(1);\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(`releasing texture ${t} for tile ${tile.key}`);\n                            texture.release();\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    // Update relative to view\n    update () {\n        let coords = this.coords;\n        if (coords.z !== this.view.center.tile.z) {\n            coords = Tile.coordinateAtZoom(coords, this.view.center.tile.z);\n        }\n        this.center_dist = Math.abs(this.view.center.tile.x - coords.x) + Math.abs(this.view.center.tile.y - coords.y);\n    }\n\n    // Set as a proxy tile for another tile\n    setProxyFor (tile) {\n        this.proxy = tile;\n        if (tile) {\n            this.visible = true;\n            this.proxy_depth = 1; // draw proxies a half-layer back (order is scaled 2x to avoid integer truncation)\n            this.update();\n        }\n        else {\n            this.proxy_depth = 0;\n        }\n    }\n\n    // Update model matrix and tile uniforms\n    setupProgram ({ model, model32 }, program) {\n        // Tile origin\n        program.uniform('4f', 'u_tile_origin', this.min.x, this.min.y, this.style_zoom, this.coords.z);\n        program.uniform('1f', 'u_tile_proxy_depth', this.proxy_depth);\n\n        // Model - transform tile space into world space (meters, absolute mercator position)\n        mat4.identity(model);\n        mat4.translate(model, model, vec3.fromValues(this.min.x, this.min.y, 0));\n        mat4.scale(model, model, vec3.fromValues(this.span.x / Geo.tile_scale, -1 * this.span.y / Geo.tile_scale, 1)); // scale tile local coords to meters\n        mat4.copy(model32, model);\n        program.uniform('Matrix4fv', 'u_model', false, model32);\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    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    printDebug () {\n        log.debug(`Tile: debug for ${this.key}: [  ${JSON.stringify(this.debug)} ]`);\n    }\n\n}\n\nTile.coord_children = {}; // only allocate children coordinates once per coordinate\n","import Tile from './tile';\nimport TilePyramid from './tile_pyramid';\n\nimport log from 'loglevel';\n\nconst TileManager = {\n\n    init({ scene, view }) {\n        this.scene = scene;\n        this.view = view;\n        this.tiles = {};\n        this.pyramid = TilePyramid;\n        this.pyramid.reset();\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.pyramid.reset();\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.scene = null;\n        this.view = null;\n    },\n\n    keepTile(tile) {\n        this.tiles[tile.key] = tile;\n        this.pyramid.addTile(tile);\n    },\n\n    hasTile(key) {\n        return this.tiles[key] !== undefined;\n    },\n\n    forgetTile(key) {\n        if (this.hasTile(key)) {\n            let tile = this.tiles[key];\n            this.pyramid.removeTile(tile);\n        }\n\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        let prev_coords = Object.keys(this.visible_coords);\n        this.visible_coords = {};\n        let tile_coords = this.view.findVisibleTileCoordinates();\n        for (let coords of tile_coords) {\n            this.queueCoordinate(coords);\n            this.visible_coords[coords.key] = coords;\n        }\n\n        // Check if visible coords changed\n        // TODO: move to a new view manager object\n        let new_coords = Object.keys(this.visible_coords);\n        let coords_changed = false;\n        if (prev_coords.length !== new_coords.length) {\n            coords_changed = true;\n        }\n        else {\n            prev_coords.sort();\n            new_coords.sort();\n            if (!prev_coords.every((c, i) => new_coords[i] === c)) {\n                coords_changed = true;\n            }\n        }\n\n        this.updateTileStates();\n    },\n\n    updateTileStates () {\n        this.forEachTile(tile => {\n            this.updateVisibility(tile);\n            tile.update();\n        });\n\n        this.loadQueuedCoordinates();\n        this.updateProxyTiles();\n        this.view.pruneTilesForView();\n    },\n\n    updateProxyTiles () {\n        if (this.view.zoom_direction === 0) {\n            return;\n        }\n\n        // Clear previous proxies\n        this.forEachTile(tile => tile.setProxyFor(null));\n\n        let proxy = false;\n        this.forEachTile(tile => {\n            if (this.view.zoom_direction === 1) {\n                if (tile.visible && tile.loading && tile.coords.z > 0) {\n                    let p = this.pyramid.getAncestor(tile);\n                    if (p) {\n                        p.setProxyFor(tile);\n                        proxy = true;\n                    }\n                }\n            }\n            else if (this.view.zoom_direction === -1) {\n                if (tile.visible && tile.loading) {\n                    let d = this.pyramid.getDescendants(tile);\n                    for (let t of d) {\n                        t.setProxyFor(tile);\n                        proxy = true;\n                    }\n                }\n            }\n        });\n\n        if (!proxy) {\n            this.view.zoom_direction = 0;\n        }\n    },\n\n    updateVisibility(tile) {\n        tile.visible = false;\n        if (tile.style_zoom === this.view.tile_zoom) {\n            if (this.visible_coords[tile.coords.key]) {\n                tile.visible = true;\n            }\n            else {\n                // brute force\n                for (let key in this.visible_coords) {\n                    if (Tile.isDescendant(tile.coords, this.visible_coords[key])) {\n                        tile.visible = true;\n                        break;\n                    }\n                }\n            }\n        }\n    },\n\n    // Remove tiles that aren't visible, and flag remaining visible ones to be updated (for loading, proxy, etc.)\n    pruneToVisibleTiles () {\n        this.removeTiles(tile => !tile.visible);\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    isLoadingVisibleTiles() {\n        return Object.keys(this.tiles).some(k => this.tiles[k].visible && this.tiles[k].loading);\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.view.center.tile.x - a.x) + Math.abs(this.view.center.tile.y - a.y);\n            let bd = Math.abs(this.view.center.tile.x - b.x) + Math.abs(this.view.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.view.center.tile.z) {\n            return;\n        }\n\n        // Determine necessary tiles for each source\n        for (let s in this.scene.sources) {\n            let source = this.scene.sources[s];\n            if (!source.tiled || !source.geometry_tiles) {\n                continue;\n            }\n\n            let key = Tile.key(coords, source, this.view.tile_zoom);\n            if (key && !this.hasTile(key)) {\n                let tile = Tile.create({\n                    source,\n                    coords,\n                    worker: this.scene.nextWorker(),\n                    style_zoom: this.view.styleZoom(coords.z),\n                    view: this.view\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();\n        tile.build(this.scene.generation)\n            .then(message => {\n                if (message) { // empty message means tile build was aborted\n                    this.buildTileCompleted(message);\n                }\n            })\n            .catch(e => {\n                log.error(`Error building tile ${tile.key}:`, e);\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.updateTileStates();\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.updateTileStates();\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            tile.buildMeshes(this.scene.styles);\n            this.updateTileStates();\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\nexport default TileManager;\n","import Geo from './geo';\nimport Tile from './tile';\n\nconst TilePyramid = {\n\n    coords: {},\n    max_proxy_descendant_depth: 3, // # of levels deep to search for descendant proxy tiles\n\n    reset() {\n        this.coords = {};\n    },\n\n    sourceTiles(coord, source) {\n        return (\n            this.coords[coord.key] &&\n            this.coords[coord.key].sources &&\n            this.coords[coord.key].sources.get(source.name));\n    },\n\n    addTile(tile) {\n        // Add target tile\n        let key = tile.coords.key;\n        let coord = this.coords[key];\n        if (!coord) {\n            coord = this.coords[key] = { descendants: 0 };\n        }\n\n        if (!coord.sources) {\n            coord.sources = new Map();\n        }\n\n        if (!coord.sources.get(tile.source.name)) {\n            coord.sources.set(tile.source.name, new Map());\n        }\n        coord.sources.get(tile.source.name).set(tile.style_zoom, tile);\n\n        // Increment reference count up the tile pyramid\n        for (let z = tile.coords.z - 1; z >= 0; z--) {\n            let up = Tile.coordinateAtZoom(tile.coords, z);\n            if (!this.coords[up.key]) {\n                this.coords[up.key] = { descendants: 0 };\n            }\n            this.coords[up.key].descendants++;\n        }\n    },\n\n    removeTile(tile) {\n        // Remove target tile\n        let source_tiles = this.sourceTiles(tile.coords, tile.source);\n        let key = tile.coords.key;\n\n        if (source_tiles) {\n            source_tiles.delete(tile.style_zoom);\n            if (source_tiles.size === 0) {\n                // remove source\n                this.coords[key].sources.delete(tile.source.name);\n                if (this.coords[key].sources.size === 0) {\n                    delete this.coords[key].sources;\n\n                    if (this.coords[key].descendants === 0) {\n                        // remove whole coord\n                        delete this.coords[key];\n                    }\n                }\n            }\n        }\n\n        // Decrement reference count up the tile pyramid\n        for (let z = tile.coords.z - 1; z >= 0; z--) {\n            let down = Tile.coordinateAtZoom(tile.coords, z);\n            if (this.coords[down.key] && this.coords[down.key].descendants > 0) {\n                this.coords[down.key].descendants--;\n                if (this.coords[down.key].descendants === 0 && !this.coords[down.key].sources) {\n                    delete this.coords[down.key];\n                }\n            }\n        }\n    },\n\n    getAncestor ({ coords, style_zoom, source }) {\n        // First check overzoomed tiles at same coordinate zoom\n        if (style_zoom > source.max_zoom) {\n            let source_tiles = this.sourceTiles(coords, source);\n            if (source_tiles) {\n                for (let z = style_zoom - 1; z >= source.max_zoom; z--) {\n                    if (source_tiles.has(z) && source_tiles.get(z).loaded) {\n                        return source_tiles.get(z);\n                    }\n                }\n            }\n            style_zoom = source.max_zoom;\n        }\n\n        // Check tiles at next zoom up\n        style_zoom--;\n        let parent = Tile.coordinateAtZoom(coords, coords.z - 1);\n        let parent_tiles = this.sourceTiles(parent, source);\n        if (parent_tiles && parent_tiles.has(style_zoom) && parent_tiles.get(style_zoom).loaded) {\n            return parent_tiles.get(style_zoom);\n        }\n        // didn't find ancestor, try next level\n        // TODO: max depth levels to check\n        if (parent.z > 0) {\n            return this.getAncestor({ coords: parent, style_zoom, source });\n        }\n    },\n\n    getDescendants ({ coords, style_zoom, source }, level = 1) {\n        let descendants = [];\n\n        // First check overzoomed tiles at same coordinate zoom\n        if (style_zoom >= source.max_zoom) {\n            let source_tiles = this.sourceTiles(coords, source);\n            if (source_tiles) {\n                let search_max_zoom = Math.max(Geo.default_view_max_zoom, style_zoom + this.max_proxy_descendant_depth);\n                for (let z = style_zoom + 1; z <= search_max_zoom; z++) {\n                    if (source_tiles.has(z) && source_tiles.get(z).loaded) {\n                        descendants.push(source_tiles.get(z));\n                        return descendants;\n                    }\n                }\n            }\n            return descendants;\n        }\n\n        // Check tiles at next zoom down\n        if (this.coords[coords.key] && this.coords[coords.key].descendants > 0) {\n            style_zoom++;\n            for (let child of Tile.childrenForCoordinate(coords)) {\n                let child_tiles = this.sourceTiles(child, source);\n                if (child_tiles && child_tiles.has(style_zoom) && child_tiles.get(style_zoom).loaded) {\n                    descendants.push(child_tiles.get(style_zoom));\n                }\n                // didn't find child, try next level\n                else if (level <= this.max_proxy_descendant_depth && child.z <= source.max_zoom) {\n                    descendants.push(...this.getDescendants({ coords: child, source, style_zoom }, level + 1));\n                }\n            }\n        }\n\n        return descendants;\n    }\n\n};\n\nexport default TilePyramid;\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","// Partial import of gl-matrix via modularized stack-gl forks\n// https://github.com/toji/gl-matrix\n// https://github.com/stackgl\n\n// vec3\n\n// Substitute 64-bit version\n// We need the extra precision when multiplying matrices w/mercator projected values\nconst vec3 = {\n    fromValues (x, y, z) {\n        var out = new Float64Array(3);\n        out[0] = x;\n        out[1] = y;\n        out[2] = z;\n        return out;\n    }\n};\n\n\n// mat3\n\nimport {default as mat3_normalFromMat4} from 'gl-mat3/normal-from-mat4';\nimport {default as mat3_invert} from 'gl-mat3/invert';\n\nconst mat3 = {\n    normalFromMat4: mat3_normalFromMat4,\n    invert: mat3_invert\n};\n\n\n// mat4\n\nimport {default as mat4_multiply} from 'gl-mat4/multiply';\nimport {default as mat4_translate} from 'gl-mat4/translate';\nimport {default as mat4_scale} from 'gl-mat4/scale';\nimport {default as mat4_perspective} from 'gl-mat4/perspective';\nimport {default as mat4_lookAt} from 'gl-mat4/lookAt';\nimport {default as mat4_identity} from 'gl-mat4/identity';\nimport {default as mat4_copy} from 'gl-mat4/copy';\n\nconst mat4 = {\n    multiply: mat4_multiply,\n    translate: mat4_translate,\n    scale: mat4_scale,\n    perspective: mat4_perspective,\n    lookAt: mat4_lookAt,\n    identity: mat4_identity,\n    copy: mat4_copy\n};\n\n\nexport {vec3, mat3, mat4};\n","// Deep/recursive merge of one or more source objects into a destination object\nexport default function mergeObjects (dest, ...sources) {\n    for (let s=0; s < sources.length; s++) {\n        let source = sources[s];\n        if (!source) {\n            continue;\n        }\n        for (let key in source) {\n            let value = source[key];\n            // Recursively merge the source into the destination if it is a a non-null key/value object\n            // (e.g. don't merge arrays, those are treated as scalar values; null values will overwrite/erase\n            // the previous destination value)\n            if (value !== null && typeof value === 'object' && !Array.isArray(value)) {\n                dest[key] = mergeObjects(dest[key] || {}, value);\n            }\n            // Overwrite the previous destination value if the source property is: a scalar (number/string),\n            // an array, or a null value\n            else if (value !== undefined) {\n                dest[key] = value;\n            }\n            // Undefined source properties are ignored\n        }\n\n    }\n    return dest;\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 && 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    if (url.indexOf('?') > -1) {\n        url += '&' + (+new Date());\n    }\n    else {\n        url += '?' + (+new Date());\n    }\n    return url;\n};\n\n// Add a set of query string params to a URL\n// params: hash of key/value pairs of query string parameters\nUtils.addParamsToURL = function (url, params) {\n    if (!params || Object.keys(params).length === 0) {\n        return url;\n    }\n\n    var qs_index = url.indexOf('?');\n    var hash_index = url.indexOf('#');\n\n    // Save and trim hash\n    var hash = '';\n    if (hash_index > -1) {\n        hash = url.slice(hash_index);\n        url = url.slice(0, hash_index);\n    }\n\n    // Start query string\n    if (qs_index === -1) {\n        qs_index = url.length;\n        url += '?';\n    }\n    qs_index++; // advanced past '?'\n\n    // Build query string params\n    var url_params = '';\n    for (var p in params) {\n        url_params += `${p}=${params[p]}&`;\n    }\n\n    // Insert new query string params and restore hash\n    // NOTE: doesn't replace any values already present on query string, just inserts dupe values\n    url = url.slice(0, qs_index) + url_params + url.slice(qs_index) + hash;\n\n    return url;\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        // jsyaml 'json' option allows duplicate keys\n        // Keeping this for backwards compatibility, but should consider migrating to requiring\n        // unique keys, as this is YAML spec. But Tangram ES currently accepts dupe keys as well,\n        // so should consider how best to unify.\n        data = yaml.safeLoad(body, { json: true });\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(JSON.stringify({\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\n// Returns true if display density changed\nUtils.use_high_density_display = true;\nUtils.updateDevicePixelRatio = function () {\n    let prev = Utils.device_pixel_ratio;\n    Utils.device_pixel_ratio = (Utils.use_high_density_display && window.devicePixelRatio) || 1;\n    return Utils.device_pixel_ratio !== prev;\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, transform) {\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, y1, y2;\n\n    // Min bounds\n    if (x <= points[0][0]) {\n        y = points[0][1];\n        if (typeof transform === 'function') {\n            y = transform(y);\n        }\n    }\n    // Max bounds\n    else if (x >= points[points.length-1][0]) {\n        y = points[points.length-1][1];\n        if (typeof transform === 'function') {\n            y = transform(y);\n        }\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                        if (typeof transform === 'function') {\n                            y1 = transform(points[i][1][c]);\n                            y2 = transform(points[i+1][1][c]);\n                            d = y2 - y1;\n                            y[c] = d * (x - x1) / (x2 - x1) + y1;\n                        }\n                        else {\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                }\n                // Single value\n                else {\n                    if (typeof transform === 'function') {\n                        y1 = transform(points[i][1]);\n                        y2 = transform(points[i+1][1]);\n                        d = y2 - y1;\n                        y = d * (x - x1) / (x2 - x1) + y1;\n                    }\n                    else {\n                        d = points[i+1][1] - points[i][1];\n                        y = d * (x - x1) / (x2 - x1) + points[i][1];\n                    }\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.toCSSColor = function (color) {\n    if (color[3] === 1) { // full opacity\n        return `rgb(${color.slice(0, 3).map(c => Math.round(c * 255)).join(', ')})`;\n    }\n    // RGB is between [0, 255] opacity is between [0, 1]\n    return `rgba(${color.map((c, i) => (i < 3 && Math.round(c * 255)) || c).join(', ')})`;\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\nUtils.debounce = function (func, wait, immediate) {\n    let timeout;\n    return function() {\n        let context = this,\n            args = arguments;\n        let later = function() {\n            timeout = null;\n            if (!immediate) {\n                func.apply(context, args);\n            }\n        };\n        let callNow = immediate && !timeout;\n        clearTimeout(timeout);\n        timeout = setTimeout(later, wait);\n        if (callNow) {\n            func.apply(context, args);\n        }\n    };\n};\n","var version;\nexport default version = {\n    get string() { return `v${version.major}.${version.minor}.${version.patch}`; },\n    major: 0,\n    minor: 7,\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, register self as target define a method:\n//\n//     WorkerBroker.addTarget('self', self);\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, 'self.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, 'self.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// Calling from worker to main thread:\n//\n// The same style of calls can be made *from* a web worker, to the main thread. The API is the same\n// with the exception that the first argument, 'worker', is not needed for WorkerBroker.postMessage(),\n// since the main thread is the implicit target.\n//\n// In main thread, define a method and register it:\n//\n//     var geometry = {\n//         length: function(x, y) {\n//             return Math.sqrt(x * x + y * y);\n//         }\n//     };\n//\n//     WorkerBroker.addTarget('geometry', geometry);\n//\n// In worker thread:\n//\n//     WorkerBroker.postMessage('geometry.length', 3, 4).then(function(d) {\n//         console.log(d);\n//     });\n//\n//     -> prints 5\n//\n\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// Register an object to receive calls from other thread\nvar targets = {};\nWorkerBroker.addTarget = function (name, target) {\n    targets[name] = target;\n};\n\n// Given a dot-notation-style method name, e.g. 'Object.object.method',\n// find the object to call the method on from the list of registered targets\nfunction findTarget (method) {\n    var chain = [];\n    if (typeof method === 'string') {\n        chain = method.split('.');\n        method = chain.pop();\n    }\n\n    // target = target || (Utils.isMainThread && window) || (Utils.isWorkerThread && self);\n    var target = targets;\n\n    for (let m=0; m < chain.length; m++) {\n        if (target[chain[m]]) {\n            target = target[chain[m]];\n        }\n        else {\n            return [];\n        }\n    }\n\n    return [method, target];\n}\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: one or more web worker instances to send the message to (single value or array)\n    //   - method: the method with this name, specified with dot-notation, will be invoked in the worker\n    //   - message: will be passed to the method call\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        // If more than one worker specified, post to multiple\n        if (Array.isArray(worker)) {\n            return Promise.all(\n                worker.map(w => WorkerBroker.postMessage(w, method, ...message))\n            );\n        }\n\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(JSON.stringify({\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 = new Map();\n\n    WorkerBroker.addWorker = function (worker) {\n\n        // Keep track of all registered workers\n        workers.set(worker, worker_id++);\n\n        // Listen for messages coming back from the worker, and fulfill that message's promise\n        worker.addEventListener('message', (event) => {\n            let data = maybeDecode(event.data);\n            if (data.type !== 'worker_reply') {\n                return;\n            }\n\n            // Pass the result to the promise\n            var id = data.message_id;\n            if (messages[id]) {\n                if (data.error) {\n                    messages[id].reject(data.error);\n                }\n                else {\n                    messages[id].resolve(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            let data = maybeDecode(event.data);\n\n            // Unique id for this message & return call to main thread\n            var id = data.message_id;\n            if (data.type !== 'worker_send' || id == null) {\n                return;\n            }\n\n            // Call the requested method and save the return value\n            // var target = targets[data.target];\n            var [method_name, target] = findTarget(data.method);\n            if (!target) {\n                throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because no object with that name is registered on main thread`);\n            }\n\n            var method = (typeof target[method_name] === 'function') && target[method_name];\n            if (!method) {\n                throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because object has no method with that name`);\n            }\n\n            var result, error;\n            try {\n                result = method.apply(target, 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            let payload, transferables = [];\n\n            // Async result\n            if (result instanceof Promise) {\n                result.then((value) => {\n                    if (value instanceof WorkerBroker.returnWithTransferables) {\n                        transferables = value.transferables;\n                        value = value.value;\n                    }\n\n                    payload = {\n                        type: 'main_reply',\n                        message_id: id,\n                        message: value\n                    };\n                    payload = maybeEncode(payload, transferables);\n                    worker.postMessage(payload, transferables.map(t => t.object));\n                    freeTransferables(transferables);\n                    // if (transferables.length > 0) {\n                    //     Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to worker thread`);\n                    // }\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                if (result instanceof WorkerBroker.returnWithTransferables) {\n                    transferables = result.transferables;\n                    result = result.value;\n                }\n\n                payload = {\n                    type: 'main_reply',\n                    message_id: id,\n                    message: result,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                };\n                payload = maybeEncode(payload, transferables);\n                worker.postMessage(payload, transferables.map(t => t.object));\n                freeTransferables(transferables);\n                // if (transferables.length > 0) {\n                //     Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to worker thread`);\n                // }\n            }\n        });\n\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    //   - method: the method with this name, specified with dot-notation, will be invoked on the main thread\n    //   - message: will be passed to the method call\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 (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        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            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        let data = maybeDecode(event.data);\n        if (data.type !== 'main_reply') {\n            return;\n        }\n\n        // Pass the result to the promise\n        var id = data.message_id;\n        if (messages[id]) {\n            if (data.error) {\n                messages[id].reject(data.error);\n            }\n            else {\n                messages[id].resolve(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        let data = maybeDecode(event.data);\n\n        // Unique id for this message & return call to main thread\n        var id = data.message_id;\n        if (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, target] = findTarget(data.method);\n        if (!target) {\n            throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because no object with that name is registered on main thread`);\n        }\n\n        var method = (typeof target[method_name] === 'function') && target[method_name];\n\n        if (!method) {\n            throw Error(`Worker broker could not dispatch message type ${data.method} because worker has no method with that name`);\n        }\n\n        var result, error;\n        try {\n            result = method.apply(target, 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 payload, transferables = [];\n\n        // Async result\n        if (result instanceof Promise) {\n            result.then((value) => {\n                if (value instanceof WorkerBroker.returnWithTransferables) {\n                    transferables = value.transferables;\n                    value = value.value;\n                }\n\n                payload = {\n                    type: 'worker_reply',\n                    message_id: id,\n                    message: value\n                };\n                payload = maybeEncode(payload, transferables);\n                self.postMessage(payload, transferables.map(t => t.object));\n                freeTransferables(transferables);\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            if (result instanceof WorkerBroker.returnWithTransferables) {\n                transferables = result.transferables;\n                result = result.value;\n            }\n\n            payload = {\n                type: 'worker_reply',\n                message_id: id,\n                message: result,\n                error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n            };\n            payload = maybeEncode(payload, transferables);\n            self.postMessage(payload, transferables.map(t => t.object));\n            freeTransferables(transferables);\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// Special return value wrapper, to indicate that we want to find and include\n// transferable objects in the response message\nWorkerBroker.returnWithTransferables = function (value) {\n    if (!(this instanceof WorkerBroker.returnWithTransferables)) {\n        return new WorkerBroker.returnWithTransferables(value);\n    }\n\n    this.value = value;\n    this.transferables = findTransferables(this.value);\n};\n\n// Build a list of transferable objects from a source object\n// Returns a list of info about each transferable:\n//   - object: the actual transferable object\n//   - parent: the parent object that the transferable is a property of (if any)\n//   - property: the property name of the transferable on the parent object (if any)\n// TODO: add option in case you DON'T want to transfer objects\nfunction findTransferables(source, parent = null, property = null, list = []) {\n    if (!source) {\n         return list;\n    }\n\n    if (Array.isArray(source)) {\n        // Check each array element\n        source.forEach((x, i) => findTransferables(x, source, i, list));\n    }\n    else if (typeof source === 'object') {\n        // Is the object a transferable array buffer?\n        if (source instanceof ArrayBuffer) {\n            list.push({ object: source, parent, property });\n        }\n        // Or looks like a typed array (has an array buffer property)?\n        else if (source.buffer instanceof ArrayBuffer) {\n            list.push({ object: source.buffer, parent, property });\n        }\n        // Otherwise check each property\n        else {\n            for (let prop in source) {\n                findTransferables(source[prop], source, prop, list);\n            }\n        }\n    }\n    return list;\n}\n\n// Remove neutered transferables from parent objects, as they should no longer be accessed after transfer\nfunction freeTransferables(transferables) {\n    if (!Array.isArray(transferables)) {\n        return;\n    }\n    transferables.filter(t => t.parent && t.property).forEach(t => delete t.parent[t.property]);\n}\n\n// Message payload can be stringified for faster transfer, if it does not include transferable objects\nfunction maybeEncode (payload, transferables) {\n    if (transferables.length === 0) {\n        payload = JSON.stringify(payload);\n    }\n    return payload;\n}\n\n// Parse stringified message payload\nfunction maybeDecode (data) {\n    return (typeof data === 'string' ? JSON.parse(data) : data);\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 c = Math.cos(a);\n    var s = Math.sin(a);\n    return [v[0] * c - v[1] * s,\n            v[0] * s + v[1] * c];\n};\n\n// Get 2D heading angle\nVector.angle = function ([x, y]) {\n    return Math.atan2(y,x);\n};\n\n// Get angle between two vectors\nVector.angleBetween = function(A, B){\n    var delta = Vector.dot(A, B);\n    if (delta < -1) {\n        delta = -1;\n    }\n    return Math.acos(delta);\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","import Geo from './geo';\nimport Tile from './tile';\nimport Camera from './camera';\nimport Utils from './utils/utils';\nimport subscribeMixin from './utils/subscribe';\n\nimport log from 'loglevel';\n\nexport default class View {\n\n    constructor (scene, options) {\n        subscribeMixin(this);\n\n        this.scene = scene;\n        this.createMatrices();\n\n        this.zoom = null;\n        this.center = null;\n        this.bounds = null;\n        this.meters_per_pixel = null;\n\n        this.panning = false;\n        this.zooming = false;\n        this.zoom_direction = 0;\n\n        // Size of viewport in CSS pixels, device pixels, and mercator meters\n        this.size = {\n            css: {},\n            device: {},\n            meters: {}\n        };\n        this.aspect = null;\n\n        this.buffer = 0;\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.preserve_tiles_within_zoom = 1;\n\n        this.reset();\n    }\n\n    // Reset state before scene config is updated\n    reset () {\n        this.createCamera();\n    }\n\n    // Create camera\n    createCamera () {\n        let active_camera = this.getActiveCamera();\n        if (active_camera) {\n            this.camera = Camera.create(active_camera, this, this.scene.config.cameras[active_camera]);\n            this.camera.updateView();\n        }\n    }\n\n    // Get active camera - for public API\n    getActiveCamera () {\n        if (this.scene.config && this.scene.config.cameras) {\n            for (let name in this.scene.config.cameras) {\n                if (this.scene.config.cameras[name].active) {\n                    return name;\n                }\n            }\n        }\n    }\n\n    // Set active camera and recompile - for public API\n    setActiveCamera (name) {\n        let prev = this.getActiveCamera();\n        if (this.scene.config.cameras[name]) {\n            this.scene.config.cameras[name].active = true;\n\n            // Clear previously active camera\n            if (prev && prev !== name && this.scene.config.cameras[prev]) {\n                delete this.scene.config.cameras[prev].active;\n            }\n        }\n\n        this.scene.updateConfig();\n        return this.getActiveCamera();\n    }\n\n    // Update method called once per frame\n    update () {\n        this.camera.update();\n    }\n\n    // Set logical pixel size of viewport\n    setViewportSize (width, height) {\n        this.size.css = { width, height };\n        this.size.device = {\n            width: Math.round(this.size.css.width * Utils.device_pixel_ratio),\n            height: Math.round(this.size.css.height * Utils.device_pixel_ratio)\n        };\n        this.aspect = this.size.css.width / this.size.css.height;\n        this.updateBounds();\n    }\n\n    // Set the map view, can be passed an object with lat/lng and/or zoom\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    setZoom (zoom) {\n        if (this.zooming) {\n            this.zooming = false;\n        }\n        else {\n            this.last_zoom = this.zoom;\n        }\n\n        let last_tile_zoom = this.tile_zoom;\n        let tile_zoom = this.tileZoom(zoom);\n        if (!this.continuous_zoom) {\n            zoom = tile_zoom;\n        }\n\n        if (tile_zoom !== last_tile_zoom) {\n            this.zoom_direction = tile_zoom > last_tile_zoom ? 1 : -1;\n        }\n\n        this.last_zoom = this.zoom;\n        this.zoom = zoom;\n        this.tile_zoom = tile_zoom;\n\n        this.updateBounds();\n        this.scene.requestRedraw();\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    ready () {\n        // TODO: better concept of \"readiness\" state?\n        if (this.size.css == null || this.center == null || this.zoom == null) {\n             return false;\n        }\n        return true;\n    }\n\n    // Calculate viewport bounds based on current center and zoom\n    updateBounds () {\n        if (!this.ready()) {\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.size.meters = {\n            x: this.size.css.width * this.meters_per_pixel,\n            y: this.size.css.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        this.center.tile = Geo.tileForMeters([this.center.meters.x, this.center.meters.y], this.tile_zoom);\n\n        // Bounds in meters\n        this.bounds = {\n            sw: {\n                x: this.center.meters.x - this.size.meters.x / 2,\n                y: this.center.meters.y - this.size.meters.y / 2\n            },\n            ne: {\n                x: this.center.meters.x + this.size.meters.x / 2,\n                y: this.center.meters.y + this.size.meters.y / 2\n            }\n        };\n\n        this.scene.tile_manager.updateTilesForView();\n\n        this.trigger('move');\n        this.scene.requestRedraw(); // TODO automate via move event?\n    }\n\n    findVisibleTileCoordinates () {\n        if (!this.bounds) {\n            return [];\n        }\n\n        let z = this.tile_zoom;\n        let sw = Geo.tileForMeters([this.bounds.sw.x, this.bounds.sw.y], z);\n        let ne = Geo.tileForMeters([this.bounds.ne.x, this.bounds.ne.y], z);\n\n        let coords = [];\n        for (let x = sw.x - this.buffer; x <= ne.x + this.buffer; x++) {\n            for (let y = ne.y - this.buffer; y <= sw.y + this.buffer; y++) {\n                coords.push(Tile.coord({ x, y, z }));\n            }\n        }\n        return coords;\n    }\n\n    // Remove tiles too far outside of view\n    pruneTilesForView () {\n        // TODO: will this function ever be called when view isn't ready?\n        if (!this.ready()) {\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.size.css.width / Geo.tile_size) + 2) / 2),\n            Math.ceil((Math.floor(this.size.css.height / Geo.tile_size) + 2) / 2)\n        ];\n\n        this.scene.tile_manager.removeTiles(tile => {\n            // Ignore visible tiles\n            if (tile.visible || tile.proxy) {\n                return false;\n            }\n\n            // Remove tiles outside given zoom that are still loading\n            if (tile.loading && tile.style_zoom !== this.tile_zoom) {\n                return true;\n            }\n\n            // Discard if too far from current zoom\n            let zdiff = Math.abs(tile.style_zoom - this.tile_zoom);\n            if (zdiff > this.preserve_tiles_within_zoom) {\n                return true;\n            }\n\n            // Handle tiles at different zooms\n            let coords = Tile.coordinateAtZoom(tile.coords, this.tile_zoom);\n\n            // Discard tiles outside an area surrounding the viewport\n            if (Math.abs(coords.x - this.center.tile.x) - border_tiles[0] > this.buffer) {\n                log.trace(`View: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${this.tile_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] > this.buffer) {\n                log.trace(`View: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${this.tile_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            return false;\n        });\n    }\n\n    // Allocate model-view matrices\n    // 64-bit versions are for CPU calcuations\n    // 32-bit versions are downsampled and sent to GPU\n    createMatrices () {\n        this.matrices = {};\n        this.matrices.model = new Float64Array(16);\n        this.matrices.model32 = new Float32Array(16);\n        this.matrices.model_view = new Float64Array(16);\n        this.matrices.model_view32 = new Float32Array(16);\n        this.matrices.normal = new Float64Array(9);\n        this.matrices.normal32 = new Float32Array(9);\n        this.matrices.inverse_normal32 = new Float32Array(9);\n    }\n\n    // Calculate and set model/view and normal matrices for a tile\n    setupTile (tile, program) {\n        // Tile-specific state\n        // TODO: calc these once per tile (currently being needlessly re-calculated per-tile-per-style)\n        tile.setupProgram(this.matrices, program);\n\n        // Model-view and normal matrices\n        this.camera.setupMatrices(this.matrices, program);\n    }\n\n    // Set general uniforms that must be updated once per program\n    setupProgram (program) {\n        program.uniform('2f', 'u_resolution', this.size.device.width, this.size.device.height);\n        program.uniform('3f', 'u_map_position', this.center.meters.x, this.center.meters.y, this.zoom);\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        this.camera.setupProgram(program);\n    }\n\n}\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/babel-runtime/core-js/array/from.js","node_modules/babel-runtime/core-js/get-iterator.js","node_modules/babel-runtime/core-js/is-iterable.js","node_modules/babel-runtime/core-js/map.js","node_modules/babel-runtime/core-js/math/log2.js","node_modules/babel-runtime/core-js/object/assign.js","node_modules/babel-runtime/core-js/object/create.js","node_modules/babel-runtime/core-js/object/define-properties.js","node_modules/babel-runtime/core-js/object/define-property.js","node_modules/babel-runtime/core-js/object/freeze.js","node_modules/babel-runtime/core-js/object/get-own-property-descriptor.js","node_modules/babel-runtime/core-js/object/keys.js","node_modules/babel-runtime/core-js/object/set-prototype-of.js","node_modules/babel-runtime/core-js/promise.js","node_modules/babel-runtime/core-js/set.js","node_modules/babel-runtime/core-js/symbol.js","node_modules/babel-runtime/core-js/symbol/iterator.js","node_modules/babel-runtime/helpers/class-call-check.js","node_modules/babel-runtime/helpers/create-class.js","node_modules/babel-runtime/helpers/define-property.js","node_modules/babel-runtime/helpers/get.js","node_modules/babel-runtime/helpers/inherits.js","node_modules/babel-runtime/helpers/interop-require-default.js","node_modules/babel-runtime/helpers/sliced-to-array.js","node_modules/babel-runtime/helpers/to-consumable-array.js","node_modules/babel-runtime/regenerator/index.js","node_modules/babel-runtime/regenerator/runtime.js","node_modules/base64-js/lib/b64.js","node_modules/bit-twiddle/twiddle.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/browser-resolve/empty.js","node_modules/buffer/index.js","node_modules/core-js/library/fn/array/from.js","node_modules/core-js/library/fn/get-iterator.js","node_modules/core-js/library/fn/is-iterable.js","node_modules/core-js/library/fn/map.js","node_modules/core-js/library/fn/math/log2.js","node_modules/core-js/library/fn/object/assign.js","node_modules/core-js/library/fn/object/create.js","node_modules/core-js/library/fn/object/define-properties.js","node_modules/core-js/library/fn/object/define-property.js","node_modules/core-js/library/fn/object/freeze.js","node_modules/core-js/library/fn/object/get-own-property-descriptor.js","node_modules/core-js/library/fn/object/keys.js","node_modules/core-js/library/fn/object/set-prototype-of.js","node_modules/core-js/library/fn/promise.js","node_modules/core-js/library/fn/set.js","node_modules/core-js/library/fn/symbol/index.js","node_modules/core-js/library/fn/symbol/iterator.js","node_modules/core-js/library/modules/$.a-function.js","node_modules/core-js/library/modules/$.add-to-unscopables.js","node_modules/core-js/library/modules/$.an-object.js","node_modules/core-js/library/modules/$.classof.js","node_modules/core-js/library/modules/$.cof.js","node_modules/core-js/library/modules/$.collection-strong.js","node_modules/core-js/library/modules/$.collection-to-json.js","node_modules/core-js/library/modules/$.collection.js","node_modules/core-js/library/modules/$.core.js","node_modules/core-js/library/modules/$.ctx.js","node_modules/core-js/library/modules/$.defined.js","node_modules/core-js/library/modules/$.descriptors.js","node_modules/core-js/library/modules/$.dom-create.js","node_modules/core-js/library/modules/$.enum-keys.js","node_modules/core-js/library/modules/$.export.js","node_modules/core-js/library/modules/$.fails.js","node_modules/core-js/library/modules/$.for-of.js","node_modules/core-js/library/modules/$.get-names.js","node_modules/core-js/library/modules/$.global.js","node_modules/core-js/library/modules/$.has.js","node_modules/core-js/library/modules/$.hide.js","node_modules/core-js/library/modules/$.html.js","node_modules/core-js/library/modules/$.invoke.js","node_modules/core-js/library/modules/$.iobject.js","node_modules/core-js/library/modules/$.is-array-iter.js","node_modules/core-js/library/modules/$.is-array.js","node_modules/core-js/library/modules/$.is-object.js","node_modules/core-js/library/modules/$.iter-call.js","node_modules/core-js/library/modules/$.iter-create.js","node_modules/core-js/library/modules/$.iter-define.js","node_modules/core-js/library/modules/$.iter-detect.js","node_modules/core-js/library/modules/$.iter-step.js","node_modules/core-js/library/modules/$.iterators.js","node_modules/core-js/library/modules/$.js","node_modules/core-js/library/modules/$.keyof.js","node_modules/core-js/library/modules/$.library.js","node_modules/core-js/library/modules/$.microtask.js","node_modules/core-js/library/modules/$.object-assign.js","node_modules/core-js/library/modules/$.object-sap.js","node_modules/core-js/library/modules/$.property-desc.js","node_modules/core-js/library/modules/$.redefine-all.js","node_modules/core-js/library/modules/$.redefine.js","node_modules/core-js/library/modules/$.same-value.js","node_modules/core-js/library/modules/$.set-proto.js","node_modules/core-js/library/modules/$.set-species.js","node_modules/core-js/library/modules/$.set-to-string-tag.js","node_modules/core-js/library/modules/$.shared.js","node_modules/core-js/library/modules/$.species-constructor.js","node_modules/core-js/library/modules/$.strict-new.js","node_modules/core-js/library/modules/$.string-at.js","node_modules/core-js/library/modules/$.task.js","node_modules/core-js/library/modules/$.to-integer.js","node_modules/core-js/library/modules/$.to-iobject.js","node_modules/core-js/library/modules/$.to-length.js","node_modules/core-js/library/modules/$.to-object.js","node_modules/core-js/library/modules/$.uid.js","node_modules/core-js/library/modules/$.wks.js","node_modules/core-js/library/modules/core.get-iterator-method.js","node_modules/core-js/library/modules/core.get-iterator.js","node_modules/core-js/library/modules/core.is-iterable.js","node_modules/core-js/library/modules/es6.array.from.js","node_modules/core-js/library/modules/es6.array.iterator.js","node_modules/core-js/library/modules/es6.map.js","node_modules/core-js/library/modules/es6.math.log2.js","node_modules/core-js/library/modules/es6.object.assign.js","node_modules/core-js/library/modules/es6.object.freeze.js","node_modules/core-js/library/modules/es6.object.get-own-property-descriptor.js","node_modules/core-js/library/modules/es6.object.keys.js","node_modules/core-js/library/modules/es6.object.set-prototype-of.js","node_modules/core-js/library/modules/es6.promise.js","node_modules/core-js/library/modules/es6.set.js","node_modules/core-js/library/modules/es6.string.iterator.js","node_modules/core-js/library/modules/es6.symbol.js","node_modules/core-js/library/modules/es7.map.to-json.js","node_modules/core-js/library/modules/es7.set.to-json.js","node_modules/core-js/library/modules/web.dom.iterable.js","node_modules/csscolorparser/csscolorparser.js","node_modules/dup/dup.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-mat3/invert.js","node_modules/gl-mat3/normal-from-mat4.js","node_modules/gl-mat4/copy.js","node_modules/gl-mat4/identity.js","node_modules/gl-mat4/lookAt.js","node_modules/gl-mat4/multiply.js","node_modules/gl-mat4/perspective.js","node_modules/gl-mat4/scale.js","node_modules/gl-mat4/translate.js","node_modules/gl-shader-errors/index.js","node_modules/ieee754/index.js","node_modules/is-array/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/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/loglevel/lib/loglevel.js","node_modules/match-feature/index.js","node_modules/pbf/buffer.js","node_modules/pbf/index.js","node_modules/point-geometry/index.js","node_modules/process/browser.js","node_modules/strip-comments/index.js","node_modules/topojson/topojson.js","node_modules/typedarray-pool/pool.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","/Users/bcamper/Documents/dev/vector-map/src/builders/common.js","/Users/bcamper/Documents/dev/vector-map/src/builders/points.js","/Users/bcamper/Documents/dev/vector-map/src/builders/polygons.js","/Users/bcamper/Documents/dev/vector-map/src/builders/polylines.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/labels/collision.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label_line.js","/Users/bcamper/Documents/dev/vector-map/src/labels/label_point.js","/Users/bcamper/Documents/dev/vector-map/src/labels/repeat_group.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/raster.js","/Users/bcamper/Documents/dev/vector-map/src/sources/topojson.js","/Users/bcamper/Documents/dev/vector-map/src/styles/lines/lines.js","/Users/bcamper/Documents/dev/vector-map/src/styles/points/point_anchor.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/raster/raster.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/canvas_text.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text.js","/Users/bcamper/Documents/dev/vector-map/src/styles/text/text_settings.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/tile_pyramid.js","/Users/bcamper/Documents/dev/vector-map/src/utils/errors.js","/Users/bcamper/Documents/dev/vector-map/src/utils/gl-matrix.js","/Users/bcamper/Documents/dev/vector-map/src/utils/merge.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","/Users/bcamper/Documents/dev/vector-map/src/view.js"],"names":[],"mappings":"AAAA;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;;ACAA;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;;ACvBA;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;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;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;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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/HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;ACFA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;;ACDA;AACA;;ACDA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;;ACDA;AACA;AACA;AACA;AACA;;ACJA;AACA;;ACDA;AACA;;ACDA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;;ACHA;;ACAA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;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;;ACnBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;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;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;;ACFA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;;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;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;;ACJA;;ACAA;AACA;AACA;AACA;;ACHA;AACA;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;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;ACLA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;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;;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;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClOA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;;ACHA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AClIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;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;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;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;;AC7BA;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;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;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;;;;;;;;;;;;mBC5DgB,QAAQ;;;;AAEjB,IAAM,WAAW,GAAG,CACvB,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,EACb,EAAE,CAAC,EAAE,iBAAI,UAAU,EAAE,CAAC,EAAE,CAAC,iBAAI,UAAU,EAAE;CAC5C,CAAC;;;AAEK,IAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;;;;;;AAIjC,SAA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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})","module.exports = { \"default\": require(\"core-js/library/fn/array/from\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/get-iterator\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/is-iterable\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/map\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/math/log2\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/assign\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/create\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/define-properties\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/define-property\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/freeze\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/get-own-property-descriptor\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/keys\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/object/set-prototype-of\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/promise\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/set\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/symbol\"), __esModule: true };","module.exports = { \"default\": require(\"core-js/library/fn/symbol/iterator\"), __esModule: true };","\"use strict\";\n\nexports[\"default\"] = function (instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$defineProperty = require(\"babel-runtime/core-js/object/define-property\")[\"default\"];\n\nexports[\"default\"] = (function () {\n  function defineProperties(target, props) {\n    for (var i = 0; i < props.length; i++) {\n      var descriptor = props[i];\n      descriptor.enumerable = descriptor.enumerable || false;\n      descriptor.configurable = true;\n      if (\"value\" in descriptor) descriptor.writable = true;\n\n      _Object$defineProperty(target, descriptor.key, descriptor);\n    }\n  }\n\n  return function (Constructor, protoProps, staticProps) {\n    if (protoProps) defineProperties(Constructor.prototype, protoProps);\n    if (staticProps) defineProperties(Constructor, staticProps);\n    return Constructor;\n  };\n})();\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$defineProperty = require(\"babel-runtime/core-js/object/define-property\")[\"default\"];\n\nexports[\"default\"] = function (obj, key, value) {\n  if (key in obj) {\n    _Object$defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$getOwnPropertyDescriptor = require(\"babel-runtime/core-js/object/get-own-property-descriptor\")[\"default\"];\n\nexports[\"default\"] = function get(_x, _x2, _x3) {\n  var _again = true;\n\n  _function: while (_again) {\n    var object = _x,\n        property = _x2,\n        receiver = _x3;\n    _again = false;\n    if (object === null) object = Function.prototype;\n\n    var desc = _Object$getOwnPropertyDescriptor(object, property);\n\n    if (desc === undefined) {\n      var parent = Object.getPrototypeOf(object);\n\n      if (parent === null) {\n        return undefined;\n      } else {\n        _x = parent;\n        _x2 = property;\n        _x3 = receiver;\n        _again = true;\n        desc = parent = undefined;\n        continue _function;\n      }\n    } else if (\"value\" in desc) {\n      return desc.value;\n    } else {\n      var getter = desc.get;\n\n      if (getter === undefined) {\n        return undefined;\n      }\n\n      return getter.call(receiver);\n    }\n  }\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Object$setPrototypeOf = require(\"babel-runtime/core-js/object/set-prototype-of\")[\"default\"];\n\nexports[\"default\"] = function (subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n  }\n\n  subClass.prototype = _Object$create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) _Object$setPrototypeOf ? _Object$setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nexports.__esModule = true;","\"use strict\";\n\nexports[\"default\"] = function (obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n};\n\nexports.__esModule = true;","\"use strict\";\n\nvar _getIterator = require(\"babel-runtime/core-js/get-iterator\")[\"default\"];\n\nvar _isIterable = require(\"babel-runtime/core-js/is-iterable\")[\"default\"];\n\nexports[\"default\"] = (function () {\n  function sliceIterator(arr, i) {\n    var _arr = [];\n    var _n = true;\n    var _d = false;\n    var _e = undefined;\n\n    try {\n      for (var _i = _getIterator(arr), _s; !(_n = (_s = _i.next()).done); _n = true) {\n        _arr.push(_s.value);\n\n        if (i && _arr.length === i) break;\n      }\n    } catch (err) {\n      _d = true;\n      _e = err;\n    } finally {\n      try {\n        if (!_n && _i[\"return\"]) _i[\"return\"]();\n      } finally {\n        if (_d) throw _e;\n      }\n    }\n\n    return _arr;\n  }\n\n  return function (arr, i) {\n    if (Array.isArray(arr)) {\n      return arr;\n    } else if (_isIterable(Object(arr))) {\n      return sliceIterator(arr, i);\n    } else {\n      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n    }\n  };\n})();\n\nexports.__esModule = true;","\"use strict\";\n\nvar _Array$from = require(\"babel-runtime/core-js/array/from\")[\"default\"];\n\nexports[\"default\"] = function (arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n    return arr2;\n  } else {\n    return _Array$from(arr);\n  }\n};\n\nexports.__esModule = true;","(function (global){\n// This method of obtaining a reference to the global object needs to be\n// kept identical to the way it is obtained in runtime.js\nvar g =\n  typeof global === \"object\" ? global :\n  typeof window === \"object\" ? window :\n  typeof self === \"object\" ? self : this;\n\n// Use `getOwnPropertyNames` because not all browsers support calling\n// `hasOwnProperty` on the global `self` object in a worker. See #183.\nvar hadRuntime = g.regeneratorRuntime &&\n  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n// Save the old regeneratorRuntime in case it needs to be restored later.\nvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n// Force reevalutation of runtime.js.\ng.regeneratorRuntime = undefined;\n\nmodule.exports = require(\"./runtime\");\n\nif (hadRuntime) {\n  // Restore the original runtime.\n  g.regeneratorRuntime = oldRuntime;\n} else {\n  // Remove the global property added by runtime.js.\n  try {\n    delete g.regeneratorRuntime;\n  } catch(e) {\n    g.regeneratorRuntime = undefined;\n  }\n}\n\nmodule.exports = { \"default\": module.exports, __esModule: true };\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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9iYWJlbC1ydW50aW1lL3JlZ2VuZXJhdG9yL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBtZXRob2Qgb2Ygb2J0YWluaW5nIGEgcmVmZXJlbmNlIHRvIHRoZSBnbG9iYWwgb2JqZWN0IG5lZWRzIHRvIGJlXG4vLyBrZXB0IGlkZW50aWNhbCB0byB0aGUgd2F5IGl0IGlzIG9idGFpbmVkIGluIHJ1bnRpbWUuanNcbnZhciBnID1cbiAgdHlwZW9mIGdsb2JhbCA9PT0gXCJvYmplY3RcIiA/IGdsb2JhbCA6XG4gIHR5cGVvZiB3aW5kb3cgPT09IFwib2JqZWN0XCIgPyB3aW5kb3cgOlxuICB0eXBlb2Ygc2VsZiA9PT0gXCJvYmplY3RcIiA/IHNlbGYgOiB0aGlzO1xuXG4vLyBVc2UgYGdldE93blByb3BlcnR5TmFtZXNgIGJlY2F1c2Ugbm90IGFsbCBicm93c2VycyBzdXBwb3J0IGNhbGxpbmdcbi8vIGBoYXNPd25Qcm9wZXJ0eWAgb24gdGhlIGdsb2JhbCBgc2VsZmAgb2JqZWN0IGluIGEgd29ya2VyLiBTZWUgIzE4My5cbnZhciBoYWRSdW50aW1lID0gZy5yZWdlbmVyYXRvclJ1bnRpbWUgJiZcbiAgT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMoZykuaW5kZXhPZihcInJlZ2VuZXJhdG9yUnVudGltZVwiKSA+PSAwO1xuXG4vLyBTYXZlIHRoZSBvbGQgcmVnZW5lcmF0b3JSdW50aW1lIGluIGNhc2UgaXQgbmVlZHMgdG8gYmUgcmVzdG9yZWQgbGF0ZXIuXG52YXIgb2xkUnVudGltZSA9IGhhZFJ1bnRpbWUgJiYgZy5yZWdlbmVyYXRvclJ1bnRpbWU7XG5cbi8vIEZvcmNlIHJlZXZhbHV0YXRpb24gb2YgcnVudGltZS5qcy5cbmcucmVnZW5lcmF0b3JSdW50aW1lID0gdW5kZWZpbmVkO1xuXG5tb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCIuL3J1bnRpbWVcIik7XG5cbmlmIChoYWRSdW50aW1lKSB7XG4gIC8vIFJlc3RvcmUgdGhlIG9yaWdpbmFsIHJ1bnRpbWUuXG4gIGcucmVnZW5lcmF0b3JSdW50aW1lID0gb2xkUnVudGltZTtcbn0gZWxzZSB7XG4gIC8vIFJlbW92ZSB0aGUgZ2xvYmFsIHByb3BlcnR5IGFkZGVkIGJ5IHJ1bnRpbWUuanMuXG4gIHRyeSB7XG4gICAgZGVsZXRlIGcucmVnZW5lcmF0b3JSdW50aW1lO1xuICB9IGNhdGNoKGUpIHtcbiAgICBnLnJlZ2VuZXJhdG9yUnVudGltZSA9IHVuZGVmaW5lZDtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHsgXCJkZWZhdWx0XCI6IG1vZHVsZS5leHBvcnRzLCBfX2VzTW9kdWxlOiB0cnVlIH07XG4iXX0=","(function (process,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\"use strict\";\n\nvar _Symbol = require(\"babel-runtime/core-js/symbol\")[\"default\"];\n\nvar _Symbol$iterator = require(\"babel-runtime/core-js/symbol/iterator\")[\"default\"];\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Promise = require(\"babel-runtime/core-js/promise\")[\"default\"];\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 = 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    // If outerFn provided, then outerFn.prototype instanceof Generator.\n    var generator = _Object$create((outerFn || Generator).prototype);\n\n    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n    return generator;\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 Generator() {}\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  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n      prototype[method] = function (arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function (genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor ? 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\" : false;\n  };\n\n  runtime.mark = function (genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = _Object$create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `value instanceof AwaitArgument` to determine if the yielded value is\n  // meant to be awaited. Some may consider the name of this method too\n  // cutesy, but they are curmudgeons.\n  runtime.awrap = function (arg) {\n    return new AwaitArgument(arg);\n  };\n\n  function AwaitArgument(arg) {\n    this.arg = arg;\n  }\n\n  function AsyncIterator(generator) {\n    // This invoke function is written in a style that assumes some\n    // calling function (or Promise) will handle exceptions.\n    function invoke(method, arg) {\n      var result = generator[method](arg);\n      var value = result.value;\n      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n        // When a yielded Promise is resolved, its final value becomes\n        // the .value of the Promise<{value,done}> result for the\n        // current iteration. If the Promise is rejected, however, the\n        // result for this iteration will be rejected with the same\n        // reason. Note that rejections of yielded Promises are not\n        // thrown back into the generator function, as is the case\n        // when an awaited Promise is rejected. This difference in\n        // behavior between yield and await is important, because it\n        // allows the consumer to decide what to do with the yielded\n        // rejection (swallow it and continue, manually .throw it back\n        // into the generator, abandon iteration, whatever). With\n        // await, by contrast, there is no opportunity to examine the\n        // rejection reason outside the generator function, so the\n        // only option is to throw it from the await expression, and\n        // let the generator function handle the exception.\n        result.value = unwrapped;\n        return result;\n      });\n    }\n\n    if (typeof process === \"object\" && process.domain) {\n      invoke = process.domain.bind(invoke);\n    }\n\n    var invokeNext = invoke.bind(generator, \"next\");\n    var invokeThrow = invoke.bind(generator, \"throw\");\n    var invokeReturn = invoke.bind(generator, \"return\");\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      var enqueueResult =\n      // If enqueue has been called before, then we want to wait until\n      // all previous Promises have been resolved before calling invoke,\n      // so that results are always delivered in the correct order. If\n      // enqueue has not been called before, then it is important to\n      // call invoke immediately, without waiting on a callback to fire,\n      // so that the async generator function has the opportunity to do\n      // any necessary setup in a predictable way. This predictability\n      // is why the Promise constructor synchronously invokes its\n      // executor callback, and why async functions synchronously\n      // execute code before the first await. Since we implement simple\n      // async functions in terms of async generators, it is especially\n      // important to get this right, even though it requires care.\n      previousPromise ? previousPromise.then(function () {\n        return invoke(method, arg);\n      }) : new _Promise(function (resolve) {\n        resolve(invoke(method, arg));\n      });\n\n      // Avoid propagating enqueueResult failures to Promises returned by\n      // later invocations of the iterator.\n      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n      return enqueueResult;\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n    : iter.next().then(function (result) {\n      return result.done ? result.value : iter.next();\n    });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\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          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n            // A return or throw (when the delegate iterator has no throw\n            // method) always terminates the yield* loop.\n            context.delegate = null;\n\n            // If the delegate iterator has a return method, give it a\n            // chance to clean up.\n            var returnMethod = delegate.iterator[\"return\"];\n            if (returnMethod) {\n              var record = tryCatch(returnMethod, delegate.iterator, arg);\n              if (record.type === \"throw\") {\n                // If the return method threw an exception, let that\n                // exception prevail over the original return or throw.\n                method = \"throw\";\n                arg = record.arg;\n                continue;\n              }\n            }\n\n            if (method === \"return\") {\n              // Continue with the outer return, now that the delegate\n              // iterator has been terminated.\n              continue;\n            }\n          }\n\n          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\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            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 === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            context.sent = undefined;\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        } 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 ? GenStateCompleted : 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        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(arg) call above.\n          method = \"throw\";\n          arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\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(true);\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,\n            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 reset(skipTempReset) {\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      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function stop() {\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 dispatchException(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          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function abrupt(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 && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && 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 complete(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" || 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\n    finish: function finish(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function _catch(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 delegateYield(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).\ntypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);\n}).call(this,require('_process'),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-runtime/regenerator/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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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\"use strict\";\n\nvar _Symbol = require(\"babel-runtime/core-js/symbol\")[\"default\"];\n\nvar _Symbol$iterator = require(\"babel-runtime/core-js/symbol/iterator\")[\"default\"];\n\nvar _Object$create = require(\"babel-runtime/core-js/object/create\")[\"default\"];\n\nvar _Promise = require(\"babel-runtime/core-js/promise\")[\"default\"];\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 = 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    // If outerFn provided, then outerFn.prototype instanceof Generator.\n    var generator = _Object$create((outerFn || Generator).prototype);\n\n    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n    return generator;\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 Generator() {}\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  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n      prototype[method] = function (arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function (genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor ? 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\" : false;\n  };\n\n  runtime.mark = function (genFun) {\n    genFun.__proto__ = GeneratorFunctionPrototype;\n    genFun.prototype = _Object$create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `value instanceof AwaitArgument` to determine if the yielded value is\n  // meant to be awaited. Some may consider the name of this method too\n  // cutesy, but they are curmudgeons.\n  runtime.awrap = function (arg) {\n    return new AwaitArgument(arg);\n  };\n\n  function AwaitArgument(arg) {\n    this.arg = arg;\n  }\n\n  function AsyncIterator(generator) {\n    // This invoke function is written in a style that assumes some\n    // calling function (or Promise) will handle exceptions.\n    function invoke(method, arg) {\n      var result = generator[method](arg);\n      var value = result.value;\n      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n        // When a yielded Promise is resolved, its final value becomes\n        // the .value of the Promise<{value,done}> result for the\n        // current iteration. If the Promise is rejected, however, the\n        // result for this iteration will be rejected with the same\n        // reason. Note that rejections of yielded Promises are not\n        // thrown back into the generator function, as is the case\n        // when an awaited Promise is rejected. This difference in\n        // behavior between yield and await is important, because it\n        // allows the consumer to decide what to do with the yielded\n        // rejection (swallow it and continue, manually .throw it back\n        // into the generator, abandon iteration, whatever). With\n        // await, by contrast, there is no opportunity to examine the\n        // rejection reason outside the generator function, so the\n        // only option is to throw it from the await expression, and\n        // let the generator function handle the exception.\n        result.value = unwrapped;\n        return result;\n      });\n    }\n\n    if (typeof process === \"object\" && process.domain) {\n      invoke = process.domain.bind(invoke);\n    }\n\n    var invokeNext = invoke.bind(generator, \"next\");\n    var invokeThrow = invoke.bind(generator, \"throw\");\n    var invokeReturn = invoke.bind(generator, \"return\");\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      var enqueueResult =\n      // If enqueue has been called before, then we want to wait until\n      // all previous Promises have been resolved before calling invoke,\n      // so that results are always delivered in the correct order. If\n      // enqueue has not been called before, then it is important to\n      // call invoke immediately, without waiting on a callback to fire,\n      // so that the async generator function has the opportunity to do\n      // any necessary setup in a predictable way. This predictability\n      // is why the Promise constructor synchronously invokes its\n      // executor callback, and why async functions synchronously\n      // execute code before the first await. Since we implement simple\n      // async functions in terms of async generators, it is especially\n      // important to get this right, even though it requires care.\n      previousPromise ? previousPromise.then(function () {\n        return invoke(method, arg);\n      }) : new _Promise(function (resolve) {\n        resolve(invoke(method, arg));\n      });\n\n      // Avoid propagating enqueueResult failures to Promises returned by\n      // later invocations of the iterator.\n      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n      return enqueueResult;\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n    : iter.next().then(function (result) {\n      return result.done ? result.value : iter.next();\n    });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\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          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n            // A return or throw (when the delegate iterator has no throw\n            // method) always terminates the yield* loop.\n            context.delegate = null;\n\n            // If the delegate iterator has a return method, give it a\n            // chance to clean up.\n            var returnMethod = delegate.iterator[\"return\"];\n            if (returnMethod) {\n              var record = tryCatch(returnMethod, delegate.iterator, arg);\n              if (record.type === \"throw\") {\n                // If the return method threw an exception, let that\n                // exception prevail over the original return or throw.\n                method = \"throw\";\n                arg = record.arg;\n                continue;\n              }\n            }\n\n            if (method === \"return\") {\n              // Continue with the outer return, now that the delegate\n              // iterator has been terminated.\n              continue;\n            }\n          }\n\n          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\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            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 === GenStateSuspendedYield) {\n            context.sent = arg;\n          } else {\n            context.sent = undefined;\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        } 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 ? GenStateCompleted : 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        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(arg) call above.\n          method = \"throw\";\n          arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\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(true);\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,\n            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 reset(skipTempReset) {\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      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function stop() {\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 dispatchException(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          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function abrupt(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 && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && 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 complete(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" || 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\n    finish: function finish(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function _catch(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 delegateYield(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).\ntypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);"]}","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","/**\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\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//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      result = []\n      boxIntersect(arg0, arg0, function(i,j) {\n        result.push([i, j])\n      }, true)\n      return result\n    case 2:\n      if(typeof arg1 === 'function') {\n        var visit = arg1\n        return boxIntersect(arg0, arg0, visit, true)\n      } else {\n        result = []\n        boxIntersect(arg0, arg1, function(i,j) {\n          result.push([i, j])\n        }, false)\n        return result\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}",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","require('../../modules/es6.string.iterator');\nrequire('../../modules/es6.array.from');\nmodule.exports = require('../../modules/$.core').Array.from;","require('../modules/web.dom.iterable');\nrequire('../modules/es6.string.iterator');\nmodule.exports = require('../modules/core.get-iterator');","require('../modules/web.dom.iterable');\nrequire('../modules/es6.string.iterator');\nmodule.exports = require('../modules/core.is-iterable');","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.map');\nrequire('../modules/es7.map.to-json');\nmodule.exports = require('../modules/$.core').Map;","require('../../modules/es6.math.log2');\nmodule.exports = require('../../modules/$.core').Math.log2;","require('../../modules/es6.object.assign');\nmodule.exports = require('../../modules/$.core').Object.assign;","var $ = require('../../modules/$');\nmodule.exports = function create(P, D){\n  return $.create(P, D);\n};","var $ = require('../../modules/$');\nmodule.exports = function defineProperties(T, D){\n  return $.setDescs(T, D);\n};","var $ = require('../../modules/$');\nmodule.exports = function defineProperty(it, key, desc){\n  return $.setDesc(it, key, desc);\n};","require('../../modules/es6.object.freeze');\nmodule.exports = require('../../modules/$.core').Object.freeze;","var $ = require('../../modules/$');\nrequire('../../modules/es6.object.get-own-property-descriptor');\nmodule.exports = function getOwnPropertyDescriptor(it, key){\n  return $.getDesc(it, key);\n};","require('../../modules/es6.object.keys');\nmodule.exports = require('../../modules/$.core').Object.keys;","require('../../modules/es6.object.set-prototype-of');\nmodule.exports = require('../../modules/$.core').Object.setPrototypeOf;","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.promise');\nmodule.exports = require('../modules/$.core').Promise;","require('../modules/es6.object.to-string');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/web.dom.iterable');\nrequire('../modules/es6.set');\nrequire('../modules/es7.set.to-json');\nmodule.exports = require('../modules/$.core').Set;","require('../../modules/es6.symbol');\nrequire('../../modules/es6.object.to-string');\nmodule.exports = require('../../modules/$.core').Symbol;","require('../../modules/es6.string.iterator');\nrequire('../../modules/web.dom.iterable');\nmodule.exports = require('../../modules/$.wks')('iterator');","module.exports = function(it){\n  if(typeof it != 'function')throw TypeError(it + ' is not a function!');\n  return it;\n};","module.exports = function(){ /* empty */ };","var isObject = require('./$.is-object');\nmodule.exports = function(it){\n  if(!isObject(it))throw TypeError(it + ' is not an object!');\n  return it;\n};","// getting tag from 19.1.3.6 Object.prototype.toString()\nvar cof = require('./$.cof')\n  , TAG = require('./$.wks')('toStringTag')\n  // ES3 wrong here\n  , ARG = cof(function(){ return arguments; }()) == 'Arguments';\n\nmodule.exports = function(it){\n  var O, T, B;\n  return it === undefined ? 'Undefined' : it === null ? 'Null'\n    // @@toStringTag case\n    : typeof (T = (O = Object(it))[TAG]) == 'string' ? T\n    // builtinTag case\n    : ARG ? cof(O)\n    // ES3 arguments fallback\n    : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n};","var toString = {}.toString;\n\nmodule.exports = function(it){\n  return toString.call(it).slice(8, -1);\n};","'use strict';\nvar $            = require('./$')\n  , hide         = require('./$.hide')\n  , redefineAll  = require('./$.redefine-all')\n  , ctx          = require('./$.ctx')\n  , strictNew    = require('./$.strict-new')\n  , defined      = require('./$.defined')\n  , forOf        = require('./$.for-of')\n  , $iterDefine  = require('./$.iter-define')\n  , step         = require('./$.iter-step')\n  , ID           = require('./$.uid')('id')\n  , $has         = require('./$.has')\n  , isObject     = require('./$.is-object')\n  , setSpecies   = require('./$.set-species')\n  , DESCRIPTORS  = require('./$.descriptors')\n  , isExtensible = Object.isExtensible || isObject\n  , SIZE         = DESCRIPTORS ? '_s' : 'size'\n  , id           = 0;\n\nvar fastKey = function(it, create){\n  // return primitive with prefix\n  if(!isObject(it))return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n  if(!$has(it, ID)){\n    // can't set id to frozen object\n    if(!isExtensible(it))return 'F';\n    // not necessary to add id\n    if(!create)return 'E';\n    // add missing object id\n    hide(it, ID, ++id);\n  // return object id with prefix\n  } return 'O' + it[ID];\n};\n\nvar getEntry = function(that, key){\n  // fast case\n  var index = fastKey(key), entry;\n  if(index !== 'F')return that._i[index];\n  // frozen object case\n  for(entry = that._f; entry; entry = entry.n){\n    if(entry.k == key)return entry;\n  }\n};\n\nmodule.exports = {\n  getConstructor: function(wrapper, NAME, IS_MAP, ADDER){\n    var C = wrapper(function(that, iterable){\n      strictNew(that, C, NAME);\n      that._i = $.create(null); // index\n      that._f = undefined;      // first entry\n      that._l = undefined;      // last entry\n      that[SIZE] = 0;           // size\n      if(iterable != undefined)forOf(iterable, IS_MAP, that[ADDER], that);\n    });\n    redefineAll(C.prototype, {\n      // 23.1.3.1 Map.prototype.clear()\n      // 23.2.3.2 Set.prototype.clear()\n      clear: function clear(){\n        for(var that = this, data = that._i, entry = that._f; entry; entry = entry.n){\n          entry.r = true;\n          if(entry.p)entry.p = entry.p.n = undefined;\n          delete data[entry.i];\n        }\n        that._f = that._l = undefined;\n        that[SIZE] = 0;\n      },\n      // 23.1.3.3 Map.prototype.delete(key)\n      // 23.2.3.4 Set.prototype.delete(value)\n      'delete': function(key){\n        var that  = this\n          , entry = getEntry(that, key);\n        if(entry){\n          var next = entry.n\n            , prev = entry.p;\n          delete that._i[entry.i];\n          entry.r = true;\n          if(prev)prev.n = next;\n          if(next)next.p = prev;\n          if(that._f == entry)that._f = next;\n          if(that._l == entry)that._l = prev;\n          that[SIZE]--;\n        } return !!entry;\n      },\n      // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n      // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n      forEach: function forEach(callbackfn /*, that = undefined */){\n        var f = ctx(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3)\n          , entry;\n        while(entry = entry ? entry.n : this._f){\n          f(entry.v, entry.k, this);\n          // revert to the last existing entry\n          while(entry && entry.r)entry = entry.p;\n        }\n      },\n      // 23.1.3.7 Map.prototype.has(key)\n      // 23.2.3.7 Set.prototype.has(value)\n      has: function has(key){\n        return !!getEntry(this, key);\n      }\n    });\n    if(DESCRIPTORS)$.setDesc(C.prototype, 'size', {\n      get: function(){\n        return defined(this[SIZE]);\n      }\n    });\n    return C;\n  },\n  def: function(that, key, value){\n    var entry = getEntry(that, key)\n      , prev, index;\n    // change existing entry\n    if(entry){\n      entry.v = value;\n    // create new entry\n    } else {\n      that._l = entry = {\n        i: index = fastKey(key, true), // <- index\n        k: key,                        // <- key\n        v: value,                      // <- value\n        p: prev = that._l,             // <- previous entry\n        n: undefined,                  // <- next entry\n        r: false                       // <- removed\n      };\n      if(!that._f)that._f = entry;\n      if(prev)prev.n = entry;\n      that[SIZE]++;\n      // add to index\n      if(index !== 'F')that._i[index] = entry;\n    } return that;\n  },\n  getEntry: getEntry,\n  setStrong: function(C, NAME, IS_MAP){\n    // add .keys, .values, .entries, [@@iterator]\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\n    $iterDefine(C, NAME, function(iterated, kind){\n      this._t = iterated;  // target\n      this._k = kind;      // kind\n      this._l = undefined; // previous\n    }, function(){\n      var that  = this\n        , kind  = that._k\n        , entry = that._l;\n      // revert to the last existing entry\n      while(entry && entry.r)entry = entry.p;\n      // get next entry\n      if(!that._t || !(that._l = entry = entry ? entry.n : that._t._f)){\n        // or finish the iteration\n        that._t = undefined;\n        return step(1);\n      }\n      // return step by kind\n      if(kind == 'keys'  )return step(0, entry.k);\n      if(kind == 'values')return step(0, entry.v);\n      return step(0, [entry.k, entry.v]);\n    }, IS_MAP ? 'entries' : 'values' , !IS_MAP, true);\n\n    // add [@@species], 23.1.2.2, 23.2.2.2\n    setSpecies(NAME);\n  }\n};","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar forOf   = require('./$.for-of')\n  , classof = require('./$.classof');\nmodule.exports = function(NAME){\n  return function toJSON(){\n    if(classof(this) != NAME)throw TypeError(NAME + \"#toJSON isn't generic\");\n    var arr = [];\n    forOf(this, false, arr.push, arr);\n    return arr;\n  };\n};","'use strict';\nvar $              = require('./$')\n  , global         = require('./$.global')\n  , $export        = require('./$.export')\n  , fails          = require('./$.fails')\n  , hide           = require('./$.hide')\n  , redefineAll    = require('./$.redefine-all')\n  , forOf          = require('./$.for-of')\n  , strictNew      = require('./$.strict-new')\n  , isObject       = require('./$.is-object')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , DESCRIPTORS    = require('./$.descriptors');\n\nmodule.exports = function(NAME, wrapper, methods, common, IS_MAP, IS_WEAK){\n  var Base  = global[NAME]\n    , C     = Base\n    , ADDER = IS_MAP ? 'set' : 'add'\n    , proto = C && C.prototype\n    , O     = {};\n  if(!DESCRIPTORS || typeof C != 'function' || !(IS_WEAK || proto.forEach && !fails(function(){\n    new C().entries().next();\n  }))){\n    // create collection constructor\n    C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n    redefineAll(C.prototype, methods);\n  } else {\n    C = wrapper(function(target, iterable){\n      strictNew(target, C, NAME);\n      target._c = new Base;\n      if(iterable != undefined)forOf(iterable, IS_MAP, target[ADDER], target);\n    });\n    $.each.call('add,clear,delete,forEach,get,has,set,keys,values,entries'.split(','),function(KEY){\n      var IS_ADDER = KEY == 'add' || KEY == 'set';\n      if(KEY in proto && !(IS_WEAK && KEY == 'clear'))hide(C.prototype, KEY, function(a, b){\n        if(!IS_ADDER && IS_WEAK && !isObject(a))return KEY == 'get' ? undefined : false;\n        var result = this._c[KEY](a === 0 ? 0 : a, b);\n        return IS_ADDER ? this : result;\n      });\n    });\n    if('size' in proto)$.setDesc(C.prototype, 'size', {\n      get: function(){\n        return this._c.size;\n      }\n    });\n  }\n\n  setToStringTag(C, NAME);\n\n  O[NAME] = C;\n  $export($export.G + $export.W + $export.F, O);\n\n  if(!IS_WEAK)common.setStrong(C, NAME, IS_MAP);\n\n  return C;\n};","var core = module.exports = {version: '1.2.6'};\nif(typeof __e == 'number')__e = core; // eslint-disable-line no-undef","// optional / simple context binding\nvar aFunction = require('./$.a-function');\nmodule.exports = function(fn, that, length){\n  aFunction(fn);\n  if(that === undefined)return fn;\n  switch(length){\n    case 1: return function(a){\n      return fn.call(that, a);\n    };\n    case 2: return function(a, b){\n      return fn.call(that, a, b);\n    };\n    case 3: return function(a, b, c){\n      return fn.call(that, a, b, c);\n    };\n  }\n  return function(/* ...args */){\n    return fn.apply(that, arguments);\n  };\n};","// 7.2.1 RequireObjectCoercible(argument)\nmodule.exports = function(it){\n  if(it == undefined)throw TypeError(\"Can't call method on  \" + it);\n  return it;\n};","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./$.fails')(function(){\n  return Object.defineProperty({}, 'a', {get: function(){ return 7; }}).a != 7;\n});","var isObject = require('./$.is-object')\n  , document = require('./$.global').document\n  // in old IE typeof document.createElement is 'object'\n  , is = isObject(document) && isObject(document.createElement);\nmodule.exports = function(it){\n  return is ? document.createElement(it) : {};\n};","// all enumerable object keys, includes symbols\nvar $ = require('./$');\nmodule.exports = function(it){\n  var keys       = $.getKeys(it)\n    , getSymbols = $.getSymbols;\n  if(getSymbols){\n    var symbols = getSymbols(it)\n      , isEnum  = $.isEnum\n      , i       = 0\n      , key;\n    while(symbols.length > i)if(isEnum.call(it, key = symbols[i++]))keys.push(key);\n  }\n  return keys;\n};","var global    = require('./$.global')\n  , core      = require('./$.core')\n  , ctx       = require('./$.ctx')\n  , PROTOTYPE = 'prototype';\n\nvar $export = function(type, name, source){\n  var IS_FORCED = type & $export.F\n    , IS_GLOBAL = type & $export.G\n    , IS_STATIC = type & $export.S\n    , IS_PROTO  = type & $export.P\n    , IS_BIND   = type & $export.B\n    , IS_WRAP   = type & $export.W\n    , exports   = IS_GLOBAL ? core : core[name] || (core[name] = {})\n    , target    = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE]\n    , key, own, out;\n  if(IS_GLOBAL)source = name;\n  for(key in source){\n    // contains in native\n    own = !IS_FORCED && target && key in target;\n    if(own && key in exports)continue;\n    // export native or passed\n    out = own ? target[key] : source[key];\n    // prevent global pollution for namespaces\n    exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n    // bind timers to global for call from export context\n    : IS_BIND && own ? ctx(out, global)\n    // wrap global constructors for prevent change them in library\n    : IS_WRAP && target[key] == out ? (function(C){\n      var F = function(param){\n        return this instanceof C ? new C(param) : C(param);\n      };\n      F[PROTOTYPE] = C[PROTOTYPE];\n      return F;\n    // make static versions for prototype methods\n    })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n    if(IS_PROTO)(exports[PROTOTYPE] || (exports[PROTOTYPE] = {}))[key] = out;\n  }\n};\n// type bitmap\n$export.F = 1;  // forced\n$export.G = 2;  // global\n$export.S = 4;  // static\n$export.P = 8;  // proto\n$export.B = 16; // bind\n$export.W = 32; // wrap\nmodule.exports = $export;","module.exports = function(exec){\n  try {\n    return !!exec();\n  } catch(e){\n    return true;\n  }\n};","var ctx         = require('./$.ctx')\n  , call        = require('./$.iter-call')\n  , isArrayIter = require('./$.is-array-iter')\n  , anObject    = require('./$.an-object')\n  , toLength    = require('./$.to-length')\n  , getIterFn   = require('./core.get-iterator-method');\nmodule.exports = function(iterable, entries, fn, that){\n  var iterFn = getIterFn(iterable)\n    , f      = ctx(fn, that, entries ? 2 : 1)\n    , index  = 0\n    , length, step, iterator;\n  if(typeof iterFn != 'function')throw TypeError(iterable + ' is not iterable!');\n  // fast case for arrays with default iterator\n  if(isArrayIter(iterFn))for(length = toLength(iterable.length); length > index; index++){\n    entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n  } else for(iterator = iterFn.call(iterable); !(step = iterator.next()).done; ){\n    call(iterator, f, step.value, entries);\n  }\n};","// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\nvar toIObject = require('./$.to-iobject')\n  , getNames  = require('./$').getNames\n  , toString  = {}.toString;\n\nvar windowNames = typeof window == 'object' && Object.getOwnPropertyNames\n  ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function(it){\n  try {\n    return getNames(it);\n  } catch(e){\n    return windowNames.slice();\n  }\n};\n\nmodule.exports.get = function getOwnPropertyNames(it){\n  if(windowNames && toString.call(it) == '[object Window]')return getWindowNames(it);\n  return getNames(toIObject(it));\n};","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n  ? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();\nif(typeof __g == 'number')__g = global; // eslint-disable-line no-undef","var hasOwnProperty = {}.hasOwnProperty;\nmodule.exports = function(it, key){\n  return hasOwnProperty.call(it, key);\n};","var $          = require('./$')\n  , createDesc = require('./$.property-desc');\nmodule.exports = require('./$.descriptors') ? function(object, key, value){\n  return $.setDesc(object, key, createDesc(1, value));\n} : function(object, key, value){\n  object[key] = value;\n  return object;\n};","module.exports = require('./$.global').document && document.documentElement;","// fast apply, http://jsperf.lnkit.com/fast-apply/5\nmodule.exports = function(fn, args, that){\n  var un = that === undefined;\n  switch(args.length){\n    case 0: return un ? fn()\n                      : fn.call(that);\n    case 1: return un ? fn(args[0])\n                      : fn.call(that, args[0]);\n    case 2: return un ? fn(args[0], args[1])\n                      : fn.call(that, args[0], args[1]);\n    case 3: return un ? fn(args[0], args[1], args[2])\n                      : fn.call(that, args[0], args[1], args[2]);\n    case 4: return un ? fn(args[0], args[1], args[2], args[3])\n                      : fn.call(that, args[0], args[1], args[2], args[3]);\n  } return              fn.apply(that, args);\n};","// fallback for non-array-like ES3 and non-enumerable old V8 strings\nvar cof = require('./$.cof');\nmodule.exports = Object('z').propertyIsEnumerable(0) ? Object : function(it){\n  return cof(it) == 'String' ? it.split('') : Object(it);\n};","// check on default Array iterator\nvar Iterators  = require('./$.iterators')\n  , ITERATOR   = require('./$.wks')('iterator')\n  , ArrayProto = Array.prototype;\n\nmodule.exports = function(it){\n  return it !== undefined && (Iterators.Array === it || ArrayProto[ITERATOR] === it);\n};","// 7.2.2 IsArray(argument)\nvar cof = require('./$.cof');\nmodule.exports = Array.isArray || function(arg){\n  return cof(arg) == 'Array';\n};","module.exports = function(it){\n  return typeof it === 'object' ? it !== null : typeof it === 'function';\n};","// call something on iterator step with safe closing on error\nvar anObject = require('./$.an-object');\nmodule.exports = function(iterator, fn, value, entries){\n  try {\n    return entries ? fn(anObject(value)[0], value[1]) : fn(value);\n  // 7.4.6 IteratorClose(iterator, completion)\n  } catch(e){\n    var ret = iterator['return'];\n    if(ret !== undefined)anObject(ret.call(iterator));\n    throw e;\n  }\n};","'use strict';\nvar $              = require('./$')\n  , descriptor     = require('./$.property-desc')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , IteratorPrototype = {};\n\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\nrequire('./$.hide')(IteratorPrototype, require('./$.wks')('iterator'), function(){ return this; });\n\nmodule.exports = function(Constructor, NAME, next){\n  Constructor.prototype = $.create(IteratorPrototype, {next: descriptor(1, next)});\n  setToStringTag(Constructor, NAME + ' Iterator');\n};","'use strict';\nvar LIBRARY        = require('./$.library')\n  , $export        = require('./$.export')\n  , redefine       = require('./$.redefine')\n  , hide           = require('./$.hide')\n  , has            = require('./$.has')\n  , Iterators      = require('./$.iterators')\n  , $iterCreate    = require('./$.iter-create')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , getProto       = require('./$').getProto\n  , ITERATOR       = require('./$.wks')('iterator')\n  , BUGGY          = !([].keys && 'next' in [].keys()) // Safari has buggy iterators w/o `next`\n  , FF_ITERATOR    = '@@iterator'\n  , KEYS           = 'keys'\n  , VALUES         = 'values';\n\nvar returnThis = function(){ return this; };\n\nmodule.exports = function(Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCED){\n  $iterCreate(Constructor, NAME, next);\n  var getMethod = function(kind){\n    if(!BUGGY && kind in proto)return proto[kind];\n    switch(kind){\n      case KEYS: return function keys(){ return new Constructor(this, kind); };\n      case VALUES: return function values(){ return new Constructor(this, kind); };\n    } return function entries(){ return new Constructor(this, kind); };\n  };\n  var TAG        = NAME + ' Iterator'\n    , DEF_VALUES = DEFAULT == VALUES\n    , VALUES_BUG = false\n    , proto      = Base.prototype\n    , $native    = proto[ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT]\n    , $default   = $native || getMethod(DEFAULT)\n    , methods, key;\n  // Fix native\n  if($native){\n    var IteratorPrototype = getProto($default.call(new Base));\n    // Set @@toStringTag to native iterators\n    setToStringTag(IteratorPrototype, TAG, true);\n    // FF fix\n    if(!LIBRARY && has(proto, FF_ITERATOR))hide(IteratorPrototype, ITERATOR, returnThis);\n    // fix Array#{values, @@iterator}.name in V8 / FF\n    if(DEF_VALUES && $native.name !== VALUES){\n      VALUES_BUG = true;\n      $default = function values(){ return $native.call(this); };\n    }\n  }\n  // Define iterator\n  if((!LIBRARY || FORCED) && (BUGGY || VALUES_BUG || !proto[ITERATOR])){\n    hide(proto, ITERATOR, $default);\n  }\n  // Plug for library\n  Iterators[NAME] = $default;\n  Iterators[TAG]  = returnThis;\n  if(DEFAULT){\n    methods = {\n      values:  DEF_VALUES  ? $default : getMethod(VALUES),\n      keys:    IS_SET      ? $default : getMethod(KEYS),\n      entries: !DEF_VALUES ? $default : getMethod('entries')\n    };\n    if(FORCED)for(key in methods){\n      if(!(key in proto))redefine(proto, key, methods[key]);\n    } else $export($export.P + $export.F * (BUGGY || VALUES_BUG), NAME, methods);\n  }\n  return methods;\n};","var ITERATOR     = require('./$.wks')('iterator')\n  , SAFE_CLOSING = false;\n\ntry {\n  var riter = [7][ITERATOR]();\n  riter['return'] = function(){ SAFE_CLOSING = true; };\n  Array.from(riter, function(){ throw 2; });\n} catch(e){ /* empty */ }\n\nmodule.exports = function(exec, skipClosing){\n  if(!skipClosing && !SAFE_CLOSING)return false;\n  var safe = false;\n  try {\n    var arr  = [7]\n      , iter = arr[ITERATOR]();\n    iter.next = function(){ safe = true; };\n    arr[ITERATOR] = function(){ return iter; };\n    exec(arr);\n  } catch(e){ /* empty */ }\n  return safe;\n};","module.exports = function(done, value){\n  return {value: value, done: !!done};\n};","module.exports = {};","var $Object = Object;\nmodule.exports = {\n  create:     $Object.create,\n  getProto:   $Object.getPrototypeOf,\n  isEnum:     {}.propertyIsEnumerable,\n  getDesc:    $Object.getOwnPropertyDescriptor,\n  setDesc:    $Object.defineProperty,\n  setDescs:   $Object.defineProperties,\n  getKeys:    $Object.keys,\n  getNames:   $Object.getOwnPropertyNames,\n  getSymbols: $Object.getOwnPropertySymbols,\n  each:       [].forEach\n};","var $         = require('./$')\n  , toIObject = require('./$.to-iobject');\nmodule.exports = function(object, el){\n  var O      = toIObject(object)\n    , keys   = $.getKeys(O)\n    , length = keys.length\n    , index  = 0\n    , key;\n  while(length > index)if(O[key = keys[index++]] === el)return key;\n};","module.exports = true;","var global    = require('./$.global')\n  , macrotask = require('./$.task').set\n  , Observer  = global.MutationObserver || global.WebKitMutationObserver\n  , process   = global.process\n  , Promise   = global.Promise\n  , isNode    = require('./$.cof')(process) == 'process'\n  , head, last, notify;\n\nvar flush = function(){\n  var parent, domain, fn;\n  if(isNode && (parent = process.domain)){\n    process.domain = null;\n    parent.exit();\n  }\n  while(head){\n    domain = head.domain;\n    fn     = head.fn;\n    if(domain)domain.enter();\n    fn(); // <- currently we use it only for Promise - try / catch not required\n    if(domain)domain.exit();\n    head = head.next;\n  } last = undefined;\n  if(parent)parent.enter();\n};\n\n// Node.js\nif(isNode){\n  notify = function(){\n    process.nextTick(flush);\n  };\n// browsers with MutationObserver\n} else if(Observer){\n  var toggle = 1\n    , node   = document.createTextNode('');\n  new Observer(flush).observe(node, {characterData: true}); // eslint-disable-line no-new\n  notify = function(){\n    node.data = toggle = -toggle;\n  };\n// environments with maybe non-completely correct, but existent Promise\n} else if(Promise && Promise.resolve){\n  notify = function(){\n    Promise.resolve().then(flush);\n  };\n// for other environments - macrotask based on:\n// - setImmediate\n// - MessageChannel\n// - window.postMessag\n// - onreadystatechange\n// - setTimeout\n} else {\n  notify = function(){\n    // strange IE + webpack dev server bug - use .call(global)\n    macrotask.call(global, flush);\n  };\n}\n\nmodule.exports = function asap(fn){\n  var task = {fn: fn, next: undefined, domain: isNode && process.domain};\n  if(last)last.next = task;\n  if(!head){\n    head = task;\n    notify();\n  } last = task;\n};","// 19.1.2.1 Object.assign(target, source, ...)\nvar $        = require('./$')\n  , toObject = require('./$.to-object')\n  , IObject  = require('./$.iobject');\n\n// should work with symbols and should have deterministic property order (V8 bug)\nmodule.exports = require('./$.fails')(function(){\n  var a = Object.assign\n    , A = {}\n    , B = {}\n    , S = Symbol()\n    , K = 'abcdefghijklmnopqrst';\n  A[S] = 7;\n  K.split('').forEach(function(k){ B[k] = k; });\n  return a({}, A)[S] != 7 || Object.keys(a({}, B)).join('') != K;\n}) ? function assign(target, source){ // eslint-disable-line no-unused-vars\n  var T     = toObject(target)\n    , $$    = arguments\n    , $$len = $$.length\n    , index = 1\n    , getKeys    = $.getKeys\n    , getSymbols = $.getSymbols\n    , isEnum     = $.isEnum;\n  while($$len > index){\n    var S      = IObject($$[index++])\n      , keys   = getSymbols ? getKeys(S).concat(getSymbols(S)) : getKeys(S)\n      , length = keys.length\n      , j      = 0\n      , key;\n    while(length > j)if(isEnum.call(S, key = keys[j++]))T[key] = S[key];\n  }\n  return T;\n} : Object.assign;","// most Object methods by ES6 should accept primitives\nvar $export = require('./$.export')\n  , core    = require('./$.core')\n  , fails   = require('./$.fails');\nmodule.exports = function(KEY, exec){\n  var fn  = (core.Object || {})[KEY] || Object[KEY]\n    , exp = {};\n  exp[KEY] = exec(fn);\n  $export($export.S + $export.F * fails(function(){ fn(1); }), 'Object', exp);\n};","module.exports = function(bitmap, value){\n  return {\n    enumerable  : !(bitmap & 1),\n    configurable: !(bitmap & 2),\n    writable    : !(bitmap & 4),\n    value       : value\n  };\n};","var redefine = require('./$.redefine');\nmodule.exports = function(target, src){\n  for(var key in src)redefine(target, key, src[key]);\n  return target;\n};","module.exports = require('./$.hide');","// 7.2.9 SameValue(x, y)\nmodule.exports = Object.is || function is(x, y){\n  return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\n};","// Works with __proto__ only. Old v8 can't work with null proto objects.\n/* eslint-disable no-proto */\nvar getDesc  = require('./$').getDesc\n  , isObject = require('./$.is-object')\n  , anObject = require('./$.an-object');\nvar check = function(O, proto){\n  anObject(O);\n  if(!isObject(proto) && proto !== null)throw TypeError(proto + \": can't set as prototype!\");\n};\nmodule.exports = {\n  set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line\n    function(test, buggy, set){\n      try {\n        set = require('./$.ctx')(Function.call, getDesc(Object.prototype, '__proto__').set, 2);\n        set(test, []);\n        buggy = !(test instanceof Array);\n      } catch(e){ buggy = true; }\n      return function setPrototypeOf(O, proto){\n        check(O, proto);\n        if(buggy)O.__proto__ = proto;\n        else set(O, proto);\n        return O;\n      };\n    }({}, false) : undefined),\n  check: check\n};","'use strict';\nvar core        = require('./$.core')\n  , $           = require('./$')\n  , DESCRIPTORS = require('./$.descriptors')\n  , SPECIES     = require('./$.wks')('species');\n\nmodule.exports = function(KEY){\n  var C = core[KEY];\n  if(DESCRIPTORS && C && !C[SPECIES])$.setDesc(C, SPECIES, {\n    configurable: true,\n    get: function(){ return this; }\n  });\n};","var def = require('./$').setDesc\n  , has = require('./$.has')\n  , TAG = require('./$.wks')('toStringTag');\n\nmodule.exports = function(it, tag, stat){\n  if(it && !has(it = stat ? it : it.prototype, TAG))def(it, TAG, {configurable: true, value: tag});\n};","var global = require('./$.global')\n  , SHARED = '__core-js_shared__'\n  , store  = global[SHARED] || (global[SHARED] = {});\nmodule.exports = function(key){\n  return store[key] || (store[key] = {});\n};","// 7.3.20 SpeciesConstructor(O, defaultConstructor)\nvar anObject  = require('./$.an-object')\n  , aFunction = require('./$.a-function')\n  , SPECIES   = require('./$.wks')('species');\nmodule.exports = function(O, D){\n  var C = anObject(O).constructor, S;\n  return C === undefined || (S = anObject(C)[SPECIES]) == undefined ? D : aFunction(S);\n};","module.exports = function(it, Constructor, name){\n  if(!(it instanceof Constructor))throw TypeError(name + \": use the 'new' operator!\");\n  return it;\n};","var toInteger = require('./$.to-integer')\n  , defined   = require('./$.defined');\n// true  -> String#at\n// false -> String#codePointAt\nmodule.exports = function(TO_STRING){\n  return function(that, pos){\n    var s = String(defined(that))\n      , i = toInteger(pos)\n      , l = s.length\n      , a, b;\n    if(i < 0 || i >= l)return TO_STRING ? '' : undefined;\n    a = s.charCodeAt(i);\n    return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n      ? TO_STRING ? s.charAt(i) : a\n      : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n  };\n};","var ctx                = require('./$.ctx')\n  , invoke             = require('./$.invoke')\n  , html               = require('./$.html')\n  , cel                = require('./$.dom-create')\n  , global             = require('./$.global')\n  , process            = global.process\n  , setTask            = global.setImmediate\n  , clearTask          = global.clearImmediate\n  , MessageChannel     = global.MessageChannel\n  , counter            = 0\n  , queue              = {}\n  , ONREADYSTATECHANGE = 'onreadystatechange'\n  , defer, channel, port;\nvar run = function(){\n  var id = +this;\n  if(queue.hasOwnProperty(id)){\n    var fn = queue[id];\n    delete queue[id];\n    fn();\n  }\n};\nvar listner = function(event){\n  run.call(event.data);\n};\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif(!setTask || !clearTask){\n  setTask = function setImmediate(fn){\n    var args = [], i = 1;\n    while(arguments.length > i)args.push(arguments[i++]);\n    queue[++counter] = function(){\n      invoke(typeof fn == 'function' ? fn : Function(fn), args);\n    };\n    defer(counter);\n    return counter;\n  };\n  clearTask = function clearImmediate(id){\n    delete queue[id];\n  };\n  // Node.js 0.8-\n  if(require('./$.cof')(process) == 'process'){\n    defer = function(id){\n      process.nextTick(ctx(run, id, 1));\n    };\n  // Browsers with MessageChannel, includes WebWorkers\n  } else if(MessageChannel){\n    channel = new MessageChannel;\n    port    = channel.port2;\n    channel.port1.onmessage = listner;\n    defer = ctx(port.postMessage, port, 1);\n  // Browsers with postMessage, skip WebWorkers\n  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n  } else if(global.addEventListener && typeof postMessage == 'function' && !global.importScripts){\n    defer = function(id){\n      global.postMessage(id + '', '*');\n    };\n    global.addEventListener('message', listner, false);\n  // IE8-\n  } else if(ONREADYSTATECHANGE in cel('script')){\n    defer = function(id){\n      html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function(){\n        html.removeChild(this);\n        run.call(id);\n      };\n    };\n  // Rest old browsers\n  } else {\n    defer = function(id){\n      setTimeout(ctx(run, id, 1), 0);\n    };\n  }\n}\nmodule.exports = {\n  set:   setTask,\n  clear: clearTask\n};","// 7.1.4 ToInteger\nvar ceil  = Math.ceil\n  , floor = Math.floor;\nmodule.exports = function(it){\n  return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n};","// to indexed object, toObject with fallback for non-array-like ES3 strings\nvar IObject = require('./$.iobject')\n  , defined = require('./$.defined');\nmodule.exports = function(it){\n  return IObject(defined(it));\n};","// 7.1.15 ToLength\nvar toInteger = require('./$.to-integer')\n  , min       = Math.min;\nmodule.exports = function(it){\n  return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n};","// 7.1.13 ToObject(argument)\nvar defined = require('./$.defined');\nmodule.exports = function(it){\n  return Object(defined(it));\n};","var id = 0\n  , px = Math.random();\nmodule.exports = function(key){\n  return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n};","var store  = require('./$.shared')('wks')\n  , uid    = require('./$.uid')\n  , Symbol = require('./$.global').Symbol;\nmodule.exports = function(name){\n  return store[name] || (store[name] =\n    Symbol && Symbol[name] || (Symbol || uid)('Symbol.' + name));\n};","var classof   = require('./$.classof')\n  , ITERATOR  = require('./$.wks')('iterator')\n  , Iterators = require('./$.iterators');\nmodule.exports = require('./$.core').getIteratorMethod = function(it){\n  if(it != undefined)return it[ITERATOR]\n    || it['@@iterator']\n    || Iterators[classof(it)];\n};","var anObject = require('./$.an-object')\n  , get      = require('./core.get-iterator-method');\nmodule.exports = require('./$.core').getIterator = function(it){\n  var iterFn = get(it);\n  if(typeof iterFn != 'function')throw TypeError(it + ' is not iterable!');\n  return anObject(iterFn.call(it));\n};","var classof   = require('./$.classof')\n  , ITERATOR  = require('./$.wks')('iterator')\n  , Iterators = require('./$.iterators');\nmodule.exports = require('./$.core').isIterable = function(it){\n  var O = Object(it);\n  return O[ITERATOR] !== undefined\n    || '@@iterator' in O\n    || Iterators.hasOwnProperty(classof(O));\n};","'use strict';\nvar ctx         = require('./$.ctx')\n  , $export     = require('./$.export')\n  , toObject    = require('./$.to-object')\n  , call        = require('./$.iter-call')\n  , isArrayIter = require('./$.is-array-iter')\n  , toLength    = require('./$.to-length')\n  , getIterFn   = require('./core.get-iterator-method');\n$export($export.S + $export.F * !require('./$.iter-detect')(function(iter){ Array.from(iter); }), 'Array', {\n  // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\n  from: function from(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\n    var O       = toObject(arrayLike)\n      , C       = typeof this == 'function' ? this : Array\n      , $$      = arguments\n      , $$len   = $$.length\n      , mapfn   = $$len > 1 ? $$[1] : undefined\n      , mapping = mapfn !== undefined\n      , index   = 0\n      , iterFn  = getIterFn(O)\n      , length, result, step, iterator;\n    if(mapping)mapfn = ctx(mapfn, $$len > 2 ? $$[2] : undefined, 2);\n    // if object isn't iterable or it's array with default iterator - use simple case\n    if(iterFn != undefined && !(C == Array && isArrayIter(iterFn))){\n      for(iterator = iterFn.call(O), result = new C; !(step = iterator.next()).done; index++){\n        result[index] = mapping ? call(iterator, mapfn, [step.value, index], true) : step.value;\n      }\n    } else {\n      length = toLength(O.length);\n      for(result = new C(length); length > index; index++){\n        result[index] = mapping ? mapfn(O[index], index) : O[index];\n      }\n    }\n    result.length = index;\n    return result;\n  }\n});\n","'use strict';\nvar addToUnscopables = require('./$.add-to-unscopables')\n  , step             = require('./$.iter-step')\n  , Iterators        = require('./$.iterators')\n  , toIObject        = require('./$.to-iobject');\n\n// 22.1.3.4 Array.prototype.entries()\n// 22.1.3.13 Array.prototype.keys()\n// 22.1.3.29 Array.prototype.values()\n// 22.1.3.30 Array.prototype[@@iterator]()\nmodule.exports = require('./$.iter-define')(Array, 'Array', function(iterated, kind){\n  this._t = toIObject(iterated); // target\n  this._i = 0;                   // next index\n  this._k = kind;                // kind\n// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n}, function(){\n  var O     = this._t\n    , kind  = this._k\n    , index = this._i++;\n  if(!O || index >= O.length){\n    this._t = undefined;\n    return step(1);\n  }\n  if(kind == 'keys'  )return step(0, index);\n  if(kind == 'values')return step(0, O[index]);\n  return step(0, [index, O[index]]);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\nIterators.Arguments = Iterators.Array;\n\naddToUnscopables('keys');\naddToUnscopables('values');\naddToUnscopables('entries');","'use strict';\nvar strong = require('./$.collection-strong');\n\n// 23.1 Map Objects\nrequire('./$.collection')('Map', function(get){\n  return function Map(){ return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n  // 23.1.3.6 Map.prototype.get(key)\n  get: function get(key){\n    var entry = strong.getEntry(this, key);\n    return entry && entry.v;\n  },\n  // 23.1.3.9 Map.prototype.set(key, value)\n  set: function set(key, value){\n    return strong.def(this, key === 0 ? 0 : key, value);\n  }\n}, strong, true);","// 20.2.2.22 Math.log2(x)\nvar $export = require('./$.export');\n\n$export($export.S, 'Math', {\n  log2: function log2(x){\n    return Math.log(x) / Math.LN2;\n  }\n});","// 19.1.3.1 Object.assign(target, source)\nvar $export = require('./$.export');\n\n$export($export.S + $export.F, 'Object', {assign: require('./$.object-assign')});","// 19.1.2.5 Object.freeze(O)\nvar isObject = require('./$.is-object');\n\nrequire('./$.object-sap')('freeze', function($freeze){\n  return function freeze(it){\n    return $freeze && isObject(it) ? $freeze(it) : it;\n  };\n});","// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\nvar toIObject = require('./$.to-iobject');\n\nrequire('./$.object-sap')('getOwnPropertyDescriptor', function($getOwnPropertyDescriptor){\n  return function getOwnPropertyDescriptor(it, key){\n    return $getOwnPropertyDescriptor(toIObject(it), key);\n  };\n});","// 19.1.2.14 Object.keys(O)\nvar toObject = require('./$.to-object');\n\nrequire('./$.object-sap')('keys', function($keys){\n  return function keys(it){\n    return $keys(toObject(it));\n  };\n});","// 19.1.3.19 Object.setPrototypeOf(O, proto)\nvar $export = require('./$.export');\n$export($export.S, 'Object', {setPrototypeOf: require('./$.set-proto').set});","'use strict';\nvar $          = require('./$')\n  , LIBRARY    = require('./$.library')\n  , global     = require('./$.global')\n  , ctx        = require('./$.ctx')\n  , classof    = require('./$.classof')\n  , $export    = require('./$.export')\n  , isObject   = require('./$.is-object')\n  , anObject   = require('./$.an-object')\n  , aFunction  = require('./$.a-function')\n  , strictNew  = require('./$.strict-new')\n  , forOf      = require('./$.for-of')\n  , setProto   = require('./$.set-proto').set\n  , same       = require('./$.same-value')\n  , SPECIES    = require('./$.wks')('species')\n  , speciesConstructor = require('./$.species-constructor')\n  , asap       = require('./$.microtask')\n  , PROMISE    = 'Promise'\n  , process    = global.process\n  , isNode     = classof(process) == 'process'\n  , P          = global[PROMISE]\n  , Wrapper;\n\nvar testResolve = function(sub){\n  var test = new P(function(){});\n  if(sub)test.constructor = Object;\n  return P.resolve(test) === test;\n};\n\nvar USE_NATIVE = function(){\n  var works = false;\n  function P2(x){\n    var self = new P(x);\n    setProto(self, P2.prototype);\n    return self;\n  }\n  try {\n    works = P && P.resolve && testResolve();\n    setProto(P2, P);\n    P2.prototype = $.create(P.prototype, {constructor: {value: P2}});\n    // actual Firefox has broken subclass support, test that\n    if(!(P2.resolve(5).then(function(){}) instanceof P2)){\n      works = false;\n    }\n    // actual V8 bug, https://code.google.com/p/v8/issues/detail?id=4162\n    if(works && require('./$.descriptors')){\n      var thenableThenGotten = false;\n      P.resolve($.setDesc({}, 'then', {\n        get: function(){ thenableThenGotten = true; }\n      }));\n      works = thenableThenGotten;\n    }\n  } catch(e){ works = false; }\n  return works;\n}();\n\n// helpers\nvar sameConstructor = function(a, b){\n  // library wrapper special case\n  if(LIBRARY && a === P && b === Wrapper)return true;\n  return same(a, b);\n};\nvar getConstructor = function(C){\n  var S = anObject(C)[SPECIES];\n  return S != undefined ? S : C;\n};\nvar isThenable = function(it){\n  var then;\n  return isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n};\nvar PromiseCapability = function(C){\n  var resolve, reject;\n  this.promise = new C(function($$resolve, $$reject){\n    if(resolve !== undefined || reject !== undefined)throw TypeError('Bad Promise constructor');\n    resolve = $$resolve;\n    reject  = $$reject;\n  });\n  this.resolve = aFunction(resolve),\n  this.reject  = aFunction(reject)\n};\nvar perform = function(exec){\n  try {\n    exec();\n  } catch(e){\n    return {error: e};\n  }\n};\nvar notify = function(record, isReject){\n  if(record.n)return;\n  record.n = true;\n  var chain = record.c;\n  asap(function(){\n    var value = record.v\n      , ok    = record.s == 1\n      , i     = 0;\n    var run = function(reaction){\n      var handler = ok ? reaction.ok : reaction.fail\n        , resolve = reaction.resolve\n        , reject  = reaction.reject\n        , result, then;\n      try {\n        if(handler){\n          if(!ok)record.h = true;\n          result = handler === true ? value : handler(value);\n          if(result === reaction.promise){\n            reject(TypeError('Promise-chain cycle'));\n          } else if(then = isThenable(result)){\n            then.call(result, resolve, reject);\n          } else resolve(result);\n        } else reject(value);\n      } catch(e){\n        reject(e);\n      }\n    };\n    while(chain.length > i)run(chain[i++]); // variable length - can't use forEach\n    chain.length = 0;\n    record.n = false;\n    if(isReject)setTimeout(function(){\n      var promise = record.p\n        , handler, console;\n      if(isUnhandled(promise)){\n        if(isNode){\n          process.emit('unhandledRejection', value, promise);\n        } else if(handler = global.onunhandledrejection){\n          handler({promise: promise, reason: value});\n        } else if((console = global.console) && console.error){\n          console.error('Unhandled promise rejection', value);\n        }\n      } record.a = undefined;\n    }, 1);\n  });\n};\nvar isUnhandled = function(promise){\n  var record = promise._d\n    , chain  = record.a || record.c\n    , i      = 0\n    , reaction;\n  if(record.h)return false;\n  while(chain.length > i){\n    reaction = chain[i++];\n    if(reaction.fail || !isUnhandled(reaction.promise))return false;\n  } return true;\n};\nvar $reject = function(value){\n  var record = this;\n  if(record.d)return;\n  record.d = true;\n  record = record.r || record; // unwrap\n  record.v = value;\n  record.s = 2;\n  record.a = record.c.slice();\n  notify(record, true);\n};\nvar $resolve = function(value){\n  var record = this\n    , then;\n  if(record.d)return;\n  record.d = true;\n  record = record.r || record; // unwrap\n  try {\n    if(record.p === value)throw TypeError(\"Promise can't be resolved itself\");\n    if(then = isThenable(value)){\n      asap(function(){\n        var wrapper = {r: record, d: false}; // wrap\n        try {\n          then.call(value, ctx($resolve, wrapper, 1), ctx($reject, wrapper, 1));\n        } catch(e){\n          $reject.call(wrapper, e);\n        }\n      });\n    } else {\n      record.v = value;\n      record.s = 1;\n      notify(record, false);\n    }\n  } catch(e){\n    $reject.call({r: record, d: false}, e); // wrap\n  }\n};\n\n// constructor polyfill\nif(!USE_NATIVE){\n  // 25.4.3.1 Promise(executor)\n  P = function Promise(executor){\n    aFunction(executor);\n    var record = this._d = {\n      p: strictNew(this, P, PROMISE),         // <- promise\n      c: [],                                  // <- awaiting reactions\n      a: undefined,                           // <- checked in isUnhandled reactions\n      s: 0,                                   // <- state\n      d: false,                               // <- done\n      v: undefined,                           // <- value\n      h: false,                               // <- handled rejection\n      n: false                                // <- notify\n    };\n    try {\n      executor(ctx($resolve, record, 1), ctx($reject, record, 1));\n    } catch(err){\n      $reject.call(record, err);\n    }\n  };\n  require('./$.redefine-all')(P.prototype, {\n    // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n    then: function then(onFulfilled, onRejected){\n      var reaction = new PromiseCapability(speciesConstructor(this, P))\n        , promise  = reaction.promise\n        , record   = this._d;\n      reaction.ok   = typeof onFulfilled == 'function' ? onFulfilled : true;\n      reaction.fail = typeof onRejected == 'function' && onRejected;\n      record.c.push(reaction);\n      if(record.a)record.a.push(reaction);\n      if(record.s)notify(record, false);\n      return promise;\n    },\n    // 25.4.5.1 Promise.prototype.catch(onRejected)\n    'catch': function(onRejected){\n      return this.then(undefined, onRejected);\n    }\n  });\n}\n\n$export($export.G + $export.W + $export.F * !USE_NATIVE, {Promise: P});\nrequire('./$.set-to-string-tag')(P, PROMISE);\nrequire('./$.set-species')(PROMISE);\nWrapper = require('./$.core')[PROMISE];\n\n// statics\n$export($export.S + $export.F * !USE_NATIVE, PROMISE, {\n  // 25.4.4.5 Promise.reject(r)\n  reject: function reject(r){\n    var capability = new PromiseCapability(this)\n      , $$reject   = capability.reject;\n    $$reject(r);\n    return capability.promise;\n  }\n});\n$export($export.S + $export.F * (!USE_NATIVE || testResolve(true)), PROMISE, {\n  // 25.4.4.6 Promise.resolve(x)\n  resolve: function resolve(x){\n    // instanceof instead of internal slot check because we should fix it without replacement native Promise core\n    if(x instanceof P && sameConstructor(x.constructor, this))return x;\n    var capability = new PromiseCapability(this)\n      , $$resolve  = capability.resolve;\n    $$resolve(x);\n    return capability.promise;\n  }\n});\n$export($export.S + $export.F * !(USE_NATIVE && require('./$.iter-detect')(function(iter){\n  P.all(iter)['catch'](function(){});\n})), PROMISE, {\n  // 25.4.4.1 Promise.all(iterable)\n  all: function all(iterable){\n    var C          = getConstructor(this)\n      , capability = new PromiseCapability(C)\n      , resolve    = capability.resolve\n      , reject     = capability.reject\n      , values     = [];\n    var abrupt = perform(function(){\n      forOf(iterable, false, values.push, values);\n      var remaining = values.length\n        , results   = Array(remaining);\n      if(remaining)$.each.call(values, function(promise, index){\n        var alreadyCalled = false;\n        C.resolve(promise).then(function(value){\n          if(alreadyCalled)return;\n          alreadyCalled = true;\n          results[index] = value;\n          --remaining || resolve(results);\n        }, reject);\n      });\n      else resolve(results);\n    });\n    if(abrupt)reject(abrupt.error);\n    return capability.promise;\n  },\n  // 25.4.4.4 Promise.race(iterable)\n  race: function race(iterable){\n    var C          = getConstructor(this)\n      , capability = new PromiseCapability(C)\n      , reject     = capability.reject;\n    var abrupt = perform(function(){\n      forOf(iterable, false, function(promise){\n        C.resolve(promise).then(capability.resolve, reject);\n      });\n    });\n    if(abrupt)reject(abrupt.error);\n    return capability.promise;\n  }\n});","'use strict';\nvar strong = require('./$.collection-strong');\n\n// 23.2 Set Objects\nrequire('./$.collection')('Set', function(get){\n  return function Set(){ return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n  // 23.2.3.1 Set.prototype.add(value)\n  add: function add(value){\n    return strong.def(this, value = value === 0 ? 0 : value, value);\n  }\n}, strong);","'use strict';\nvar $at  = require('./$.string-at')(true);\n\n// 21.1.3.27 String.prototype[@@iterator]()\nrequire('./$.iter-define')(String, 'String', function(iterated){\n  this._t = String(iterated); // target\n  this._i = 0;                // next index\n// 21.1.5.2.1 %StringIteratorPrototype%.next()\n}, function(){\n  var O     = this._t\n    , index = this._i\n    , point;\n  if(index >= O.length)return {value: undefined, done: true};\n  point = $at(O, index);\n  this._i += point.length;\n  return {value: point, done: false};\n});","'use strict';\n// ECMAScript 6 symbols shim\nvar $              = require('./$')\n  , global         = require('./$.global')\n  , has            = require('./$.has')\n  , DESCRIPTORS    = require('./$.descriptors')\n  , $export        = require('./$.export')\n  , redefine       = require('./$.redefine')\n  , $fails         = require('./$.fails')\n  , shared         = require('./$.shared')\n  , setToStringTag = require('./$.set-to-string-tag')\n  , uid            = require('./$.uid')\n  , wks            = require('./$.wks')\n  , keyOf          = require('./$.keyof')\n  , $names         = require('./$.get-names')\n  , enumKeys       = require('./$.enum-keys')\n  , isArray        = require('./$.is-array')\n  , anObject       = require('./$.an-object')\n  , toIObject      = require('./$.to-iobject')\n  , createDesc     = require('./$.property-desc')\n  , getDesc        = $.getDesc\n  , setDesc        = $.setDesc\n  , _create        = $.create\n  , getNames       = $names.get\n  , $Symbol        = global.Symbol\n  , $JSON          = global.JSON\n  , _stringify     = $JSON && $JSON.stringify\n  , setter         = false\n  , HIDDEN         = wks('_hidden')\n  , isEnum         = $.isEnum\n  , SymbolRegistry = shared('symbol-registry')\n  , AllSymbols     = shared('symbols')\n  , useNative      = typeof $Symbol == 'function'\n  , ObjectProto    = Object.prototype;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar setSymbolDesc = DESCRIPTORS && $fails(function(){\n  return _create(setDesc({}, 'a', {\n    get: function(){ return setDesc(this, 'a', {value: 7}).a; }\n  })).a != 7;\n}) ? function(it, key, D){\n  var protoDesc = getDesc(ObjectProto, key);\n  if(protoDesc)delete ObjectProto[key];\n  setDesc(it, key, D);\n  if(protoDesc && it !== ObjectProto)setDesc(ObjectProto, key, protoDesc);\n} : setDesc;\n\nvar wrap = function(tag){\n  var sym = AllSymbols[tag] = _create($Symbol.prototype);\n  sym._k = tag;\n  DESCRIPTORS && setter && setSymbolDesc(ObjectProto, tag, {\n    configurable: true,\n    set: function(value){\n      if(has(this, HIDDEN) && has(this[HIDDEN], tag))this[HIDDEN][tag] = false;\n      setSymbolDesc(this, tag, createDesc(1, value));\n    }\n  });\n  return sym;\n};\n\nvar isSymbol = function(it){\n  return typeof it == 'symbol';\n};\n\nvar $defineProperty = function defineProperty(it, key, D){\n  if(D && has(AllSymbols, key)){\n    if(!D.enumerable){\n      if(!has(it, HIDDEN))setDesc(it, HIDDEN, createDesc(1, {}));\n      it[HIDDEN][key] = true;\n    } else {\n      if(has(it, HIDDEN) && it[HIDDEN][key])it[HIDDEN][key] = false;\n      D = _create(D, {enumerable: createDesc(0, false)});\n    } return setSymbolDesc(it, key, D);\n  } return setDesc(it, key, D);\n};\nvar $defineProperties = function defineProperties(it, P){\n  anObject(it);\n  var keys = enumKeys(P = toIObject(P))\n    , i    = 0\n    , l = keys.length\n    , key;\n  while(l > i)$defineProperty(it, key = keys[i++], P[key]);\n  return it;\n};\nvar $create = function create(it, P){\n  return P === undefined ? _create(it) : $defineProperties(_create(it), P);\n};\nvar $propertyIsEnumerable = function propertyIsEnumerable(key){\n  var E = isEnum.call(this, key);\n  return E || !has(this, key) || !has(AllSymbols, key) || has(this, HIDDEN) && this[HIDDEN][key]\n    ? E : true;\n};\nvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key){\n  var D = getDesc(it = toIObject(it), key);\n  if(D && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key]))D.enumerable = true;\n  return D;\n};\nvar $getOwnPropertyNames = function getOwnPropertyNames(it){\n  var names  = getNames(toIObject(it))\n    , result = []\n    , i      = 0\n    , key;\n  while(names.length > i)if(!has(AllSymbols, key = names[i++]) && key != HIDDEN)result.push(key);\n  return result;\n};\nvar $getOwnPropertySymbols = function getOwnPropertySymbols(it){\n  var names  = getNames(toIObject(it))\n    , result = []\n    , i      = 0\n    , key;\n  while(names.length > i)if(has(AllSymbols, key = names[i++]))result.push(AllSymbols[key]);\n  return result;\n};\nvar $stringify = function stringify(it){\n  if(it === undefined || isSymbol(it))return; // IE8 returns string on undefined\n  var args = [it]\n    , i    = 1\n    , $$   = arguments\n    , replacer, $replacer;\n  while($$.length > i)args.push($$[i++]);\n  replacer = args[1];\n  if(typeof replacer == 'function')$replacer = replacer;\n  if($replacer || !isArray(replacer))replacer = function(key, value){\n    if($replacer)value = $replacer.call(this, key, value);\n    if(!isSymbol(value))return value;\n  };\n  args[1] = replacer;\n  return _stringify.apply($JSON, args);\n};\nvar buggyJSON = $fails(function(){\n  var S = $Symbol();\n  // MS Edge converts symbol values to JSON as {}\n  // WebKit converts symbol values to JSON as null\n  // V8 throws on boxed symbols\n  return _stringify([S]) != '[null]' || _stringify({a: S}) != '{}' || _stringify(Object(S)) != '{}';\n});\n\n// 19.4.1.1 Symbol([description])\nif(!useNative){\n  $Symbol = function Symbol(){\n    if(isSymbol(this))throw TypeError('Symbol is not a constructor');\n    return wrap(uid(arguments.length > 0 ? arguments[0] : undefined));\n  };\n  redefine($Symbol.prototype, 'toString', function toString(){\n    return this._k;\n  });\n\n  isSymbol = function(it){\n    return it instanceof $Symbol;\n  };\n\n  $.create     = $create;\n  $.isEnum     = $propertyIsEnumerable;\n  $.getDesc    = $getOwnPropertyDescriptor;\n  $.setDesc    = $defineProperty;\n  $.setDescs   = $defineProperties;\n  $.getNames   = $names.get = $getOwnPropertyNames;\n  $.getSymbols = $getOwnPropertySymbols;\n\n  if(DESCRIPTORS && !require('./$.library')){\n    redefine(ObjectProto, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n  }\n}\n\nvar symbolStatics = {\n  // 19.4.2.1 Symbol.for(key)\n  'for': function(key){\n    return has(SymbolRegistry, key += '')\n      ? SymbolRegistry[key]\n      : SymbolRegistry[key] = $Symbol(key);\n  },\n  // 19.4.2.5 Symbol.keyFor(sym)\n  keyFor: function keyFor(key){\n    return keyOf(SymbolRegistry, key);\n  },\n  useSetter: function(){ setter = true; },\n  useSimple: function(){ setter = false; }\n};\n// 19.4.2.2 Symbol.hasInstance\n// 19.4.2.3 Symbol.isConcatSpreadable\n// 19.4.2.4 Symbol.iterator\n// 19.4.2.6 Symbol.match\n// 19.4.2.8 Symbol.replace\n// 19.4.2.9 Symbol.search\n// 19.4.2.10 Symbol.species\n// 19.4.2.11 Symbol.split\n// 19.4.2.12 Symbol.toPrimitive\n// 19.4.2.13 Symbol.toStringTag\n// 19.4.2.14 Symbol.unscopables\n$.each.call((\n  'hasInstance,isConcatSpreadable,iterator,match,replace,search,' +\n  'species,split,toPrimitive,toStringTag,unscopables'\n).split(','), function(it){\n  var sym = wks(it);\n  symbolStatics[it] = useNative ? sym : wrap(sym);\n});\n\nsetter = true;\n\n$export($export.G + $export.W, {Symbol: $Symbol});\n\n$export($export.S, 'Symbol', symbolStatics);\n\n$export($export.S + $export.F * !useNative, 'Object', {\n  // 19.1.2.2 Object.create(O [, Properties])\n  create: $create,\n  // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n  defineProperty: $defineProperty,\n  // 19.1.2.3 Object.defineProperties(O, Properties)\n  defineProperties: $defineProperties,\n  // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n  getOwnPropertyDescriptor: $getOwnPropertyDescriptor,\n  // 19.1.2.7 Object.getOwnPropertyNames(O)\n  getOwnPropertyNames: $getOwnPropertyNames,\n  // 19.1.2.8 Object.getOwnPropertySymbols(O)\n  getOwnPropertySymbols: $getOwnPropertySymbols\n});\n\n// 24.3.2 JSON.stringify(value [, replacer [, space]])\n$JSON && $export($export.S + $export.F * (!useNative || buggyJSON), 'JSON', {stringify: $stringify});\n\n// 19.4.3.5 Symbol.prototype[@@toStringTag]\nsetToStringTag($Symbol, 'Symbol');\n// 20.2.1.9 Math[@@toStringTag]\nsetToStringTag(Math, 'Math', true);\n// 24.3.3 JSON[@@toStringTag]\nsetToStringTag(global.JSON, 'JSON', true);","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar $export  = require('./$.export');\n\n$export($export.P, 'Map', {toJSON: require('./$.collection-to-json')('Map')});","// https://github.com/DavidBruant/Map-Set.prototype.toJSON\nvar $export  = require('./$.export');\n\n$export($export.P, 'Set', {toJSON: require('./$.collection-to-json')('Set')});","require('./es6.array.iterator');\nvar Iterators = require('./$.iterators');\nIterators.NodeList = Iterators.HTMLCollection = Iterators.Array;","// (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\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","'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    this.tileCoords = [];\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    if (features.length) this.splitTile(features, 0, 0, 0);\n\n    if (debug) {\n        if (features.length) 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    solidChildren: false,   // whether to tile solid square tiles further\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\n    // avoid recursion by using a processing queue\n    while (stack.length) {\n        y = stack.pop();\n        x = stack.pop();\n        z = stack.pop();\n        features = stack.pop();\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 * options.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            this.tileCoords.push({z: z, x: x, y: y});\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 solid clipped square\n        if (!options.solidChildren && isClippedSquare(tile, options.extent, options.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 * options.buffer / options.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 (!parent) return null;\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, 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    if (!this.tiles[id]) return null;\n\n    return transformTile(this.tiles[id], extent);\n};\n\nfunction transformTile(tile, extent) {\n    if (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\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\n// checks whether a tile is a whole-area fill after clipping; if it is, there's no sense slicing it further\nfunction isClippedSquare(tile, extent, buffer) {\n\n    var features = tile.source;\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    var len = feature.geometry[0].length;\n    if (len !== 5) return false;\n\n    for (var i = 0; i < len; i++) {\n        var p = transformPoint(feature.geometry[0][i], extent, tile.z2, tile.x, tile.y);\n        if ((p[0] !== -buffer && p[0] !== extent + buffer) ||\n            (p[1] !== -buffer && p[1] !== extent + buffer)) return false;\n    }\n\n    return true;\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","module.exports = invert\n\n/**\n * Inverts a mat3\n *\n * @alias mat3.invert\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nfunction invert(out, a) {\n  var a00 = a[0], a01 = a[1], a02 = a[2]\n  var a10 = a[3], a11 = a[4], a12 = a[5]\n  var a20 = a[6], a21 = a[7], a22 = a[8]\n\n  var b01 = a22 * a11 - a12 * a21\n  var b11 = -a22 * a10 + a12 * a20\n  var b21 = a21 * a10 - a11 * a20\n\n  // Calculate the determinant\n  var det = a00 * b01 + a01 * b11 + a02 * b21\n\n  if (!det) return null\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\n  return out\n}\n","module.exports = normalFromMat4\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @alias mat3.normalFromMat4\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*/\nfunction normalFromMat4(out, a) {\n  var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3]\n  var a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7]\n  var a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11]\n  var a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15]\n\n  var b00 = a00 * a11 - a01 * a10\n  var b01 = a00 * a12 - a02 * a10\n  var b02 = a00 * a13 - a03 * a10\n  var b03 = a01 * a12 - a02 * a11\n  var b04 = a01 * a13 - a03 * a11\n  var b05 = a02 * a13 - a03 * a12\n  var b06 = a20 * a31 - a21 * a30\n  var b07 = a20 * a32 - a22 * a30\n  var b08 = a20 * a33 - a23 * a30\n  var b09 = a21 * a32 - a22 * a31\n  var b10 = a21 * a33 - a23 * a31\n  var b11 = a22 * a33 - a23 * a32\n\n  // Calculate the determinant\n  var det = b00 * b11\n          - b01 * b10\n          + b02 * b09\n          + b03 * b08\n          - b04 * b07\n          + b05 * b06\n\n  if (!det) return null\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","module.exports = copy;\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 */\nfunction copy(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};","module.exports = identity;\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nfunction identity(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};","var identity = require('./identity');\n\nmodule.exports = lookAt;\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 */\nfunction lookAt(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) < 0.000001 &&\n        Math.abs(eyey - centery) < 0.000001 &&\n        Math.abs(eyez - centerz) < 0.000001) {\n        return 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};","module.exports = multiply;\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 */\nfunction multiply(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};","module.exports = perspective;\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 */\nfunction perspective(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};","module.exports = scale;\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 **/\nfunction scale(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};","module.exports = translate;\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 */\nfunction translate(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};","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","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","'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');\n// var 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;\n// module.exports.dump                = dumper.dump;\n// module.exports.safeDump            = dumper.safeDump;\nmodule.exports.YAMLException       = require('./js-yaml/exception');\n\n// Deprecated 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') || (subject === null);\n}\n\n\nfunction isObject(subject) {\n  return (typeof subject === 'object') && (subject !== null);\n}\n\n\nfunction toArray(sequence) {\n  if (Array.isArray(sequence)) return sequence;\n  else if (isNothing(sequence)) 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 (number === 0) && (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","// YAML error class. http://stackoverflow.com/questions/8458984\n//\n'use strict';\n\nfunction YAMLException(reason, mark) {\n  // Super constructor\n  Error.call(this);\n\n  // Include stack trace in error object\n  if (Error.captureStackTrace) {\n    // Chrome and NodeJS\n    Error.captureStackTrace(this, this.constructor);\n  } else {\n    // FF, IE 10+ and Safari 6+. Fallback for others\n    this.stack = (new Error()).stack || '';\n  }\n\n  this.name = 'YAMLException';\n  this.reason = reason;\n  this.mark = mark;\n  this.message = (this.reason || '(unknown reason)') + (this.mark ? ' ' + this.mark.toString() : '');\n}\n\n\n// Inherit from Error\nYAMLException.prototype = Object.create(Error.prototype);\nYAMLException.prototype.constructor = YAMLException;\n\n\nYAMLException.prototype.toString = function toString(compact) {\n  var result = this.name + ': ';\n\n  result += 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 c === 0x2C/* , */ ||\n         c === 0x5B/* [ */ ||\n         c === 0x5D/* ] */ ||\n         c === 0x7B/* { */ ||\n         c === 0x7D/* } */;\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  this.json      = options['json']      || false;\n  this.listener  = options['listener']  || null;\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  if (state.onWarning) {\n    state.onWarning.call(null, generateError(state, message));\n  }\n}\n\n\nvar directiveHandlers = {\n\n  YAML: function handleYamlDirective(state, name, args) {\n\n    var match, major, minor;\n\n    if (state.version !== null) {\n      throwError(state, 'duplication of %YAML directive');\n    }\n\n    if (args.length !== 1) {\n      throwError(state, 'YAML directive accepts exactly one argument');\n    }\n\n    match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n    if (match === null) {\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 (major !== 1) {\n      throwError(state, 'unacceptable YAML version of the document');\n    }\n\n    state.version = args[0];\n    state.checkLineBreaks = (minor < 2);\n\n    if (minor !== 1 && minor !== 2) {\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 (args.length !== 2) {\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 (!(_character === 0x09 ||\n              (0x20 <= _character && _character <= 0x10FFFF))) {\n          throwError(state, 'expected valid JSON character');\n        }\n      }\n    } else if (PATTERN_NON_PRINTABLE.test(_result)) {\n      throwError(state, 'the stream contains non-printable characters');\n    }\n\n    state.result += _result;\n  }\n}\n\nfunction mergeMappings(state, destination, source, overridableKeys) {\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      overridableKeys[key] = true;\n    }\n  }\n}\n\nfunction storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode) {\n  var index, quantity;\n\n  keyNode = String(keyNode);\n\n  if (_result === null) {\n    _result = {};\n  }\n\n  if (keyTag === 'tag:yaml.org,2002:merge') {\n    if (Array.isArray(valueNode)) {\n      for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n        mergeMappings(state, _result, valueNode[index], overridableKeys);\n      }\n    } else {\n      mergeMappings(state, _result, valueNode, overridableKeys);\n    }\n  } else {\n    if (!state.json &&\n        !_hasOwnProperty.call(overridableKeys, keyNode) &&\n        _hasOwnProperty.call(_result, keyNode)) {\n      throwError(state, 'duplicated mapping key');\n    }\n    _result[keyNode] = valueNode;\n    delete overridableKeys[keyNode];\n  }\n\n  return _result;\n}\n\nfunction readLineBreak(state) {\n  var ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x0A/* LF */) {\n    state.position++;\n  } else if (ch === 0x0D/* CR */) {\n    state.position++;\n    if (state.input.charCodeAt(state.position) === 0x0A/* LF */) {\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 (ch !== 0) {\n    while (is_WHITE_SPACE(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (allowComments && ch === 0x23/* # */) {\n      do {\n        ch = state.input.charCodeAt(++state.position);\n      } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && ch !== 0);\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 (ch === 0x20/* Space */) {\n        state.lineIndent++;\n        ch = state.input.charCodeAt(++state.position);\n      }\n    } else {\n      break;\n    }\n  }\n\n  if (checkIndent !== -1 && lineBreaks !== 0 && 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 ((ch === 0x2D/* - */ || ch === 0x2E/* . */) &&\n      ch === state.input.charCodeAt(_position + 1) &&\n      ch === state.input.charCodeAt(_position + 2)) {\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 (count === 1) {\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      ch === 0x23/* # */    ||\n      ch === 0x26/* & */    ||\n      ch === 0x2A/* * */    ||\n      ch === 0x21/* ! */    ||\n      ch === 0x7C/* | */    ||\n      ch === 0x3E/* > */    ||\n      ch === 0x27/* ' */    ||\n      ch === 0x22/* \" */    ||\n      ch === 0x25/* % */    ||\n      ch === 0x40/* @ */    ||\n      ch === 0x60/* ` */) {\n    return false;\n  }\n\n  if (ch === 0x3F/* ? */ || ch === 0x2D/* - */) {\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 (ch !== 0) {\n    if (ch === 0x3A/* : */) {\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 (ch === 0x23/* # */) {\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 (ch !== 0x27/* ' */) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    if (ch === 0x27/* ' */) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (ch === 0x27/* ' */) {\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,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch !== 0x22/* \" */) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    if (ch === 0x22/* \" */) {\n      captureSegment(state, captureStart, state.position, true);\n      state.position++;\n      return true;\n\n    } else if (ch === 0x5C/* \\ */) {\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      overridableKeys = {},\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 (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  while (ch !== 0) {\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 (ch === 0x3F/* ? */) {\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) && ch === 0x3A/* : */) {\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, overridableKeys, keyTag, keyNode, valueNode);\n    } else if (isPair) {\n      _result.push(storeMappingPair(state, null, overridableKeys, 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 (ch === 0x2C/* , */) {\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 (ch !== 0) {\n    ch = state.input.charCodeAt(++state.position);\n\n    if (ch === 0x2B/* + */ || ch === 0x2D/* - */) {\n      if (CHOMPING_CLIP === chomping) {\n        chomping = (ch === 0x2B/* + */) ? 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 (ch === 0x23/* # */) {\n      do { ch = state.input.charCodeAt(++state.position); }\n      while (!is_EOL(ch) && (ch !== 0));\n    }\n  }\n\n  while (ch !== 0) {\n    readLineBreak(state);\n    state.lineIndent = 0;\n\n    ch = state.input.charCodeAt(state.position);\n\n    while ((!detectedIndent || state.lineIndent < textIndent) &&\n           (ch === 0x20/* Space */)) {\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 (emptyLines === 0) {\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      state.result += common.repeat('\\n', emptyLines);\n    }\n\n    detectedIndent = true;\n    emptyLines = 0;\n    captureStart = state.position;\n\n    while (!is_EOL(ch) && (ch !== 0)) {\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 (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (ch !== 0) {\n\n    if (ch !== 0x2D/* - */) {\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) && (ch !== 0)) {\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      overridableKeys = {},\n      keyTag        = null,\n      keyNode       = null,\n      valueNode     = null,\n      atExplicitKey = false,\n      detected      = false,\n      ch;\n\n  if (state.anchor !== null) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (ch !== 0) {\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 ((ch === 0x3F/* ? */ || ch === 0x3A/* : */) && is_WS_OR_EOL(following)) {\n\n      if (ch === 0x3F/* ? */) {\n        if (atExplicitKey) {\n          storeMappingPair(state, _result, overridableKeys, 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 (ch === 0x3A/* : */) {\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, overridableKeys, 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, overridableKeys, 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 && (ch !== 0)) {\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, overridableKeys, 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 (ch !== 0x21/* ! */) return false;\n\n  if (state.tag !== null) {\n    throwError(state, 'duplication of a tag property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  if (ch === 0x3C/* < */) {\n    isVerbatim = true;\n    ch = state.input.charCodeAt(++state.position);\n\n  } else if (ch === 0x21/* ! */) {\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 (ch !== 0 && ch !== 0x3E/* > */);\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 (ch !== 0 && !is_WS_OR_EOL(ch)) {\n\n      if (ch === 0x21/* ! */) {\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 (ch !== 0x26/* & */) return false;\n\n  if (state.anchor !== null) {\n    throwError(state, 'duplication of an anchor property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (ch !== 0 && !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      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch !== 0x2A/* * */) return false;\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (ch !== 0 && !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\n  if (state.listener !== null) {\n    state.listener('open', state);\n  }\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 (indentStatus === 1) {\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 (indentStatus === 1 || 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 (indentStatus === 1) {\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 (state.tag !== null || state.anchor !== null) {\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 (state.tag === null) {\n            state.tag = '?';\n          }\n        }\n\n        if (state.anchor !== null) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else if (indentStatus === 0) {\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 (state.tag !== null && 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 (state.anchor !== null) {\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 (state.result !== null && 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 (state.anchor !== null) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else {\n      throwError(state, 'unknown tag !<' + state.tag + '>');\n    }\n  }\n\n  if (state.listener !== null) {\n    state.listener('close', state);\n  }\n  return state.tag !== null ||  state.anchor !== null || 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 ((ch = state.input.charCodeAt(state.position)) !== 0) {\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (state.lineIndent > 0 || ch !== 0x25/* % */) {\n      break;\n    }\n\n    hasDirectives = true;\n    ch = state.input.charCodeAt(++state.position);\n    _position = state.position;\n\n    while (ch !== 0 && !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 (ch !== 0) {\n      while (is_WHITE_SPACE(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      if (ch === 0x23/* # */) {\n        do { ch = state.input.charCodeAt(++state.position); }\n        while (ch !== 0 && !is_EOL(ch));\n        break;\n      }\n\n      if (is_EOL(ch)) break;\n\n      _position = state.position;\n\n      while (ch !== 0 && !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 (ch !== 0) readLineBreak(state);\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 (state.lineIndent === 0 &&\n      state.input.charCodeAt(state.position)     === 0x2D/* - */ &&\n      state.input.charCodeAt(state.position + 1) === 0x2D/* - */ &&\n      state.input.charCodeAt(state.position + 2) === 0x2D/* - */) {\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 (state.input.charCodeAt(state.position) === 0x2E/* . */) {\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 (input.charCodeAt(input.length - 1) !== 0x0A/* LF */ &&\n        input.charCodeAt(input.length - 1) !== 0x0D/* CR */) {\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  // Use 0 as string terminator. That significantly simplifies bounds check.\n  state.input += '\\0';\n\n  while (state.input.charCodeAt(state.position) === 0x20/* Space */) {\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);\n\n  if (documents.length === 0) {\n    /*eslint-disable no-undefined*/\n    return undefined;\n  } else if (documents.length === 1) {\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) return null;\n\n  indent = indent || 4;\n  maxLength = maxLength || 75;\n\n  head = '';\n  start = this.position;\n\n  while (start > 0 && '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(start - 1)) === -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 && '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(end)) === -1) {\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 exclude.indexOf(index) === -1;\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 && type.loadKind !== 'scalar') {\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 (map !== null) {\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 (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) {\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 (YAML_NODE_KINDS.indexOf(this.kind) === -1) {\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 (data === null) return false;\n\n  var code, idx, bitlen = 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 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) return new NodeBuffer(result);\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 (data === null) return false;\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.prototype.toString.call(object) === '[object Boolean]';\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 (data === null) return false;\n\n  if (!YAML_FLOAT_PATTERN.test(data)) 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 ('+-'.indexOf(value[0]) >= 0) {\n    value = value.slice(1);\n  }\n\n  if (value === '.inf') {\n    return (sign === 1) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n  } else if (value === '.nan') {\n    return NaN;\n\n  } else if (value.indexOf(':') >= 0) {\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\n\nvar SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/;\n\nfunction representYamlFloat(object, style) {\n  var res;\n\n  if (isNaN(object)) {\n    switch (style) {\n      case 'lowercase': return '.nan';\n      case 'uppercase': return '.NAN';\n      case 'camelcase': return '.NaN';\n    }\n  } else if (Number.POSITIVE_INFINITY === object) {\n    switch (style) {\n      case 'lowercase': return '.inf';\n      case 'uppercase': return '.INF';\n      case 'camelcase': return '.Inf';\n    }\n  } else if (Number.NEGATIVE_INFINITY === object) {\n    switch (style) {\n      case 'lowercase': return '-.inf';\n      case 'uppercase': return '-.INF';\n      case 'camelcase': return '-.Inf';\n    }\n  } else if (common.isNegativeZero(object)) {\n    return '-0.0';\n  }\n\n  res = object.toString(10);\n\n  // JS stringifier can build scientific format without dots: 5e-100,\n  // while YAML requres dot: 5.e-100. Fix it with simple hack\n\n  return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace('e', '.e') : res;\n}\n\nfunction isFloat(object) {\n  return (Object.prototype.toString.call(object) === '[object Number]') &&\n         (object % 1 !== 0 || 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 (data === null) return false;\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') return false;\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))) return false;\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))) return false;\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 (value === '0') return 0;\n\n  if (ch === '0') {\n    if (value[1] === 'b') return sign * parseInt(value.slice(2), 2);\n    if (value[1] === 'x') return sign * parseInt(value, 16);\n    return sign * parseInt(value, 8);\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.prototype.toString.call(object)) === '[object Number]' &&\n         (object % 1 === 0 && !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  // workaround to exclude package from browserify list.\n  var _require = require;\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 (data === null) return false;\n\n  try {\n    var source = '(' + data + ')',\n        ast    = esprima.parse(source, { range: true });\n\n    if (ast.type                    !== 'Program'             ||\n        ast.body.length             !== 1                     ||\n        ast.body[0].type            !== 'ExpressionStatement' ||\n        ast.body[0].expression.type !== 'FunctionExpression') {\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 (ast.type                    !== 'Program'             ||\n      ast.body.length             !== 1                     ||\n      ast.body[0].type            !== 'ExpressionStatement' ||\n      ast.body[0].expression.type !== 'FunctionExpression') {\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.prototype.toString.call(object) === '[object Function]';\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 (data === null) return false;\n  if (data.length === 0) return false;\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) modifiers = tail[1];\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\n  return true;\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) modifiers = tail[1];\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) result += 'g';\n  if (object.multiline) result += 'm';\n  if (object.ignoreCase) result += 'i';\n\n  return result;\n}\n\nfunction isRegExp(object) {\n  return Object.prototype.toString.call(object) === '[object RegExp]';\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 typeof object === 'undefined';\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 data !== null ? data : {}; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlMerge(data) {\n  return data === '<<' || data === null;\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 (data === null) return true;\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 object === null;\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 (data === null) return true;\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 (_toString.call(pair) !== '[object Object]') return false;\n\n    for (pairKey in pair) {\n      if (_hasOwnProperty.call(pair, pairKey)) {\n        if (!pairHasKey) pairHasKey = true;\n        else return false;\n      }\n    }\n\n    if (!pairHasKey) return false;\n\n    if (objectKeys.indexOf(pairKey) === -1) objectKeys.push(pairKey);\n    else return false;\n  }\n\n  return true;\n}\n\nfunction constructYamlOmap(data) {\n  return data !== null ? 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 (data === null) return true;\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 (_toString.call(pair) !== '[object Object]') return false;\n\n    keys = Object.keys(pair);\n\n    if (keys.length !== 1) return false;\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return true;\n}\n\nfunction constructYamlPairs(data) {\n  if (data === null) return [];\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 data !== null ? data : []; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n  if (data === null) return true;\n\n  var key, object = data;\n\n  for (key in object) {\n    if (_hasOwnProperty.call(object, key)) {\n      if (object[key] !== null) return false;\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlSet(data) {\n  return data !== null ? 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 data !== null ? 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 (data === null) return false;\n  if (YAML_TIMESTAMP_REGEXP.exec(data) === null) return false;\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 (match === null) throw new Error('Date resolve error');\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] === '-') delta = -delta;\n  }\n\n  date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n  if (delta) date.setTime(date.getTime() - delta);\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","/*\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\nfunction notNull(x)  { return x != null; }\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[0] === '$') {\n        return 'context.' + key.substring(1);\n    }\n    return 'context.feature.properties.' + key;\n}\n\nfunction nullValue(key, value) {\n    return ' true ';\n}\n\nfunction propertyEqual(key, value) {\n    return wrap(maybeQuote(value) + ' === ' + lookUp(key));\n}\n\nfunction propertyOr(key, values) {\n    return wrap(values.map(function (x) { return propertyEqual(key, x); }).join(' || '));\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 (values && values.length > 0) ? printNested(values.map(parseFilter), '||') : 'true';\n}\n\nfunction all(_, values) {\n    return (values && values.length > 0) ? printNested(values.map(parseFilter), '&&') : 'true';\n}\n\nfunction not(key, value) {\n    return '!' + wrap(parseFilter(value).join(' && '));\n}\n\nfunction none(key, values) {\n    return '!' + wrap(any(null, values));\n}\n\nfunction propertyMatchesBoolean(key, value) {\n    return wrap(lookUp(key) + (value ? ' != ' : ' == ')  + 'null');\n}\n\nfunction rangeMatch(key, values) {\n    var expressions = [];\n\n    if (values.max) {\n        expressions.push('' + lookUp(key) + ' < ' + values.max);\n    }\n\n    if (values.min) {\n        expressions.push('' + lookUp(key) + ' >= ' + values.min);\n    }\n\n    return wrap(expressions.join(' && '));\n}\n\nfunction parseFilter(filter) {\n    var filterAST = [];\n\n    // Function filter\n    if (typeof filter === 'function') {\n        return [wrap(filter.toString() + '(context)')];\n    }\n    // Array filter, implicit 'any'\n    else if (Array.isArray(filter)) {\n        return [any(null, filter)];\n    }\n    // Null filter object\n    else if (filter == null) {\n        return ['true'];\n    }\n\n    // Object filter, e.g. implicit 'all'\n    var keys = Object.keys(filter);\n    for (var k=0; k < keys.length; k++) {\n        var key = keys[k];\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 (key === 'not') {\n            filterAST.push(not(key, value));\n        } else if (key === 'any') {\n            filterAST.push(any(key, value));\n        } else if (key === 'all') {\n            filterAST.push(all(key, value));\n        } else if (key === 'none') {\n            filterAST.push(none(key, value));\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 if (value == null) {\n            filterAST.push(nullValue(key, value));\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"]}","'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","// shim for using process in browser\n\nvar process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n    && window.setImmediate;\n    var canMutationObserver = typeof window !== 'undefined'\n    && window.MutationObserver;\n    var canPost = typeof window !== 'undefined'\n    && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    var queue = [];\n\n    if (canMutationObserver) {\n        var hiddenDiv = document.createElement(\"div\");\n        var observer = new MutationObserver(function () {\n            var queueList = queue.slice();\n            queue.length = 0;\n            queueList.forEach(function (fn) {\n                fn();\n            });\n        });\n\n        observer.observe(hiddenDiv, { attributes: true });\n\n        return function nextTick(fn) {\n            if (!queue.length) {\n                hiddenDiv.setAttribute('yes', 'no');\n            }\n            queue.push(fn);\n        };\n    }\n\n    if (canPost) {\n        window.addEventListener('message', function (ev) {\n            var source = ev.source;\n            if ((source === window || source === null) && ev.data === 'process-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('process-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\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","(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/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}"]}","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","// Geometry building functions\nimport Geo from '../geo';\n\nexport const tile_bounds = [\n    { x: 0, y: 0},\n    { x: Geo.tile_scale, y: -Geo.tile_scale } // TODO: correct for flipped y-axis?\n];\n\nexport const default_uvs = [0, 0, 1, 1];\n\n// Tests if a line segment (from point A to B) is outside the tile bounds\n// (within a certain tolerance to account for geometry nearly on tile edges)\nexport function outsideTile (_a, _b, tolerance) {\n    let tile_min = tile_bounds[0];\n    let tile_max = tile_bounds[1];\n\n    // TODO: fix flipped Y coords here, confusing with 'max' reference\n    if ((_a[0] <= tile_min.x + tolerance && _b[0] <= tile_min.x + tolerance) ||\n        (_a[0] >= tile_max.x - tolerance && _b[0] >= tile_max.x - tolerance) ||\n        (_a[1] >= tile_min.y - tolerance && _b[1] >= tile_min.y - tolerance) ||\n        (_a[1] <= tile_max.y + tolerance && _b[1] <= tile_max.y + tolerance)) {\n        return true;\n    }\n\n    return false;\n}\n","// Point builders\nimport { default_uvs } from './common';\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.\nexport function buildQuadsForPoints (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        var [min_u, min_v, max_u, max_v] = texcoord_scale || default_uvs;\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","// Polygon builders\nimport Geo from '../geo';\nimport Vector from '../vector';\nimport { default_uvs, outsideTile } from './common';\n\nimport earcut from 'earcut';\n\nconst up_vec3 = [0, 0, 1];\n\n// Tesselate a flat 2D polygon\n// x & y coordinates will be set as first two elements of provided vertex_template\nexport function buildPolygons (\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 || default_uvs;\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 = 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\nexport function buildExtrudedPolygons (\n    polygons,\n    z, height, min_height,\n    vertex_data, vertex_template,\n    normal_index,\n    normal_normalize,\n    {\n        remove_tile_edges,\n        tile_edge_tolerance,\n        texcoord_index,\n        texcoord_scale,\n        texcoord_normalize,\n        winding\n    }) {\n\n    // Top\n    var min_z = z + (min_height || 0);\n    var max_z = z + height;\n    vertex_template[2] = max_z;\n    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 || default_uvs;\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                if (remove_tile_edges && outsideTile(contour[w], contour[w+1], tile_edge_tolerance)) {\n                    continue; // don't extrude tile edges\n                }\n\n                // Wall order is dependent on winding order, so that normals face outward\n                let w0, w1;\n                if (winding === 'CCW') {\n                    w0 = w;\n                    w1 = w+1;\n                }\n                else {\n                    w0 = w+1;\n                    w1 = w;\n                }\n\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[w1][0], contour[w1][1], max_z],\n                    [contour[w1][0], contour[w1][1], min_z],\n                    [contour[w0][0], contour[w0][1], min_z],\n                    // Triangle\n                    [contour[w0][0], contour[w0][1], min_z],\n                    [contour[w0][0], contour[w0][1], max_z],\n                    [contour[w1][0], contour[w1][1], max_z]\n                ];\n\n                // Calc the normal of the wall from up vector and one segment of the wall triangles\n                let wall_vec = Vector.normalize([contour[w1][0] - contour[w0][0], contour[w1][1] - contour[w0][1], 0]);\n                let normal = Vector.cross(up_vec3, wall_vec);\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// Triangulation using earcut\n// https://github.com/mapbox/earcut\nexport function triangulatePolygon (contours) {\n    return earcut(contours);\n}\n","// Geometry building functions\n\nimport Vector from '../vector';\nimport Geo from '../geo';\nimport { default_uvs, outsideTile } from './common';\n\nconst zero_vec2 = [0, 0];\n\n// Build tessellated triangles for a polyline\nconst corners_for_cap = {\n    butt: 0,\n    square: 2,\n    round: 3\n};\n\nconst triangles_for_join = {\n    miter: 0,\n    bevel: 1,\n    round: 3\n};\n\n// Scaling factor to add precision to line texture V coordinate packed as normalized short\nconst v_scale_adjust = Geo.tile_scale;\n\nexport function buildPolylines (\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        texcoord_ratio,\n        scaling_index,\n        scaling_normalize,\n        join, cap,\n        miter_limit\n    }) {\n\n    var cornersOnCap = corners_for_cap[cap] || 0;         // default 'butt'\n    var trianglesOnJoin = triangles_for_join[join] || 0;  // default 'miter'\n\n    // Configure miter limit\n    if (trianglesOnJoin === 0) {\n        miter_limit = miter_limit || 3; // default miter limit\n        var miter_len_sq = miter_limit * miter_limit;\n    }\n\n    // Build variables\n    if (texcoord_index) {\n        texcoord_normalize = texcoord_normalize || 1;\n        texcoord_ratio = texcoord_ratio || 1;\n        var [min_u, min_v, max_u, max_v] = texcoord_scale || default_uvs;\n    }\n\n    // Values that are constant for each line and are passed to helper functions\n    var context = {\n        vertex_data,\n        vertex_template,\n        half_width: 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        v_scale: 1 / ((width * texcoord_ratio) * v_scale_adjust), // scales line texture as a ratio of the line's width\n        total_dist: 0,\n        num_pairs: 0\n    };\n\n    for (var ln = 0; ln < lines.length; ln++) {\n        // Remove dupe points from lines\n        var line = dedupeLine(lines[ln], closed_polygon);\n        if (!line) {\n            continue; // skip if no valid line remaining\n        }\n\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(context);\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(outsideTile(line[i], line[lineSize-2], 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 (outsideTile(coordCurr, coordNext, tile_edge_tolerance)) {\n                        normCurr = Vector.normalize(Vector.perp(coordPrev, coordCurr));\n                        if (isPrev) {\n                            addVertexPair(\n                                coordCurr, normCurr,\n                                context.texcoords && Vector.length(Vector.sub(coordCurr, coordPrev)),\n                                context);\n                            context.num_pairs++;\n\n                            // Add vertices to buffer acording their index\n                            indexPairs(context);\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, context);\n                }\n\n                //  Miter limit: if miter join is too sharp, convert to bevel instead\n                if (trianglesOnJoin === 0 && Vector.lengthSq(normCurr) > miter_len_sq) {\n                    trianglesOnJoin = triangles_for_join['bevel']; // switch to bevel\n                }\n\n                // If it's a JOIN\n                if (trianglesOnJoin !== 0 && isPrev && isNext) {\n                    addJoin([coordPrev, coordCurr, coordNext],\n                            [normPrev,normCurr, normNext],\n                            trianglesOnJoin,\n                            context);\n                } else {\n                    addVertexPair(\n                        coordCurr, normCurr,\n                        context.texcoords && Vector.length(Vector.sub(coordCurr, coordPrev)),\n                        context);\n                }\n\n                if (isNext) {\n                   context.num_pairs++;\n                }\n\n                isPrev = true;\n            }\n        }\n\n        // Add vertices to buffer according to their index\n        indexPairs(context);\n\n         // If it's the END of a LINE\n        if(!closed_polygon) {\n            addCap(coordCurr, normCurr, cornersOnCap , false, context);\n        }\n    }\n}\n\n// Remove duplicate points from a line, creating a new line only when points must be removed\nfunction dedupeLine (line, closed) {\n    let i, dupes;\n\n    // Collect dupe points\n    for (i=0; i < line.length - 1; i++) {\n        if (line[i][0] === line[i+1][0] && line[i][1] === line[i+1][1]) {\n            dupes = dupes || [];\n            dupes.push(i);\n        }\n    }\n\n    // Remove dupe points\n    if (dupes) {\n        line = line.slice(0);\n        dupes.forEach(d => line.splice(d, 1));\n    }\n\n    // Line needs at least 2 points, polygon needs at least 3 (+1 to close)\n    if (!closed && line.length < 2 || closed && line.length < 4) {\n        return;\n    }\n    return line;\n}\n\n// Add to equidistant pairs of vertices (internal method for polyline builder)\nfunction addVertex(coord, normal, uv, { half_width, 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] * half_width,\n                       coord[1] + normal[1] * half_width]);\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, dist, context) {\n    if (context.texcoords) {\n        context.total_dist += dist * context.v_scale;\n        addVertex(coord, normal, [context.max_u, context.total_dist], context);\n        addVertex(coord, Vector.neg(normal), [context.min_u, context.total_dist], context);\n    }\n    else {\n        addVertex(coord, normal, null, context);\n        addVertex(coord, Vector.neg(normal), null, context);\n    }\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, context) {\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(context);\n\n    // Initial parameters\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n\n    // Calculate the angle between A and B\n    var angle_delta = Vector.angleBetween(nA, nB);\n\n    // Calculate the angle for each triangle\n    var angle_step = angle_delta/numTriangles;\n\n    // Joins that turn left or right behave diferently...\n    // triangles need to be rotated in diferent directions\n    if (!signed) {\n        angle_step *= -1;\n    }\n\n    if (context.texcoords) {\n        var uvCurr = Vector.set(uA);\n        var uv_delta = Vector.div(Vector.sub(uB,uA), numTriangles);\n    }\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, context);\n\n    //  Add first corner\n    addVertex(coord, normCurr, uA, context);\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_step);     //  Rotate the extrusion normal\n        if (context.texcoords) {\n            uvCurr = Vector.add(uvCurr,uv_delta);\n        }\n        addVertex(coord, normCurr, uvCurr, context);      //  Add computed corner\n    }\n\n    // Index the vertices\n    for (var i = 0; i < numTriangles; i++) {\n        if (signed) {\n            addIndex(i+2, context);\n            addIndex(0, context);\n            addIndex(i+1, context);\n        } else {\n            addIndex(i+1, context);\n            addIndex(0, context);\n            addIndex(i+2, context);\n        }\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n\n//  addBevel    A ----- B\n//             / \\ , . / \\\n//           /   /\\   /\\  \\\n//              /  \\ /   \\ \\\n//                / C \\\nfunction addBevel (coord, nA, nC, nB, uA, uC, uB, signed, context) {\n    // Add previous vertices to buffer and clear the buffers and index pairs\n    // because we are going to add more triangles.\n    indexPairs(context);\n\n    //  Add the FIRST and CENTER vertex\n    addVertex(coord, nC, uC, context);\n    addVertex(coord, nA, uA, context);\n    addVertex(coord, nB, uB, context);\n\n    if (signed) {\n        addIndex(2, context);\n        addIndex(0, context);\n        addIndex(1, context);\n    } else {\n        addIndex(1, context);\n        addIndex(0, context);\n        addIndex(2, context);\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n\n\n//  Tessalate a SQUARE geometry between A and B     + ........+\n//  and interpolating their UVs                     : \\  2  / :\n//                                                  : 1\\   /3 :\n//                                                  A -- C -- B\nfunction addSquare (coord, nA, nB, uA, uC, uB, signed, context) {\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(context);\n\n    // Initial parameters\n    var normCurr = Vector.set(nA);\n    var normPrev = [0,0];\n    if (context.texcoords) {\n        var uvCurr = Vector.set(uA);\n        var uv_delta = Vector.div(Vector.sub(uB,uA), 4);\n    }\n\n    // First and last cap have different directions\n    var angle_step = 0.78539816339; // PI/4 = 45 degrees\n    if (!signed) {\n        angle_step *= -1;\n    }\n\n    //  Add the FIRST and CENTER vertex\n    //  The triangles will be add in a FAN style around it\n    //\n    //                       A -- C\n    addVertex(coord, zero_vec2, uC, context);\n\n    //  Add first corner     +\n    //                       :\n    //                       A -- C\n    addVertex(coord, normCurr, uA, context);\n\n    // Iterate through the rest of the coorners completing the triangles\n    // (except the corner 1 to save one triangle to be draw )\n    for (var t = 0; t < 4; t++) {\n\n        // 0     1     2\n        //  + ........+\n        //  : \\     / :\n        //  :  \\   /  :\n        //  A -- C -- B  3\n\n        normPrev = Vector.normalize(normCurr);\n        normCurr = Vector.rot( Vector.normalize(normCurr), angle_step);     //  Rotate the extrusion normal\n\n        if (t === 0 || t === 2) {\n            // In order to make this \"fan\" look like a square the mitters need to be streach\n            var scale = 2 / (1 + Math.abs(Vector.dot(normPrev, normCurr)));\n            normCurr = Vector.mult(normCurr, scale*scale);\n        }\n\n        if (context.texcoords) {\n            uvCurr = Vector.add(uvCurr,uv_delta);\n        }\n\n        if (t !== 1) {\n            //  Add computed corner (except the corner 1)\n            addVertex(coord, normCurr, uvCurr, context);\n        }\n    }\n\n    for (var i = 0; i < 3; i++) {\n        if (signed) {\n            addIndex(i+2, context);\n            addIndex(0, context);\n            addIndex(i+1, context);\n        } else {\n            addIndex(i+1, context);\n            addIndex(0, context);\n            addIndex(i+2, context);\n        }\n    }\n\n    // Clear the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.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, nTriangles, context) {\n    var signed = Vector.signed_area(coords[0], coords[1], coords[2]) > 0;\n    var nA = normals[0],              // normal to point A (aT)\n        nC = Vector.neg(normals[1]),  // normal to center (-vP)\n        nB = normals[2];              // normal to point B (bT)\n    var uA, uB, uC;\n\n    if (context.texcoords) {\n        context.total_dist += Vector.length(Vector.sub(coords[1], coords[0])) * context.v_scale;\n        uA = [context.max_u, context.total_dist];\n        uC = [context.min_u, context.total_dist];\n        uB = uA;\n    }\n\n    if (signed) {\n        addVertex(coords[1], nA, uA, context);\n        addVertex(coords[1], nC, uC, context);\n    } else {\n        nA = Vector.neg(normals[0]);\n        nC = normals[1];\n        nB = Vector.neg(normals[2]);\n\n        if (context.texcoords) {\n            uA = [context.min_u, context.total_dist];\n            uC = [context.max_u, context.total_dist];\n            uB = uA;\n        }\n        addVertex(coords[1], nC, uC, context);\n        addVertex(coords[1], nA, uA, context);\n    }\n\n    if (nTriangles === 1) {\n        addBevel(coords[1], nA, nC, nB, uA, uC, uB, signed, context);\n    } else if (nTriangles > 1){\n        addFan(coords[1], nA, nC, nB, uA, uC, uB, signed, nTriangles, context);\n    }\n\n    if (signed) {\n        addVertex(coords[1], nB, uB, context);\n        addVertex(coords[1], nC, uC, context);\n    } else {\n        addVertex(coords[1], nC, uC, context);\n        addVertex(coords[1], nB, uB, context);\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, context) {\n\n    if (numCorners < 1) {\n        return;\n    }\n\n    // UVs\n    var uvA, uvB, uvC;\n    if (context.texcoords) {\n        uvC = [context.min_u+(context.max_u-context.min_u)/2, context.total_dist];   // Center point UVs\n        uvA = [context.min_u, context.total_dist];                                   // Beginning angle UVs\n        uvB = [context.max_u, context.total_dist];                                   // Ending angle UVs\n    }\n\n    if ( numCorners === 2 ){\n        // If caps are set as squares\n        addSquare( coord,\n                   Vector.neg(normal), normal,\n                   uvA, uvC, uvB,\n                   isBeginning,\n                   context);\n    } else {\n        // If caps are set as round ( numCorners===3 )\n        addFan( coord,\n                Vector.neg(normal), zero_vec2, normal,\n                uvA, uvC, uvB,\n                isBeginning, numCorners*2, context);\n    }\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, half_width, 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 half_width 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] = half_width;\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 (context) {\n    // Add vertices to buffer acording their index\n    for (var i = 0; i < context.num_pairs; i++) {\n        addIndex(2*i+2, context);\n        addIndex(2*i+1, context);\n        addIndex(2*i+0, context);\n\n        addIndex(2*i+2, context);\n        addIndex(2*i+3, context);\n        addIndex(2*i+1, context);\n    }\n\n    context.num_pairs = 0;\n\n    // Clean the buffer\n    context.vertices = [];\n    if (context.scalingVecs) {\n        context.scalingVecs = [];\n    }\n    if (context.texcoords) {\n        context.texcoords = [];\n    }\n}\n","import Utils from './utils/utils';\nimport ShaderProgram from './gl/shader_program';\nimport {mat4, mat3, vec3} from './utils/gl-matrix';\n\n// Abstract base class\nexport default class Camera {\n\n    constructor(name, view, options = {}) {\n        this.view = view;\n        this.position = options.position;\n        this.zoom = options.zoom;\n    }\n\n    // Create a camera by type name, factory-style\n    static create(name, view, config) {\n        switch (config.type) {\n            case 'isometric':\n                return new IsometricCamera(name, view, config);\n            case 'flat':\n                return new FlatCamera(name, view, config);\n            case 'perspective':\n            /* falls through */\n            default:\n                return new PerspectiveCamera(name, view, config);\n        }\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 pass for feature selection, etc.)\n    setupProgram(program) {\n    }\n\n    // Sync camera position/zoom to scene view\n    updateView () {\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.view.setView(view);\n        }\n    }\n\n    // Set model-view and normal matrices\n    setupMatrices (matrices, program) {\n        // Model view matrix - transform tile space into view space (meters, relative to camera)\n        mat4.multiply(matrices.model_view32, this.view_matrix, matrices.model);\n        program.uniform('Matrix4fv', 'u_modelView', false, matrices.model_view32);\n\n        // Normal matrices - transforms surface normals into view space\n        mat3.normalFromMat4(matrices.normal32, matrices.model_view32);\n        mat3.invert(matrices.inverse_normal32, matrices.normal32);\n        program.uniform('Matrix3fv', 'u_normalMatrix', false, matrices.normal32);\n        program.uniform('Matrix3fv', 'u_inverseNormalMatrix', false, matrices.inverse_normal32);\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, view, options = {}) {\n        super(name, view, 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.view_matrix = new Float64Array(16);\n        this.projection_matrix = 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.view.size.css.height * this.view.meters_per_pixel;\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.view.zoom, this.focal_length),\n            fov: Utils.interpolate(this.view.zoom, this.fov)\n         });\n\n        // View matrix\n        var position = [this.view.center.meters.x, this.view.center.meters.y, height];\n        this.position_meters = position;\n\n        // mat4.lookAt(this.view_matrix,\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.view_matrix,\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.projection_matrix, fov, this.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.view.size.css.width;\n        this.vanishing_point_skew[1] = this.vanishing_point[1] / this.view.size.css.height;\n\n        // Adjust projection matrix to include vanishing point skew\n        this.projection_matrix[8] = -this.vanishing_point_skew[0]; // z column of x row, e.g. amount z skews x\n        this.projection_matrix[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.projection_matrix, this.projection_matrix,\n            vec3.fromValues(\n                viewport_height/2 * this.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.projection_matrix, this.projection_matrix, 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.projection_matrix);\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, view, options = {}) {\n        super(name, view, 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.view_matrix = new Float64Array(16);\n        this.projection_matrix = 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.view.size.css.height * this.view.meters_per_pixel;\n        var position = [this.view.center.meters.x, this.view.center.meters.y, this.viewport_height];\n        this.position_meters = position;\n\n        // View\n        mat4.identity(this.view_matrix);\n        mat4.translate(this.view_matrix, this.view_matrix, vec3.fromValues(-position[0], -position[1], 0));\n\n        // Projection\n        mat4.identity(this.projection_matrix);\n\n        // apply isometric skew\n        this.projection_matrix[8] = this.axis.x / this.view.aspect; // z column of x row, e.g. amount z skews x\n        this.projection_matrix[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.projection_matrix, this.projection_matrix,\n            vec3.fromValues(\n                2 / this.view.size.meters.x,\n                2 / this.view.size.meters.y,\n                2 / this.view.size.meters.y\n            )\n        );\n    }\n\n    setupProgram(program) {\n        program.uniform('Matrix4fv', 'u_projection', false, this.projection_matrix);\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, view, options = {}) {\n        super(name, view, 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.default_source_max_zoom = 18;\nGeo.default_view_max_zoom = 20;\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\n\nlet meters_per_pixel = [];\nGeo.metersPerPixel = function (z) {\n    meters_per_pixel[z] = meters_per_pixel[z] || Geo.min_zoom_meters_per_pixel / Math.pow(2, z);\n    return meters_per_pixel[z];\n};\n\nlet meters_per_tile = [];\nGeo.metersPerTile = function (z) {\n    meters_per_tile[z] = meters_per_tile[z] || Geo.circumference_meters / Math.pow(2, z);\n    return meters_per_tile[z];\n};\n\n// Conversion functions based on an defined tile scale\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\nlet units_per_meter = [];\nGeo.unitsPerMeter = function (z) {\n    units_per_meter[z] = units_per_meter[z] || Geo.tile_scale / (Geo.tile_size * Geo.metersPerPixel(z));\n    return units_per_meter[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 == null) {\n        return; // skip if missing geometry (valid GeoJSON)\n    }\n\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    let area = Geo.signedPolygonAreaSum(ring);\n    if (area > 0) {\n        return 'CW';\n    }\n    else if (area < 0) {\n        return 'CCW';\n    }\n    // return undefined on zero area polygon\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    if (!fullscreen) {\n        Context.resize(gl, parseFloat(canvas.style.width), parseFloat(canvas.style.height), options.device_pixel_ratio);\n    }\n    else {\n        Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\n        window.addEventListener('resize', function () {\n            Context.resize(gl, window.innerWidth, window.innerHeight, options.device_pixel_ratio);\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(width * device_pixel_ratio);\n    gl.canvas.height = Math.round(height * device_pixel_ratio);\n    gl.bindFramebuffer(gl.FRAMEBUFFER, null);\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        RenderState.defaults = {};\n        // Culling\n        RenderState.defaults.culling = true;\n        RenderState.defaults.culling_face = gl.BACK;\n\n        // Blending\n        RenderState.defaults.blending = false;\n        RenderState.defaults.blending_src = gl.ONE_MINUS_SRC_ALPHA;\n        RenderState.defaults.blending_dst = gl.ONE_MINUS_SRC_ALPHA;\n        RenderState.defaults.blending_src_alpha = gl.ONE;\n        RenderState.defaults.blending_dst_alpha = gl.ONE_MINUS_SRC_ALPHA;\n\n        // Depth test/write\n        RenderState.defaults.depth_write = true;\n        RenderState.defaults.depth_test = true;\n        gl.depthFunc(gl.LESS); // depth function only needs to be set once\n\n    \t// Culling\n    \tRenderState.culling = new RenderState(\n    \t\t{ cull: RenderState.defaults.culling, face: RenderState.defaults.culling_face },\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                blend: RenderState.defaults.blending,\n                src: RenderState.defaults.blending_src,\n                dst: RenderState.defaults.blending_dst,\n                src_alpha: RenderState.defaults.blending_src_alpha,\n                dst_alpha: RenderState.defaults.blending_dst_alpha\n            },\n            (value) => {\n    \t\t\tif (value.blend) {\n            \t\tgl.enable(gl.BLEND);\n\n                    if (value.src_alpha && value.dst_alpha) {\n                        gl.blendFuncSeparate(value.src, value.dst, value.src_alpha, value.dst_alpha);\n                    }\n                    else {\n                        gl.blendFunc(value.src, value.dst);\n                    }\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: RenderState.defaults.depth_write },\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            { depth_test: RenderState.defaults.depth_test },\n            (value) => {\n    \t\t\tif (value.depth_test) {\n            \t\tgl.enable(gl.DEPTH_TEST);\n    \t\t\t} else {\n            \t\tgl.disable(gl.DEPTH_TEST);\n    \t\t\t}\n    \t\t}\n    \t);\n\n    }\n}\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        let precision = '';\n        let high = this.gl.getShaderPrecisionFormat(this.gl.FRAGMENT_SHADER, this.gl.HIGH_FLOAT);\n        if (high && high.precision > 0) {\n            precision = 'precision highp float;\\n';\n        }\n        else {\n            precision = 'precision mediump float;\\n';\n        }\n\n        defines['TANGRAM_VERTEX_SHADER'] = true;\n        defines['TANGRAM_FRAGMENT_SHADER'] = false;\n        this.computed_vertex_source =\n            header +\n            precision +\n            ShaderProgram.buildDefineString(defines) +\n            this.computed_vertex_source;\n\n        // Precision qualifier only valid in fragment shader\n        // NB: '#extension' statements added to fragment shader only, as IE11 throws error when they appear in\n        // vertex shader (even when guarded by #ifdef), and no WebGL extensions require '#extension' in vertex shaders\n        defines['TANGRAM_VERTEX_SHADER'] = false;\n        defines['TANGRAM_FRAGMENT_SHADER'] = true;\n        this.computed_fragment_source =\n            ShaderProgram.buildExtensionString(extensions) +\n            header +\n            precision +\n            ShaderProgram.buildDefineString(defines) +\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)) {\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)) {\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            log.warn(`Can't find texture '${texture_name}'`);\n            return;\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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\\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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\\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 += `#ifdef GL_${ext}\\n#extension GL_${ext} : enable\\n#endif\\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/accessors'] =\n\"#ifdef TANGRAM_VERTEX_SHADER\\n\" +\n\"\\n\" +\n\"// Vertex position in model space: [0, 1] range over the local tile\\n\" +\n\"// Note positions can be outside that range due to unclipped geometry, geometry higher than a unit cube, etc.\\n\" +\n\"vec4 modelPosition() {\\n\" +\n\"    return\\n\" +\n\"        vec4(\\n\" +\n\"            SHORT(a_position.xyz)                       // scale normalized short to full range\\n\" +\n\"            / TANGRAM_TILE_SCALE                        // scale coords to ~0-1 range\\n\" +\n\"            * exp2(u_tile_origin.z - u_tile_origin.w),  // adjust for tile overzooming\\n\" +\n\"        1.)\\n\" +\n\"        + vec4(0., 1., 0., 0.);\\n\" +\n\"        // NB: additional offset to account for unusual Tangram JS y coords,\\n\" +\n\"        // should be refactored to remove\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"// Position in model space as above, but according to tile coordinate (as opposed to style) zoom\\n\" +\n\"// e.g. unadjusted for tile overzooming\\n\" +\n\"vec4 modelPositionBaseZoom() {\\n\" +\n\"    return\\n\" +\n\"        vec4(\\n\" +\n\"            SHORT(a_position.xyz)   // scale normalized short to full range\\n\" +\n\"            / TANGRAM_TILE_SCALE,   // scale coords to ~0-1 range\\n\" +\n\"        1.)\\n\" +\n\"        + vec4(0., 1., 0., 0.);\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Vertex position in world coordinates, useful for 3d procedural textures, etc.\\n\" +\n\"vec4 worldPosition() {\\n\" +\n\"    return v_world_position;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"// Optionally wrap 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\"#ifdef TANGRAM_VERTEX_SHADER\\n\" +\n\"\\n\" +\n\"vec4 wrapWorldPosition(vec4 world_position) {\\n\" +\n\"    #if defined(TANGRAM_WORLD_POSITION_WRAP)\\n\" +\n\"    vec2 anchor = u_tile_origin.xy - mod(u_tile_origin.xy, TANGRAM_WORLD_POSITION_WRAP);\\n\" +\n\"        world_position.xy -= anchor;\\n\" +\n\"    #endif\\n\" +\n\"    return world_position;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"// Normal in world space\\n\" +\n\"#if defined(TANGRAM_VERTEX_SHADER)\\n\" +\n\"\\n\" +\n\"vec3 worldNormal() {\\n\" +\n\"    return TANGRAM_NORMAL;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#elif defined(TANGRAM_FRAGMENT_SHADER)\\n\" +\n\"\\n\" +\n\"vec3 worldNormal() {\\n\" +\n\"    return u_inverseNormalMatrix * TANGRAM_NORMAL;\\n\" +\n\"}\\n\" +\n\"\\n\" +\n\"#endif\\n\" +\n\"\";\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;\\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/rasters'] =\n\"// Uniforms defining raster textures and macros for accessing them\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_FRAGMENT_SHADER\\n\" +\n\"uniform sampler2D u_rasters[TANGRAM_NUM_RASTER_SOURCES];    // raster tile texture samplers\\n\" +\n\"uniform vec2 u_raster_sizes[TANGRAM_NUM_RASTER_SOURCES];    // raster tile texture sizes (width/height in pixels)\\n\" +\n\"uniform vec3 u_raster_offsets[TANGRAM_NUM_RASTER_SOURCES];  // raster tile texture UV starting offset for tile\\n\" +\n\"\\n\" +\n\"// Note: the raster accessors below are #defines rather than functions to\\n\" +\n\"// avoid issues with constant integer expressions for array indices\\n\" +\n\"\\n\" +\n\"// Adjusts UVs in model space to account for raster tile texture overzooming\\n\" +\n\"// (applies scale and offset adjustments)\\n\" +\n\"#define adjustRasterUV(raster_index, uv) \" +\n\"    ((uv) * u_raster_offsets[raster_index].z + u_raster_offsets[raster_index].xy)\\n\" +\n\"\\n\" +\n\"// Returns the UVs of the current model position for a raster sampler\\n\" +\n\"#define currentRasterUV(raster_index) \" +\n\"    (adjustRasterUV(raster_index, v_modelpos_base_zoom.xy))\\n\" +\n\"\\n\" +\n\"// Returns pixel location in raster tile texture at current model position\\n\" +\n\"#define currentRasterPixel(raster_index) \" +\n\"    (currentRasterUV(raster_index) * rasterPixelSize(raster_index))\\n\" +\n\"\\n\" +\n\"// Samples a raster tile texture for the current model position\\n\" +\n\"#define sampleRaster(raster_index) \" +\n\"    (texture2D(u_rasters[raster_index], currentRasterUV(raster_index)))\\n\" +\n\"\\n\" +\n\"// Samples a raster tile texture for a given pixel\\n\" +\n\"#define sampleRasterAtPixel(raster_index, pixel) \" +\n\"    (texture2D(u_rasters[raster_index], adjustRasterUV(raster_index, (pixel) / rasterPixelSize(raster_index))))\\n\" +\n\"\\n\" +\n\"// Returns size of raster sampler in pixels\\n\" +\n\"#define rasterPixelSize(raster_index) \" +\n\"    (u_raster_sizes[raster_index])\\n\" +\n\"\\n\" +\n\"#endif\\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/unpack'] =\n\"\\n\" +\n\"// Unpack normalized shorts back to their original integer values\\n\" +\n\"#define SHORT(x) (x * 32767.)\\n\" +\n\"#define UNSIGNED_SHORT(x) (x * 65535.)\\n\" +\n\"\\n\" +\n\"// Used for cases where an attribute is stored as a normalized int type,\\n\" +\n\"// but is a floating point value that needs a range greater than [0, 1] or [-1, 1].\\n\" +\n\"// The integer value is \\\"scaled\\\" to an 8.8 fixed point style integer before it is\\n\" +\n\"// normalized in the VBO. Used for cases where low precision is suitable for both\\n\" +\n\"// the integer and fractional portions of the number.\\n\" +\n\"// Examples are extrusion vectors for dynamic lines, and screen-space size for point sprites.\\n\" +\n\"#define SCALE_8(x) (x * 256.)\\n\" +\n\"\";\n\nshaderSources['styles/points/points_fragment'] =\n\"uniform vec2 u_resolution;\\n\" +\n\"uniform float u_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec4 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL vec3(0., 0., 1.)\\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: camera\\n\" +\n\"#pragma tangram: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\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\"\\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\"    // 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(color.a - (smoothstep(0., TANGRAM_FADE_RANGE, (point_dist - TANGRAM_FADE_START)) / TANGRAM_FADE_RANGE), 0., color.a);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // If blending is off, use alpha discard as a lower-quality substitute\\n\" +\n\"    #if !defined(TANGRAM_BLEND_OVERLAY) && !defined(TANGRAM_BLEND_INLAY)\\n\" +\n\"        if (color.a < TANGRAM_ALPHA_DISCARD) {\\n\" +\n\"            discard;\\n\" +\n\"        }\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"\\n\" +\n\"    // Fade out when tile is zooming out, e.g. acting as proxy tiles\\n\" +\n\"    // NB: this is mostly done to compensate for text label collision happening at the label\\'s 1x zoom. As labels\\n\" +\n\"    // in proxy tiles are scaled down, they begin to overlap, and the fade is a simple way to ease the transition.\\n\" +\n\"    #ifdef TANGRAM_FADE_ON_ZOOM_OUT\\n\" +\n\"        color.a *= clamp(1. - TANGRAM_FADE_ON_ZOOM_OUT_RATE * (u_tile_origin.z - u_map_position.z), 0., 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\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 vec4 u_tile_origin;\\n\" +\n\"uniform float u_tile_proxy_depth;\\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\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL vec3(0., 0., 1.)\\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: material\\n\" +\n\"#pragma tangram: lighting\\n\" +\n\"#pragma tangram: raster\\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\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\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(SHORT(a_position.xyz), 1.);\\n\" +\n\"\\n\" +\n\"    // Apply positioning and scaling in screen space\\n\" +\n\"    float zscale = fract(u_map_position.z) * (SCALE_8(a_shape.w) - 1.) + 1.;\\n\" +\n\"    // float zscale = log(fract(u_map_position.z) + 1.) / log(2.) * (a_shape.w - 1.) + 1.;\\n\" +\n\"    vec2 shape = SCALE_8(a_shape.xy) * 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(SHORT(offset), 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\"    v_world_position = wrapWorldPosition(v_world_position);\\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\"        // +1 is to keep all layers including proxies > 0\\n\" +\n\"        applyLayerOrder(SHORT(a_position.w) + u_tile_proxy_depth + 1., position);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Apply pixel offset in screen-space\\n\" +\n\"    // Multiply by 2 is because screen is 2 units wide Normalized Device Coords (and u_resolution device pixels wide)\\n\" +\n\"    // Device pixel ratio adjustment is because shape is in logical pixels\\n\" +\n\"    position.xy += shape * position.w * 2. * u_device_pixel_ratio / 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_time;\\n\" +\n\"uniform vec3 u_map_position;\\n\" +\n\"uniform vec4 u_tile_origin;\\n\" +\n\"uniform float u_meters_per_pixel;\\n\" +\n\"uniform float u_device_pixel_ratio;\\n\" +\n\"\\n\" +\n\"uniform mat3 u_normalMatrix;\\n\" +\n\"uniform mat3 u_inverseNormalMatrix;\\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\"#define TANGRAM_NORMAL v_normal\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"    varying vec2 v_texcoord;\\n\" +\n\"#endif\\n\" +\n\"\\n\" +\n\"#ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"    varying vec4 v_modelpos_base_zoom;\\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: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main (void) {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\n\" +\n\"    vec4 color = v_color;\\n\" +\n\"    vec3 normal = TANGRAM_NORMAL;\\n\" +\n\"\\n\" +\n\"    // Apply raster to vertex color\\n\" +\n\"    #ifdef TANGRAM_RASTER_TEXTURE_COLOR\\n\" +\n\"        color *= sampleRaster(0); // multiplied to tint texture color\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // First, get normal from raster tile (if applicable)\\n\" +\n\"    #ifdef TANGRAM_RASTER_TEXTURE_NORMAL\\n\" +\n\"        normal = normalize(sampleRaster(0).rgb * 2. - 1.);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Second, alter normal with normal map texture (if applicable)\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT) && defined(TANGRAM_MATERIAL_NORMAL_TEXTURE)\\n\" +\n\"        calculateNormal(normal);\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Normal modification applied here for fragment lighting or no lighting,\\n\" +\n\"    // and in vertex shader for vertex lighting\\n\" +\n\"    #if !defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Color modification before lighting is applied\\n\" +\n\"    #pragma tangram: color\\n\" +\n\"\\n\" +\n\"    #if defined(TANGRAM_LIGHTING_FRAGMENT)\\n\" +\n\"        // Calculate per-fragment lighting\\n\" +\n\"        color = calculateLighting(v_position.xyz - u_eye, normal, color);\\n\" +\n\"    #elif defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        // Apply lighting intensity interpolated from vertex shader\\n\" +\n\"        color *= v_lighting;\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Post-processing effects (modify color after lighting)\\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 vec4 u_tile_origin;\\n\" +\n\"uniform float u_tile_proxy_depth;\\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\"uniform mat3 u_inverseNormalMatrix;\\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\"// Optional model position varying for tile coordinate zoom\\n\" +\n\"#ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"    varying vec4 v_modelpos_base_zoom;\\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: raster\\n\" +\n\"#pragma tangram: global\\n\" +\n\"\\n\" +\n\"void main() {\\n\" +\n\"    // Initialize globals\\n\" +\n\"    #pragma tangram: setup\\n\" +\n\"\\n\" +\n\"    // Texture UVs\\n\" +\n\"    #ifdef TANGRAM_TEXTURE_COORDS\\n\" +\n\"        v_texcoord = a_texcoord;\\n\" +\n\"        #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"            v_texcoord.y *= TANGRAM_V_SCALE_ADJUST;\\n\" +\n\"        #endif\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Pass model position to fragment shader\\n\" +\n\"    #ifdef TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING\\n\" +\n\"        v_modelpos_base_zoom = modelPositionBaseZoom();\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Position\\n\" +\n\"    vec4 position = vec4(SHORT(a_position.xyz), 1.);\\n\" +\n\"\\n\" +\n\"    #ifdef TANGRAM_EXTRUDE_LINES\\n\" +\n\"        vec2 extrude = SCALE_8(a_extrude.xy);\\n\" +\n\"        float width = SHORT(a_extrude.z);\\n\" +\n\"        float dwdz = SHORT(a_extrude.w);\\n\" +\n\"        float dz = clamp(u_map_position.z - u_tile_origin.z, 0., 1.);\\n\" +\n\"\\n\" +\n\"        // Interpolate between zoom levels\\n\" +\n\"        width += dwdz * dz;\\n\" +\n\"\\n\" +\n\"        // Scale pixel dimensions to be consistent in screen space\\n\" +\n\"        width *= exp2(-dz);\\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 = wrapWorldPosition(u_model * position);\\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\"    #if defined(TANGRAM_LIGHTING_VERTEX)\\n\" +\n\"        // Vertex lighting\\n\" +\n\"        vec3 normal = v_normal;\\n\" +\n\"\\n\" +\n\"        // Modify normal before lighting\\n\" +\n\"        #pragma tangram: normal\\n\" +\n\"\\n\" +\n\"        // Pass lighting intensity to fragment shader\\n\" +\n\"        v_lighting = calculateLighting(position.xyz - u_eye, normal, vec4(1.));\\n\" +\n\"    #endif\\n\" +\n\"\\n\" +\n\"    // Camera\\n\" +\n\"    cameraProjection(position);\\n\" +\n\"\\n\" +\n\"    // +1 is to keep all layers including proxies > 0\\n\" +\n\"    applyLayerOrder(SHORT(a_position.w) + u_tile_proxy_depth + 1., position);\\n\" +\n\"\\n\" +\n\"    gl_Position = position;\\n\" +\n\"}\\n\" +\n\"\";\n\nexport default shaderSources;\n","// Texture management\nimport Utils from '../utils/utils';\nimport subscribeMixin from '../utils/subscribe';\nimport WorkerBroker from '../utils/worker_broker';\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\n        this.name = name;\n        this.retain_count = 0;\n        this.source = null;\n        this.source_type = null;\n        this.config_type = null;\n        this.loading = null;    // a Promise object to track the loading state of this texture\n        this.loaded = false;    // successfully loaded as expected\n        this.filtering = options.filtering;\n        this.sprites = options.sprites;\n        this.texcoords = {};    // sprite UVs ([0, 1] range)\n        this.sizes = {};        // sprite sizes (pixel size)\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        // Destroy previous texture if present\n        if (Texture.textures[this.name]) {\n            // Preserve previous retain count\n            this.retain_count = Texture.textures[this.name].retain_count;\n            Texture.textures[this.name].retain_count = 0; // allow to be freed\n            Texture.textures[this.name].destroy();\n        }\n\n        // Cache texture instance and definition\n        Texture.textures[this.name] = this;\n        Texture.texture_configs[this.name] = Object.assign({ name }, options);\n\n        this.load(options);\n        log.trace(`creating Texture ${this.name}`);\n    }\n\n    // Destroy a single texture instance\n    destroy() {\n        if (this.retain_count > 0) {\n            log.error(`Texture '${this.name}': destroying texture with retain count of '${this.retain_count}'`);\n            return;\n        }\n\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        log.trace(`destroying Texture ${this.name}`);\n    }\n\n    retain () {\n        this.retain_count++;\n    }\n\n    release () {\n        if (this.retain_count <= 0) {\n            log.error(`Texture '${this.name}': releasing texture with retain count of '${this.retain_count}'`);\n        }\n\n        this.retain_count--;\n        if (this.retain_count <= 0) {\n            this.destroy();\n        }\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    load(options) {\n        if (!options) {\n            return this.loading || Promise.resolve(this);\n        }\n\n        this.loading = null;\n        if (typeof options.url === 'string') {\n            this.config_type = 'url';\n            this.setUrl(options.url, options);\n        } else if (options.element) {\n            this.config_type = 'element';\n            this.setElement(options.element, options);\n        } else if (options.data && options.width && options.height) {\n            this.config_type = 'data';\n            this.setData(options.width, options.height, options.data, options);\n        }\n\n        this.loading =\n            (this.loading && this.loading.then(() => { this.calculateSprites(); return this; })) ||\n            Promise.resolve(this);\n        return this.loading;\n    }\n\n    // Sets texture from an url\n    setUrl(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.url = Utils.cacheBusterForUrl(url); // save URL reference (will be overwritten when element is loaded below)\n        this.source = this.url;\n        this.source_type = 'url';\n\n        this.loading = new Promise((resolve, reject) => {\n            let image = new Image();\n            image.onload = () => {\n                try {\n                    this.setElement(image, options);\n                }\n                catch (e) {\n                    this.loaded = false;\n                    log.warn(`Texture '${this.name}': failed to load url: '${this.source}'`, e, options);\n                    Texture.trigger('warning', { message: `Failed to load texture from ${this.source}`, error: e, texture: options });\n                }\n\n                this.loaded = true;\n                resolve(this);\n            };\n            image.onerror = e => {\n                // Warn and resolve on error\n                this.loaded = false;\n                log.warn(`Texture '${this.name}': failed to load url: '${this.source}'`, e, options);\n                Texture.trigger('warning', { message: `Failed to load texture from ${this.source}`, error: e, texture: options });\n                resolve(this);\n            };\n            image.crossOrigin = 'anonymous';\n            image.src = this.source;\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\n        this.source = data;\n        this.source_type = 'data';\n\n        this.update(options);\n        this.setFiltering(options);\n\n        this.loaded = true;\n        this.loading = Promise.resolve(this);\n        return this.loading;\n    }\n\n    // Sets the texture to track a element (canvas/image)\n    setElement(element, options) {\n        let el = element;\n\n        // a string element is interpeted as a CSS selector\n        if (typeof element === 'string') {\n            element = document.querySelector(element);\n        }\n\n        if (element instanceof HTMLCanvasElement ||\n            element instanceof HTMLImageElement ||\n            element instanceof HTMLVideoElement) {\n            this.source = element;\n            this.source_type = 'element';\n\n            this.update(options);\n            this.setFiltering(options);\n        }\n        else {\n            this.loaded = false;\n            let msg = `the 'element' parameter (\\`element: ${JSON.stringify(el)}\\`) must be a CSS `;\n            msg += `selector string, or a <canvas>, <image> or <video> object`;\n            log.warn(`Texture '${this.name}': ${msg}`, options);\n            Texture.trigger('warning', { message: `Failed to load texture because ${msg}`, texture: options });\n        }\n\n        this.loaded = true;\n        this.loading = Promise.resolve(this);\n        return this.loading;\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 or Canvas element\n        if (this.source instanceof HTMLCanvasElement || this.source instanceof HTMLVideoElement ||\n            (this.source instanceof HTMLImageElement && this.source.complete)) {\n\n            this.width = this.source.width;\n            this.height = this.source.height;\n            this.gl.texImage2D(this.gl.TEXTURE_2D, 0, this.gl.RGBA, this.gl.RGBA, this.gl.UNSIGNED_BYTE, this.source);\n        }\n        // Raw image buffer\n        else if (this.source_type === 'data') {\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.source);\n        }\n\n        Texture.trigger('update', this);\n    }\n\n    // Determines appropriate filtering mode\n    setFiltering(options = {}) {\n        if (!this.valid) {\n            return;\n        }\n\n        options.filtering = options.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            if (options.filtering === '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                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                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                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                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] = Texture.getTexcoordsForSprite(\n                    [sprite[0], sprite[1]],\n                    [sprite[2], sprite[3]],\n                    [this.width, this.height]\n                );\n\n                // Pixel size of sprite\n                this.sizes[s] = [sprite[2], sprite[3]];\n            }\n        }\n    }\n\n}\n\n\n// Static/class methods and state\n\nTexture.create = function (gl, name, options) {\n    return new Texture(gl, name, options);\n};\n\nTexture.retain = function (name) {\n    if (Texture.textures[name]) {\n        Texture.textures[name].retain();\n    }\n};\n\nTexture.release = function (name) {\n    if (Texture.textures[name]) {\n        Texture.textures[name].release();\n    }\n};\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            texture.destroy();\n        }\n    }\n};\n\n// Get sprite pixel size and UVs\nTexture.getSpriteInfo = function (texname, sprite) {\n    let texture = Texture.textures[texname];\n    return texture && { size: texture.sizes[sprite], texcoords: texture.texcoords[sprite] };\n};\n\n// Re-scale UVs from [0, 1] range to a smaller area within the image\nTexture.getTexcoordsForSprite = function (area_origin, area_size, tex_size) {\n    var area_origin_y = tex_size[1] - area_origin[1] - area_size[1];\n\n    return [\n        area_origin[0] / tex_size[0],\n        area_origin_y / tex_size[1],\n        (area_size[0] + area_origin[0]) / tex_size[0],\n        (area_size[1] + area_origin_y) / tex_size[1]\n    ];\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\n            // If texture already exists and definition hasn't changed, no need to re-create\n            // Note: to avoid flicker when other textures/scene items change\n            if (!Texture.changed(texname, config)) {\n                continue;\n            }\n\n            let texture = Texture.create(gl, texname, config);\n            loading.push(texture.loading);\n        }\n    }\n    return Promise.all(loading);\n};\n\n// Indicate if a texture definition would be a change from the current cache\nTexture.changed = function (name, config) {\n    let texture = Texture.textures[name];\n    if (texture) { // cached texture\n        // canvas/image-based textures are considered dynamic and always refresh\n        if (texture.config_type === 'element' || config.element != null) {\n            return true;\n        }\n\n        // compare definitions\n        if (JSON.stringify(Texture.texture_configs[name]) ===\n            JSON.stringify(Object.assign({ name }, config))) {\n            return false;\n        }\n    }\n    return true;\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                sizes: tex.sizes,\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// Report max texture size for a GL context\nTexture.getMaxTextureSize = function (gl) {\n    return gl.getParameter(gl.MAX_TEXTURE_SIZE);\n};\n\n// Global set of textures, by name\nTexture.textures = {};\nTexture.texture_configs = {};\nTexture.boundTexture = -1;\nTexture.activeUnit = -1;\n\nTexture.base_url = null; // optional base URL to add to textures\n\nWorkerBroker.addTarget('Texture', Texture);\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","// Manage rendering for primitives\nimport ShaderProgram from './shader_program';\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        return true;\n    }\n\n}\n","import 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","import 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 RepeatGroup from './repeat_group';\n\nimport log from 'loglevel';\n\nvar Collision;\n\nexport default Collision = {\n\n    tiles: {},\n\n    startTile (tile) {\n        let state = this.tiles[tile] = {\n            bboxes: {           // current set of placed bounding boxes\n                aabb: [],\n                obb: []\n            },\n            objects: {},        // objects to collide, grouped by priority, then by style\n            keep: {},           // objects that were kept after collision, grouped by style\n            styles: new Set()   // styles contributing collision objects\n        };\n\n        // Promise resolved when all registered styles have added objects\n        state.complete = new Promise((resolve, reject) => {\n            state.resolve = resolve;\n            state.reject = reject;\n        });\n    },\n\n    resetTile (tile) {\n        delete this.tiles[tile];\n    },\n\n    // Add a style to the pending set, collision will block on all styles submitting to collision set\n    addStyle (style, tile) {\n        this.tiles[tile].styles.add(style);\n    },\n\n    // Add collision objects for a style\n    collide (objects, style, tile) {\n        let state = this.tiles[tile];\n        if (!state) {\n            log.trace('Collision.collide() called with null tile', tile, this.tiles, style, objects);\n            return Promise.reject(Error('Collision.collide() called with null tile', tile, this.tiles, style, objects));\n        }\n\n        // Group by priority and style\n        let tile_objects = state.objects;\n        for (let i=0; i < objects.length; i++) {\n            let obj = objects[i];\n            let priority = obj.layout.priority;\n            tile_objects[priority] = tile_objects[priority] || {};\n            tile_objects[priority][style] = tile_objects[priority][style] || [];\n            tile_objects[priority][style].push(obj);\n        }\n\n        // Remove from pending style set, if no more styles, do collision & finish tile\n        state.styles.delete(style);\n        if (state.styles.size === 0) {\n            this.endTile(tile);\n        }\n\n        // Wait for objects to be added from all styles\n        return state.complete.then(() => {\n            return state.keep[style] || [];\n        });\n    },\n\n    // Test labels for collisions, higher to lower priority\n    // When two collide, discard the lower-priority label\n    endTile (tile) {\n        let state = this.tiles[tile];\n        let bboxes = state.bboxes;\n        let keep = state.keep;\n\n        RepeatGroup.clear(tile);\n\n        // Process labels by priority, then by style\n        let priorities = Object.keys(state.objects).sort((a, b) => a - b);\n        for (let priority of priorities) {\n            let style_objects = state.objects[priority];\n            if (!style_objects) { // no labels at this priority, skip to next\n                continue;\n            }\n\n            // For each style\n            for (let style in style_objects) {\n                let objects = style_objects[style];\n                keep[style] = keep[style] || [];\n\n                for (let i = 0; i < objects.length; i++) {\n                    let { label, layout } = objects[i]; // TODO: `label` should be generic\n\n                    // test the label for intersections with other labels in the tile\n                    if (!layout.collide || !label.discard(bboxes)) {\n                        // check for repeats\n                        let check = RepeatGroup.check(label, layout, tile);\n                        if (check) {\n                            // log.trace(`discard label '${label.text}', (one_per_group: ${check.one_per_group}), dist ${Math.sqrt(check.dist_sq)/layout.units_per_pixel} < ${Math.sqrt(check.repeat_dist_sq)/layout.units_per_pixel}`);\n                            continue;\n                        }\n                        // register as placed for future repeat culling\n                        RepeatGroup.add(label, layout, tile);\n\n                        label.add(bboxes); // add label to currently visible set\n                        keep[style].push(objects[i]);\n                    }\n                    // else if (layout.collide) {\n                    //     log.trace(`discard label '${label.text}' due to collision`);\n                    // }\n                }\n            }\n        }\n\n        delete this.tiles[tile];\n        state.resolve();\n    }\n\n};\n","import boxIntersect from 'box-intersect'; // https://github.com/mikolalysenko/box-intersect\nimport Utils from '../utils/utils';\nimport OBB from '../utils/obb';\n\n// import log from 'loglevel';\n\nexport default class Label {\n\n    constructor (size, options = {}) {\n        this.size = size;\n        this.options = options;\n        this.position = null;\n        this.aabb = null;\n        this.obb = null;\n    }\n\n    // check for overlaps with other labels in the tile\n    occluded (bboxes) {\n        let intersect = false;\n        let aabbs = bboxes.aabb;\n        let obbs = bboxes.obb;\n\n        // Broad phase\n        if (aabbs.length > 0) {\n            boxIntersect([this.aabb], aabbs, (i, j) => {\n                // log.trace('collision: broad phase collide', this.options.id, this, this.aabb, aabbs[j]);\n\n                // Skip narrow phase collision if no rotation\n                if (this.obb.angle === 0 && obbs[j].angle === 0) {\n                    // log.trace('collision: skip narrow phase collide because neither is rotated', this.options.id, this, this.obb, obbs[j]);\n                    intersect = true;\n                    return true;\n                }\n\n                // Narrow phase\n                if (OBB.intersect(this.obb, obbs[j])) {\n                    // log.trace('collision: narrow phase collide', this.options.id, this, this.obb, obbs[j]);\n                    intersect = true;\n                    return true;\n                }\n            });\n        }\n        return intersect;\n    }\n\n    // Add this label's bounding box to the provided set\n    add (bboxes) {\n        bboxes.aabb.push(this.aabb);\n        bboxes.obb.push(this.obb);\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    // Depends on whether label must fit in the tile bounds, and if so, can it be moved to fit there\n    discard (bboxes) {\n        // Should the label be culled if it can't fit inside the tile bounds?\n        if (this.options.cull_from_tile) {\n            let in_tile = this.inTileBounds();\n\n            // If it doesn't fit, should we try to move it into the tile bounds?\n            if (!in_tile && this.options.move_into_tile) {\n                // Can we fit the label into the tile?\n                if (!this.moveIntoTile()) {\n                    return true; // can't fit in tile, discard\n                }\n            } else if (!in_tile) {\n                return true; // out of tile bounds, discard\n            }\n        }\n\n        // If the label hasn't been discarded yet, check to see if it's occluded by other labels\n        return this.occluded(bboxes);\n    }\n}\n\nLabel.epsilon = 0.9999; // tolerance around collision boxes, prevent perfectly adjacent objects from colliding\n","import Vector from '../vector';\nimport Label from './label';\nimport OBB from '../utils/obb';\n\nexport default class LabelLine extends Label {\n\n    constructor (size, lines, options) {\n        super(size, options);\n\n        this.lines = lines;\n\n        // optionally limit the line segments that the label may be placed in, by specifying a segment index range\n        // used as a coarse subdivide for placing multiple labels per line geometry\n        this.segment_index = options.segment_start || 0;\n        this.segment_max = options.segment_end || this.lines.length;\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.updateBBoxes();\n    }\n\n    moveNextSegment () {\n        if (this.segment_index + 1 >= this.segment_max - 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 () {\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[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    updateBBoxes () {\n        let upp = this.options.units_per_pixel;\n        let width = (this.size[0] + this.options.buffer[0] * 2) * upp * Label.epsilon;\n        let height = (this.size[1] + this.options.buffer[1] * 2) * upp * Label.epsilon;\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        this.obb = new OBB(p[0], p[1], -this.angle, width, height);\n        this.aabb = this.obb.getExtent();\n    }\n\n    // Try to move the label into the tile bounds\n    // Returns true if label was moved into tile, false if it couldn't be moved\n    moveIntoTile () {\n        let in_tile = false;\n        let fits_to_segment = this.fitToSegment();\n\n        // Try line segments until we find one that fits the label (and is inside the tile)\n        while (!in_tile || !fits_to_segment) {\n            if (!this.moveNextSegment()) {\n                break; // we can't move further in this line\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 (bboxes) {\n        // First find a line segment that fits the label\n        if (this.lines && !this.fitToSegment()) {\n            while (!this.fitToSegment()) {\n                if (!this.moveNextSegment()) {\n                    return true;\n                }\n            }\n        }\n\n        // If label fits in line, run standard discard tests\n        return super.discard(bboxes);\n    }\n\n}\n","import Label from './label';\nimport Geo from '../geo';\nimport OBB from '../utils/obb';\nimport PointAnchor from '../styles/points/point_anchor';\n\nexport default class LabelPoint extends Label {\n\n    constructor (position, size, options) {\n        super(size, options);\n        this.position = [position[0], position[1]];\n        this.update();\n    }\n\n    update() {\n        this.options.offset = this.computeOffset();\n        this.updateBBoxes();\n    }\n\n    computeOffset () {\n        return PointAnchor.computeOffset(this.options.offset, this.size, this.options.anchor);\n    }\n\n    updateBBoxes () {\n        let width = (this.size[0] + this.options.buffer[0] * 2) * this.options.units_per_pixel * Label.epsilon;\n        let height = (this.size[1] + this.options.buffer[1] * 2) * this.options.units_per_pixel * Label.epsilon;\n\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        this.obb = new OBB(p[0], p[1], 0, width, height);\n        this.aabb = this.obb.getExtent();\n    }\n\n    // Try to move the label into the tile bounds\n    // Returns true if label was moved into tile, false if it couldn't be moved\n    moveIntoTile () {\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.updateBBoxes();\n        }\n\n        return this.inTileBounds();\n    }\n\n}\n","import Geo from '../geo';\n\nexport default class RepeatGroup {\n\n    constructor (key, repeat_dist, max_repeat_dist) {\n        this.key = key;\n        this.repeat_dist = repeat_dist;\n        this.repeat_dist_sq = this.repeat_dist * this.repeat_dist;\n        this.max_repeat_dist_sq = max_repeat_dist * max_repeat_dist;\n        this.one_per_group = (this.repeat_dist_sq >= this.max_repeat_dist_sq) ? true : false;\n        this.positions = [];\n    }\n\n    // Check an object to see if it's a repeat in this group\n    check (obj) {\n        // If only one object allowed per group, shortcut distance logic\n        if (this.one_per_group) {\n            if (this.positions.length > 0) {\n                // reported distance maxes out at threshold in this case\n                // (not true dist value since we skipped calculating it)\n                return {\n                    dist_sq: this.max_repeat_dist_sq,\n                    repeat_dist_sq: this.repeat_dist_sq,\n                    one_per_group: this.one_per_group\n                };\n            }\n            return; // no object for this group yet\n        }\n\n        // Check distance from new object to objects already in group\n        let p1 = obj.position;\n        for (let i=0; i < this.positions.length; i++) {\n            let p2 = this.positions[i];\n            let dx = p1[0] - p2[0];\n            let dy = p1[1] - p2[1];\n            let dist_sq = dx * dx + dy * dy;\n\n            // Found an existing object within allowed distance\n            if (dist_sq < this.repeat_dist_sq) {\n                return {\n                    dist_sq,\n                    repeat_dist_sq: this.repeat_dist_sq\n                };\n            }\n        }\n    }\n\n    // Add object to this group\n    add (obj) {\n        // only store object's position, to save space / prevent unnecessary references\n        if (obj && obj.position) {\n            this.positions.push(obj.position);\n        }\n    }\n\n    // Static methods are used to manage repeat groups, within and across tiles\n\n    // Reset all groups for this tile\n    static clear (tile) {\n        this.groups[tile] = {};\n    }\n\n    // Check an object to see if it's a repeat within its designated group\n    static check (obj, layout, tile) {\n        if (layout.repeat_distance && this.groups[tile][layout.repeat_group]) {\n            return this.groups[tile][layout.repeat_group].check(obj);\n        }\n    }\n\n    // Add an object to its designated group\n    static add (obj, layout, tile) {\n        if (layout.repeat_distance) {\n            if (this.groups[tile][layout.repeat_group] == null) {\n                this.groups[tile][layout.repeat_group] = new RepeatGroup(\n                    layout.repeat_group,\n                    layout.repeat_distance,\n                    RepeatGroup.max_repeat_dist\n                );\n            }\n            this.groups[tile][layout.repeat_group].add(obj);\n        }\n    }\n\n}\n\n// Current set of repeat groups, grouped and keyed by tile\nRepeatGroup.groups = {};\n\n// Max repeat dist: for groups with a repeat dist beyond this threshold, only one label\n// will be allowed per group, e.g. set to tile size for one-label-per-tile\nRepeatGroup.max_repeat_dist = Geo.tile_scale;\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 extendLeaflet(options);\n}\n\nfunction extendLeaflet(options) {\n\n    // If LeafletLayer is already defined when this is called just return that immediately\n    // e.g. if you call leafletLayer multiple times (which is valid)\n    if (typeof LeafletLayer !== 'undefined') {\n        return new LeafletLayer(options);\n    }\n\n    // Leaflet layer functionality is only defined in main thread\n    if (Utils.isMainThread) {\n\n        let L = options.leaflet || window.L;\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                options.wheelDebounceTime = options.wheelDebounceTime || 40;\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                this.debounceViewReset = Utils.debounce(() => {\n                    this._map.fire('zoomend');\n                    this._map.fire('moveend');\n                }, this.options.wheelDebounceTime);\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                    this.updateSize();\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.default_view_max_zoom);\n\n                    this.scene.view.setView(view);\n                    this.scene.immediateRedraw();\n                    this.reverseTransform();\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.view.startZoom();\n                    this._updating_tangram = false;\n                };\n                map.on('zoomstart', this.hooks.zoomstart);\n\n                this.hooks.dragstart = () => {\n                    this.scene.view.panning = true;\n                };\n                map.on('dragstart', this.hooks.dragstart);\n\n                this.hooks.dragend = () => {\n                    this.scene.view.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                // Setup feature selection\n                this.setupSelectionEventHandlers(map);\n                this.setSelectionEvents(this.options.events);\n\n                // Add GL canvas to layer container\n                this.scene.container = this.getContainer();\n\n                // Initial view\n                this.updateView();\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._updating_tangram = true;\n\n                    this.updateSize();\n                    this.updateView();\n                    this.reverseTransform();\n\n                    this._updating_tangram = false;\n\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                map.off('click', this.hooks.click);\n                map.off('mousemove', this.hooks.mousemove);\n                map.off('mouseout', this.hooks.mouseout);\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.view.continuous_zoom && map.scrollWheelZoom && this.options.modifyScrollWheel !== false) {\n                    let layer = this;\n                    let enabled = map.scrollWheelZoom.enabled();\n                    if (enabled) {\n                        map.scrollWheelZoom.disable(); // disable before modifying\n                    }\n\n                    // modify prototype and current instance, so add/remove hooks work on existing references\n                    L.Map.ScrollWheelZoom._onWheelScroll = map.scrollWheelZoom._onWheelScroll = function(e) {\n                        // modify to skip debounce, as it seems to cause animation-sync issues in Chrome\n                        // with Tangram continuous rendering\n                        this._delta += L.DomEvent.getWheelDelta(e);\n                        this._lastMousePos = this._map.mouseEventToContainerPoint(e);\n                        this._performZoom();\n                        L.DomEvent.stop(e);\n                    };\n\n                    L.Map.ScrollWheelZoom._performZoom = 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\n                        layer.debounceViewReset();\n                    };\n\n                    if (enabled) {\n                        map.scrollWheelZoom.enable(); // re-enable after modifying\n                    }\n                }\n            },\n\n            updateView: function () {\n                var view = this._map.getCenter();\n                view.zoom = Math.min(this._map.getZoom(), this._map.getMaxZoom() || Geo.default_view_max_zoom);\n                this.scene.view.setView(view);\n            },\n\n            updateSize: function () {\n                var size = this._map.getSize();\n                this.scene.resizeMap(size.x, size.y);\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.view.center.lat, this.scene.view.center.lng], this.scene.view.zoom, { animate: false });\n                this.reverseTransform();\n                this._updating_tangram = false;\n            },\n\n            render: function () {\n                if (!this.scene) {\n                    return;\n                }\n                this.scene.update();\n            },\n\n            // Reverse the CSS positioning Leaflet applies to the layer, since Tangram's WebGL canvas\n            // is expected to be 'absolutely' positioned.\n            reverseTransform: function () {\n                if (!this._map || !this.scene || !this.scene.container) {\n                    return;\n                }\n\n                var top_left = this._map.containerPointToLayerPoint([0, 0]);\n                L.DomUtil.setPosition(this.scene.container, top_left);\n            },\n\n            // Tie Leaflet event handlers to Tangram feature selection\n            setupSelectionEventHandlers: function (map) {\n                this._selection_events = {};\n\n                this.hooks.click = (event) => {\n                    if (typeof this._selection_events.click === 'function') {\n                        this.scene.getFeatureAt(event.containerPoint).\n                            then(selection => {\n                                let results = Object.assign({}, selection, { leaflet_event: event });\n                                this._selection_events.click(results);\n                            });\n                    }\n                };\n                map.on('click', this.hooks.click);\n\n                this.hooks.mousemove = (event) => {\n                    if (typeof this._selection_events.hover === 'function') {\n                        this.scene.getFeatureAt(event.containerPoint).\n                            then(selection => {\n                                let results = Object.assign({}, selection, { leaflet_event: event });\n                                this._selection_events.hover(results);\n                            });\n                    }\n                };\n                map.on('mousemove', this.hooks.mousemove);\n\n                this.hooks.mouseout = (event) => {\n                    // When mouse leaves map, send an additional selection event to indicate no feature is selected\n                    if (typeof this._selection_events.hover === 'function') {\n                        this._selection_events.hover({ changed: true, leaflet_event: event });\n                    }\n                };\n                map.on('mouseout', this.hooks.mouseout);\n            },\n\n            // Set user-defined handlers for feature selection events\n            // Currently only one handler can be defined for each event type\n            // Event types are: `click`, `hover` (leaflet `mousemove`)\n            setSelectionEvents: function (events) {\n                this._selection_events = Object.assign(this._selection_events, events);\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        return new LeafletLayer(options);\n    }\n}\n","import 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 (view, config) {\n        this.name = config.name;\n        this.view = view;\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 (view, config) {\n        if (Light.types[config.type]) {\n            return new Light.types[config.type](view, 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};\n            `;\n        let assign = `\n            ${this.name} = u_${this.name};\\n\n        `;\n\n        ShaderProgram.addBlock(Light.block, instance);\n        ShaderProgram.addBlock('setup', assign);\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(view, config) {\n        super(view, 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(view, config) {\n        super(view, 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 (view, config) {\n        super(view, config);\n        this.type = 'point';\n        this.struct_name = 'PointLight';\n\n        this.position = config.position || [0, 0, '100px'];\n        this.position_eye = []; // position in eyespace\n        this.origin = config.origin || 'ground';\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.view.camera.position_meters[0];\n            this.position_eye[1] = y - this.view.camera.position_meters[1];\n\n            this.position_eye[2] = StyleParser.convertUnits(this.position[2],\n                { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.zoom) });\n            this.position_eye[2] = this.position_eye[2] - this.view.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,\n                { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.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.view.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],\n                    { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.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],\n                    { zoom: this.view.zoom, meters_per_pixel: Geo.metersPerPixel(this.view.zoom) }));\n        }\n    }\n}\nLight.types['point'] = PointLight;\n\n\nclass SpotLight extends PointLight {\n\n    constructor (view, config) {\n        super(view, 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","import 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        style.addShaderBlock('setup', '\\nmaterial = u_material;\\n', '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} from './leaflet_layer';\n\n// The scene worker is only activated when a worker thread is instantiated, but must always be loaded\nimport Scene from './scene';\nimport {SceneWorker} from './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 './sources/raster';\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 Collision from './labels/collision';\nimport FeatureSelection from './selection';\n\nimport yaml from 'js-yaml';\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    Scene,\n    SceneWorker,\n    WorkerBroker,\n    ruleCache,\n    StyleManager,\n    StyleParser,\n    Collision,\n    FeatureSelection\n};\n\n// Window can only be set in main thread\nif (Utils.isMainThread) {\n\n    window.Tangram = module.exports = {\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","import 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 {Style} from './styles/style';\nimport {StyleManager} from './styles/style_manager';\nimport {StyleParser} from './styles/style_parser';\nimport SceneLoader from './scene_loader';\nimport View from './view';\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 log from 'loglevel';\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';\nimport {RasterStyle} from './styles/raster/raster';\n\n// Add built-in rendering styles\nStyleManager.register(Polygons);\nStyleManager.register(Lines);\nStyleManager.register(Points);\nStyleManager.register(TextStyle);\nStyleManager.register(RasterStyle);\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 = null; // will be a promise that resolves when scene is loaded\n        this.sources = {};\n\n        this.view = new View(this, options);\n        this.tile_manager = TileManager;\n        this.tile_manager.init({ scene: this, view: this.view });\n        this.num_workers = options.numWorkers || 2;\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.render_count = 0;\n        this.last_render_count = 0;\n        this.render_count_changed = false;\n        this.frame = 0;\n        this.queue_screenshot = null;\n        this.selection = null;\n        this.resetTime();\n\n        this.container = options.container;\n\n        this.lights = null;\n        this.background = null;\n\n        // Listen to related objects\n        this.listeners = {\n            view: {\n                move: () => this.trigger('move')\n            }\n        };\n        this.view.subscribe(this.listeners.view);\n\n        this.updating = 0;\n        this.generation = 0; // an id that is incremented each time the scene config is invalidated\n        this.last_complete_generation = 0; // last generation id with a complete view\n        this.setupDebug();\n\n        this.logLevel = options.logLevel || 'warn';\n        log.setLevel(this.logLevel);\n    }\n\n    static create (config, options = {}) {\n        return new Scene(config, options);\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 this.initializing;\n        }\n\n        this.updating++;\n        this.initialized = false;\n\n        // Load scene definition (sources, styles, etc.), then create styles & workers\n        this.initializing = this.loadScene(config_source, config_path)\n            .then(() => this.createWorkers())\n            .then(() => {\n                this.createCanvas();\n                this.resetFeatureSelection();\n\n                if (!this.listeners.texture) {\n                    this.listeners.texture = {\n                        update: () => this.dirty = true,\n                        warning: (data) => this.trigger('warning', Object.assign({ type: 'textures' }, data))\n                    };\n                    Texture.subscribe(this.listeners.texture);\n                }\n\n                // Only retain visible tiles for rebuilding\n                this.tile_manager.pruneToVisibleTiles();\n                return this.updateConfig({ rebuild: true });\n            }).then(() => {\n                this.updating--;\n                this.initializing = null;\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                this.requestRedraw();\n        }).catch(error => {\n            this.initializing = null;\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        return this.initializing;\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        this.view.unsubscribe(this.listeners.view);\n        Texture.unsubscribe(this.listeners.texture);\n        this.listeners = 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.container.style.backgroundColor = 'transparent';\n        this.container.appendChild(this.canvas);\n\n        try {\n            this.gl = Context.getContext(this.canvas, {\n                alpha: true, premultipliedAlpha: true, // TODO: vary w/scene alpha\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, 'self.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        this.next_worker = 0;\n        return Promise.all(queue);\n    }\n\n    // Round robin selection of next worker\n    nextWorker() {\n        var worker = this.workers[this.next_worker];\n        this.next_worker = (this.next_worker + 1) % this.workers.length;\n        return worker;\n    }\n\n    // Scene is ready for rendering\n    ready() {\n        if (!this.view.ready() || Object.keys(this.sources).length === 0) {\n             return false;\n        }\n        return true;\n    }\n\n    // Resize the map when device pixel ratio changes, e.g. when switching between displays\n    updateDevicePixelRatio () {\n        if (Utils.updateDevicePixelRatio()) {\n            WorkerBroker.postMessage(this.workers, 'self.updateDevicePixelRatio', Utils.device_pixel_ratio)\n                .then(() => this.rebuild())\n                .then(() => this.resizeMap(this.view.size.css.width, this.view.size.css.height));\n        }\n    }\n\n    resizeMap(width, height) {\n        this.dirty = true;\n        this.view.setViewportSize(width, height);\n        if (this.gl) {\n            Context.resize(this.gl, width, height, Utils.device_pixel_ratio);\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        // Render on demand\n        var will_render = !(\n            this.dirty === false ||\n            this.initialized === false ||\n            this.updating > 0 ||\n            this.ready() === 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.updateDevicePixelRatio();\n        this.render();\n        this.updateViewComplete(); // fires event when rendered tile set or style changes\n        this.completeScreenshot(); // completes screenshot capture if requested\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        // Update styles, camera, lights\n        this.view.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.view.panning || this.view.zooming) {\n                this.selection.clearPendingRequests();\n                return;\n            }\n\n            this.selection.bind();                  // switch to FBO\n            this.renderPass(\n                'selection_program',                // render w/alternate program\n                { allow_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        this.render_count_changed = false;\n        if (this.render_count !== this.last_render_count) {\n            this.render_count_changed = true;\n\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_blend } = {}) {\n        // optionally force alpha off (e.g. for selection pass)\n        allow_blend = (allow_blend == null) ? true : allow_blend;\n\n        this.clearFrame({ clear_color: true, clear_depth: true });\n\n        // Sort styles by blend order\n        let styles = Object.keys(this.active_styles).\n            map(s => this.styles[s]).\n            sort(Style.blendOrderSort);\n\n        // Render styles\n        let count = 0; // how many primitives were rendered\n        let last_blend;\n        for (let style of styles) {\n            // Only update render state when blend mode changes\n            if (style.blend !== last_blend) {\n                let state = Object.assign({},\n                    Style.render_states[style.blend],       // render state for blend mode\n                    { blend: (allow_blend && style.blend) } // enable/disable blending (e.g. no blend for selection)\n                );\n                this.setRenderState(state);\n            }\n            count += this.renderStyle(style.name, program_key);\n            last_blend = style.blend;\n        }\n\n        return count;\n    }\n\n    renderStyle(style, program_key) {\n        let first_for_style = true;\n        let render_count = 0;\n\n        let program = this.styles[style][program_key];\n        if (!program || !program.compiled) {\n            return 0;\n        }\n\n        // Render tile GL geometries\n        for (let t in this.renderable_tiles) {\n            let tile = this.renderable_tiles[t];\n\n            if (tile.meshes[style] == null) {\n                continue;\n            }\n\n            // Style-specific state\n            // Only setup style if rendering 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('1f', 'u_time', this.animated ? (((+new Date()) - this.start_time) / 1000) : 0);\n                this.view.setupProgram(program);\n                for (let i in this.lights) {\n                    this.lights[i].setupProgram(program);\n                }\n            }\n\n            // Tile-specific state\n            this.view.setupTile(tile, program);\n\n            // Render tile\n            tile.meshes[style].render();\n            render_count += tile.meshes[style].geometry_count;\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        // Set GL state\n        RenderState.depth_write.set({ depth_write: clear_depth });\n\n        let gl = this.gl;\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, 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 : RenderState.defaults.depth_test;      // default true\n        depth_write = (depth_write === false) ? false : RenderState.defaults.depth_write;   // default true\n        cull_face = (cull_face === false) ? false : RenderState.defaults.culling;           // default true\n        blend = (blend != null) ? blend : RenderState.defaults.blending;                    // default false\n\n        // Reset frame state\n        let gl = this.gl;\n\n        RenderState.depth_test.set({ depth_test: depth_test });\n        RenderState.depth_write.set({ depth_write: depth_write });\n        RenderState.culling.set({ cull: cull_face, face: RenderState.defaults.culling_face });\n\n        // Blending of alpha channel is modified to account for WebGL alpha behavior, see:\n        // http://webglfundamentals.org/webgl/lessons/webgl-and-alpha.html\n        // http://stackoverflow.com/a/11533416\n        if (blend) {\n            // Opaque: all source, no destination\n            if (blend === 'opaque') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.SRC_ALPHA, dst: gl.ZERO\n                });\n            }\n            // Traditional alpha blending\n            else if (blend === 'overlay' || blend === 'inlay') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.SRC_ALPHA, dst: gl.ONE_MINUS_SRC_ALPHA,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n            // Additive blending\n            else if (blend === 'add') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.ONE, dst: gl.ONE,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n            // Multiplicative blending\n            else if (blend === 'multiply') {\n                RenderState.blending.set({\n                    blend: true,\n                    src: gl.ZERO, dst: gl.SRC_COLOR,\n                    src_alpha: gl.ONE, dst_alpha: gl.ONE_MINUS_SRC_ALPHA\n                });\n            }\n        }\n        else {\n            RenderState.blending.set({ blend: false });\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.view.size.device.width,\n            y: pixel.y * Utils.device_pixel_ratio / this.view.size.device.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            then(selection => Object.assign(selection, { pixel })).\n            catch(error => Promise.resolve({ error }));\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(options) {\n        return this.rebuildGeometry(options);\n    }\n\n    // Rebuild all tiles\n    // sync: boolean of whether to sync the config object to the worker\n    // sources: optional array of data sources to selectively rebuild (by default all our rebuilt)\n    rebuildGeometry({ sync = true, sources = null } = {}) {\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            if (sync) {\n                this.syncConfigToWorker();\n                StyleManager.compile(this.updateActiveStyles(), this); // only recompile newly active styles\n            }\n            this.resetFeatureSelection();\n            this.resetTime();\n\n            // Rebuild visible tiles\n            this.tile_manager.pruneToVisibleTiles();\n            this.tile_manager.forEachTile(tile => {\n                if (!sources || sources.indexOf(tile.source.name) > -1) {\n                    this.tile_manager.buildTile(tile);\n                }\n            });\n            this.tile_manager.updateTilesForView(); // picks up additional tiles for any new/changed data sources\n            this.tile_manager.checkBuildQueue();    // resolve immediately if no tiles to 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    // TODO move to tile manager\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 = Utils.pathForURL(config_path || this.config_source);\n        }\n        else {\n            this.config_path = Utils.pathForURL(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    // Add source to a scene, arguments `name` and `config` need to be provided:\n    //  - If the name doesn't match a sources it will create it\n    //  - the `config` obj follow the YAML scene spec, ex: ```{type: 'TopoJSON', url: \"//vector.mapzen.com/osm/all/{z}/{x}/{y}.topojson\"]}```\n    //    that looks like:\n    //\n    //      scene.setDataSource(\"osm\", {type: 'TopoJSON', url: \"//vector.mapzen.com/osm/all/{z}/{x}/{y}.topojson\" });\n    //\n    //  - also can be pass a ```data``` obj: ```{type: 'GeoJSON', data: JSObj ]}```\n    //\n    //      var geojson_data = {};\n    //      ...\n    //      scene.setDataSource(\"dynamic_data\", {type: 'GeoJSON', data: geojson_data });\n    //\n    setDataSource (name, config) {\n        if (!name || !config || !config.type || (!config.url && !config.data)) {\n            log.error(\"No name provided or not a valid config:\", name, config);\n            return;\n        }\n\n        let load = (this.config.sources[name] == null);\n        let source = this.config.sources[name] = Object.assign({}, config);\n\n        if (source.data && typeof source.data === 'object') {\n            source.url = Utils.createObjectURL(new Blob([JSON.stringify(source.data)]));\n            delete source.data;\n        }\n\n        if (load) {\n            return this.updateConfig({ rebuild: { sources: [name] } });\n        } else {\n            return this.rebuild({ sources: [name] });\n        }\n    }\n\n    createDataSources() {\n        let reset = []; // sources to reset\n        let prev_source_names = Object.keys(this.sources);\n\n        for (var name in this.config.sources) {\n            let source = this.config.sources[name];\n            let prev_source = this.sources[name];\n\n            try {\n                this.sources[name] = DataSource.create(Object.assign({}, source, {name}), this.sources);\n                if (!this.sources[name]) {\n                    throw {};\n                }\n            }\n            catch(e) {\n                delete this.sources[name];\n                let message = `Could not create data source: ${e.message}`;\n                log.warn(`Scene: ${message}`, source);\n                this.trigger('warning', { type: 'sources', source, message });\n            }\n\n            // Data source changed?\n            if (DataSource.changed(this.sources[name], prev_source)) {\n                reset.push(name);\n            }\n        }\n\n        // Sources that were removed\n        for (let s of prev_source_names) {\n            if (!this.config.sources[s]) {\n                delete this.sources[s]; // TODO: remove from workers too?\n                reset.push(s);\n            }\n        }\n\n        // Remove tiles from sources that have changed\n        if (reset.length > 0) {\n            this.tile_manager.removeTiles(tile => {\n                return (reset.indexOf(tile.source.name) > -1);\n            });\n        }\n\n        // Mark sources that generate geometry tiles\n        // (all except those that are only raster sources attached to other sources)\n        for (let layer of Utils.values(this.config.layers)) {\n            if (layer.data && this.sources[layer.data.source]) {\n                this.sources[layer.data.source].geometry_tiles = true;\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        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 && rule.draw) {\n                for (let [name, group] of Utils.entries(rule.draw)) {\n                    // TODO: warn on non-object draw group\n                    if (group != null && 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    // Get active camera - for public API\n    getActiveCamera() {\n        return this.view.getActiveCamera();\n    }\n\n    // Set active camera - for public API\n    setActiveCamera(name) {\n        return this.view.setActiveCamera(name);\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.view, 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, 0]; // default background TODO: vary w/scene alpha\n        }\n\n        // if background is fully opaque, set canvas background to match\n        if (this.background.color[3] === 1) {\n            this.canvas.style.backgroundColor =\n                `rgba(${this.background.color.map(c => Math.floor(c * 255)).join(', ')})`;\n        }\n        else {\n            this.canvas.style.backgroundColor = 'transparent';\n        }\n\n        this.gl.clearColor(...this.background.color);\n    }\n\n    // Update scene config, and optionally rebuild geometry\n    // rebuild can be boolean, or an object containing rebuild options to passthrough\n    updateConfig({ rebuild } = {}) {\n        this.generation++;\n        this.updating++;\n        this.config.scene = this.config.scene || {};\n\n        StyleManager.init();\n        this.view.reset();\n        this.createLights();\n        this.createDataSources();\n        this.loadTextures();\n        this.setBackground();\n\n        // TODO: detect changes to styles? already (currently) need to recompile anyway when camera or lights change\n        this.updateStyles();\n\n        // Optionally rebuild geometry\n        let done = rebuild ?\n            this.rebuildGeometry(typeof rebuild === 'object' && rebuild) :\n            this.syncConfigToWorker(); // rebuildGeometry() also syncs config\n\n        // Finish by updating bounds and re-rendering\n        return done.then(() => {\n            this.updating--;\n            this.view.updateBounds();\n            this.requestRedraw();\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        return WorkerBroker.postMessage(this.workers, 'self.updateConfig', {\n            config: this.config_serialized,\n            generation: this.generation\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            WorkerBroker.postMessage(this.workers, 'self.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 WorkerBroker.postMessage(this.workers, 'self.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    // Fires event when rendered tile set or style changes\n    updateViewComplete () {\n        if ((this.render_count_changed || this.generation !== this.last_complete_generation) &&\n            !this.tile_manager.isLoadingVisibleTiles()) {\n            this.last_complete_generation = this.generation;\n            this.trigger('view_complete');\n        }\n    }\n\n    resetViewComplete () {\n        this.last_complete_generation = null;\n    }\n\n    // Take a screenshot\n    // Asynchronous because we have to wait for next render to capture buffer\n    // Returns a promise\n    screenshot () {\n        if (this.queue_screenshot != null) {\n            return this.queue_screenshot.promise; // only capture one screenshot at a time\n        }\n\n        this.requestRedraw();\n\n        // Will resolve once rendering is complete and render buffer is captured\n        this.queue_screenshot = {};\n        this.queue_screenshot.promise = new Promise((resolve, reject) => {\n            this.queue_screenshot.resolve = resolve;\n            this.queue_screenshot.reject = reject;\n        });\n        return this.queue_screenshot.promise;\n    }\n\n    // Called after rendering, captures render buffer and resolves promise with image data\n    completeScreenshot () {\n        if (this.queue_screenshot != null) {\n            // Get data URL, convert to blob\n            // Strip host/mimetype/etc., convert base64 to binary without UTF-8 mangling\n            // Adapted from: https://gist.github.com/unconed/4370822\n            var url = this.canvas.toDataURL('image/png');\n            var data = atob(url.slice(22));\n            var buffer = new Uint8Array(data.length);\n            for (var i = 0; i < data.length; ++i) {\n                buffer[i] = data.charCodeAt(i);\n            }\n            var blob = new Blob([buffer], { type: 'image/png' });\n\n            // Resolve with screenshot data\n            this.queue_screenshot.resolve({ url, blob });\n            this.queue_screenshot = null;\n        }\n    }\n\n\n    // Stats/debug/profiling methods\n\n    // Log messages pass through from web workers\n    workerLogMessage(event) {\n        let data = typeof event.data === 'string' ? JSON.parse(event.data) : event.data; // optional un-stringify\n        if (data.type !== 'log') {\n            return;\n        }\n\n        var { worker_id, level, msg } = 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        WorkerBroker.postMessage(this.workers, 'self.profile', name);\n    }\n\n    _profileEnd(name) {\n        console.profileEnd(`main thread: ${name}`);\n        WorkerBroker.postMessage(this.workers, 'self.profileEnd', name);\n    }\n\n    // Debug config and functions\n    setupDebug () {\n        let scene = this;\n        this.debug = {\n            profile: {\n                geometry_build: false\n            },\n\n            // Rebuild geometry a given # of times and print average, min, max timings\n            timeRebuild (num = 1, options = {}) {\n                let times = [];\n                let cycle = () => {\n                    let start = +new Date();\n                    scene.rebuild(options).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            // Return geometry counts of visible tiles, grouped by style name\n            geometryCountByStyle () {\n                let counts = {};\n                for (let tile of scene.tile_manager.getRenderableTiles()) {\n                    for (let style in tile.meshes) {\n                        counts[style] = counts[style] || 0;\n                        counts[style] += tile.meshes[style].geometry_count;\n                    }\n                }\n                return counts;\n            },\n\n            geometryCountByBaseStyle () {\n                let style_counts = scene.debug.geometryCountByStyle();\n                let counts = {};\n                for (let style in style_counts) {\n                    let base = scene.styles[style].built_in ? style : scene.styles[style].base;\n                    counts[base] = counts[base] || 0;\n                    counts[base] += style_counts[style];\n                }\n                return counts;\n            }\n        };\n    }\n\n}\n","import Utils from './utils/utils';\nimport GLSL from './gl/glsl';\nimport {StyleParser} from './styles/style_parser';\nimport mergeObjects from './utils/merge';\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 'import' scenes\n    // Optional *initial* path only (won't be passed to recursive 'import' 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            // accept single-string or array\n            if (typeof config.import === 'string') {\n                config.import = [config.import];\n            }\n\n            if (!Array.isArray(config.import)) {\n                SceneLoader.normalize(config, path);\n                return config;\n            }\n\n            // Collect URLs of scenes to import\n            let imports = [];\n            for (let url of config.import) {\n                imports.push(Utils.addBaseURL(url, path));\n            }\n            delete config.import; // don't want to merge this property\n\n            return Promise.\n                all(imports.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    // 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        // Move \"locally defined\" textures, e.g. those specified as strings or blocks,\n        // to the scene's top-level set of textures (config.textures). There are 3 such types of textures:\n        // - in a style's `texture` property (texture can be specified as string or object)\n        // - in a style's `material` properties (texture can be specified as string or object)\n        // - in a style's custom uniforms (`shaders.uniforms`) (texture can be specified as string only)\n        //\n        // For textures specified as strings, we first check to see if there is a texture already defined\n        // with that string name. If there IS, then no changes are made. If there is NOT, then the texture string\n        // is assumed to be a URL. A top-level `config.textures` object is created for the texture (with a private,\n        // synthetic texture name); the texture's URL will be expanded to include the current scene file's path below.\n        if (config.styles) {\n            for (let [style_name, style] of Utils.entries(config.styles)) {\n                // Style `texture`\n                if (style.texture) {\n                    let tex = style.texture;\n\n                    // Texture by URL (string-named texture not referencing existing texture definition)\n                    if (typeof tex === 'string' && !config.textures[tex]) {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = { url: tex };\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                    // Texture by object\n                    else if (typeof tex === 'object') {\n                        let texture_name = '__' + style_name;\n                        config.textures[texture_name] = tex;\n                        style.texture = texture_name; // point style to location of texture\n                    }\n                }\n\n                // Material\n                if (style.material) {\n                    for (let prop of ['emission', 'ambient', 'diffuse', 'specular', 'normal']) {\n                        // Material property has a texture\n                        if (style.material[prop] != null && style.material[prop].texture) {\n                            let tex = style.material[prop].texture;\n\n                            // Texture by URL (string-named texture not referencing existing texture definition)\n                            if (typeof tex === 'string' &&\n                                !config.textures[tex]) {\n                                let texture_name = '__' + style_name + '_material_' + prop;\n                                config.textures[texture_name] = { url: tex };\n                                style.material[prop].texture = texture_name; // point style to location of texture\n                            }\n                            // Texture by object\n                            else if (typeof tex === 'object') {\n                                let texture_name = '__' + style_name + '_material_' + prop;\n                                config.textures[texture_name] = tex;\n                                style.material[prop].texture = texture_name; // point style to location of texture\n                            }\n                        }\n                    }\n                }\n\n                // Shader uniforms\n                if (style.shaders && style.shaders.uniforms) {\n                    for (let {type, value, key, uniforms} of GLSL.parseUniforms(style.shaders.uniforms)) {\n                        // Texture by URL (string-named texture not referencing existing texture definition)\n                        if (type === 'sampler2D' && typeof value === 'string' && !config.textures[value]) {\n                            let texture_name = '__' + style_name + '_uniform_' + key;\n                            config.textures[texture_name] = { url: value };\n                            uniforms[key] = texture_name; // point style to location of texture\n                        }\n                    }\n\n                }\n            }\n        }\n\n        // Add current scene file base path to textures\n        // Only adds path for textures with relative URLs, so textures in imported scenes get the base\n        // path of their immediate scene file\n        if (config.textures) {\n            for (let texture of Utils.values(config.textures)) {\n                if (texture.url) {\n                    texture.url = Utils.addBaseURL(texture.url, path);\n                }\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        // Replace global scene properties\n        config = StyleParser.applyGlobalProperties(config);\n\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        config.layers = config.layers || {};\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 mergeObjects from './utils/merge';\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\nif (Utils.isWorkerThread) {\n\nObject.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: {},     // raw config (e.g. functions, etc. not expanded)\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        config = JSON.parse(config);\n\n        self.last_config = mergeObjects({}, self.config);\n        self.config = mergeObjects({}, config);\n        self.generation = generation;\n\n        // Data block functions are not context wrapped like the rest of the style functions are\n        // TODO: probably want a cleaner way to exclude these\n        for (let layer in config.layers) {\n            if (config.layers[layer]) {\n                config.layers[layer].data = Utils.stringsToFunctions(config.layers[layer].data);\n            }\n        }\n\n        // Expand global properties\n        self.global = Utils.stringsToFunctions(config.global);\n\n        // Create data sources\n        config.sources = Utils.stringsToFunctions(config.sources); // parse new sources\n        self.sources.tiles = {}; // clear previous sources\n        for (let name in config.sources) {\n            let source;\n            try {\n                source = DataSource.create(Object.assign({}, config.sources[name], {name}), self.sources.tiles);\n            }\n            catch(e) {\n                continue;\n            }\n\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        // Clear tile cache if data source config changed\n        if (!self.config.sources ||\n            !self.last_config.sources ||\n            Object.keys(self.config.sources).some(s => {\n                return JSON.stringify(self.config.sources[s]) !== JSON.stringify(self.last_config.sources[s]);\n            })) {\n            self.tiles = {};\n        }\n\n        // Expand styles\n        config.styles = Utils.stringsToFunctions(config.styles, StyleParser.wrapFunction);\n        self.styles = StyleManager.build(config.styles, { generation: self.generation, sources: self.sources.tiles });\n\n        // Parse each top-level layer as a separate rule tree\n        self.layers = Utils.stringsToFunctions(config.layers, StyleParser.wrapFunction);\n        self.rules = parseRules(self.layers);\n\n        // Sync tetxure info from main thread\n        self.syncing_textures = self.syncTextures(config.textures);\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.getTile(tile.key) != null) {\n            // Already loading?\n            if (self.getTile(tile.key).loading === true) {\n                return;\n            }\n        }\n\n        // Update tile cache\n        tile = self.tiles[tile.key] = Object.assign(self.getTile(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                        if (!self.getTile(tile.key)) {\n                            Utils.log('trace', `stop tile build after data source load because tile was removed: ${tile.key}`);\n                            return;\n                        }\n\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).then(keys => {\n                            resolve(WorkerBroker.returnWithTransferables({ 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}: ${tile.error} at: ${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).then(keys => {\n                    return WorkerBroker.returnWithTransferables({ tile: Tile.slice(tile, keys) });\n                });\n            }\n        });\n    },\n\n    // Load this tile's data source\n    loadTileSourceData (tile) {\n        if (self.sources.tiles[tile.source]) {\n            return self.sources.tiles[tile.source].load(tile);\n        }\n        else {\n            tile.source_data = { error: `Data source '${tile.source}' not found` };\n            return Promise.resolve(tile);\n        }\n    },\n\n    getTile(key) {\n        return self.tiles[key];\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, e.g. width/height, which we only know after the texture loads\n    syncTextures (tex_config) {\n        let textures = [];\n        if (tex_config) {\n            textures.push(...Object.keys(tex_config));\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    // Sync device pixel ratio from main thread\n    updateDevicePixelRatio (device_pixel_ratio) {\n        Utils.device_pixel_ratio = device_pixel_ratio;\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\nWorkerBroker.addTarget('self', self);\n\n}\n","import Texture from './gl/texture';\nimport WorkerBroker from './utils/worker_broker';\n\nimport log from 'loglevel';\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 = Texture.create( this.gl, 'selection_fbo', { filtering: 'nearest' });\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                reject\n            };\n        });\n    }\n\n    // Any pending selection requests\n    pendingRequests() {\n        return this.requests;\n    }\n\n    clearPendingRequests() {\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            // Reject request since it will never be fulfilled\n            // TODO: pass a reason for rejection?\n            request.reject({ request });\n            delete this.requests[r];\n        }\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                            'self.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            log.error(\"FeatureSelection.finishRead(): could not find message\", message);\n            return; // request was cleared before it returned\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 &&\n                JSON.stringify(feature) !== JSON.stringify(this.feature))) {\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        // Initialize tile-specific tracking info\n        if (!this.tiles[tile.key]) {\n            this.tiles[tile.key] = {\n                entries: [],                        // set of feature entries in this thread\n                tile: {                             // subset of tile properties to pass back with feature\n                    key: tile.key,\n                    coords: tile.coords,\n                    style_zoom: tile.style_zoom,\n                    source: tile.source,\n                    generation: tile.generation\n                }\n            };\n        }\n\n        this.tiles[tile.key].entries.push(key);\n\n        return this.map[key];\n    }\n\n    static makeColor(feature, tile, context) {\n        var selector = this.makeEntry(tile);\n        selector.feature = {\n            id: feature.id,\n            properties: feature.properties,\n            layers: context.layers,\n            tile: this.tiles[tile.key].tile\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 (this.tiles[key]) {\n            this.tiles[key].entries.forEach(k => delete this.map[k]);\n            this.map_size -= this.tiles[key].entries.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 (config, sources) {\n        this.config = config; // save original config\n        this.sources = sources; // full set of data sources TODO: centralize these like textures?\n        this.id = config.id;\n        this.name = config.name;\n        this.pad_scale = config.pad_scale || 0.0001; // scale tile up by small factor to cover seams\n        this.default_winding = null; // winding order will adapt to data source\n        this.rasters = // attached raster tile sources\n            Array.isArray(config.rasters) ? [...new Set(config.rasters)] : []; // de-dupe with set conversion\n\n        // Optional function to transform source data\n        this.transform = config.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 = config.extra_data;\n\n        // Optional additional scripts made available to the transform function\n        if (typeof importScripts === 'function' && config.scripts) {\n            config.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 = config.max_zoom || Geo.default_source_max_zoom;\n    }\n\n    // Create a tile source by type, factory-style\n    static create (source, sources) {\n        if (DataSource.types[source.type]) {\n            return new DataSource.types[source.type](source, sources);\n        }\n    }\n\n    // Check if a data source definition changed\n    static changed (source, prev_source) {\n        if (!source || !prev_source) {\n            return true;\n        }\n\n        let cur = Object.assign({}, source.config, { id: null }); // null out ids since we don't want to compare them\n        let prev = Object.assign({}, prev_source.config, { id: null });\n\n        return JSON.stringify(cur) !== JSON.stringify(prev);\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        let units_per_meter = Geo.unitsPerMeter(z);\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) * units_per_meter;\n                    coord[1] = (coord[1] - min.y) * units_per_meter * -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        dest.rasters = [...this.rasters]; // copy list of rasters to load for tile\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                        // Use first encountered polygon winding order as default for data source\n                        this.updateDefaultWinding(feature.geometry);\n                    });\n                }\n            }\n\n            dest.default_winding = this.default_winding || 'CCW';\n            return dest;\n        });\n    }\n\n    // Sub-classes must implement\n    _load(dest) {\n        throw new MethodNotImplemented('_load');\n    }\n\n    // Infer winding for data source from first ring of provided geometry\n    updateDefaultWinding (geom) {\n        if (this.default_winding == null) {\n            if (geom.type === 'Polygon') {\n                this.default_winding = Geo.ringWinding(geom.coordinates[0]);\n            }\n            else if (geom.type === 'MultiPolygon') {\n                this.default_winding = Geo.ringWinding(geom.coordinates[0][0]);\n            }\n        }\n        return this.default_winding;\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.url = Utils.addParamsToURL(source.url, source.url_params);\n        this.response_type = \"\"; // use to set explicit XHR type\n\n        if (this.url == null) {\n            throw Error('Network data source must provide a `url` property');\n        }\n    }\n\n    _load (dest) {\n        let url = this.formatUrl(this.url, 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 (url_template, 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(url_template, tile) {\n        let coords = Geo.wrapTile(tile.coords, { x: true });\n        let url = url_template.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 {MVTSource} from './mvt';\nimport Geo from '../geo';\n\n// For tiling GeoJSON client-side\nimport geojsonvt from 'geojson-vt';\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    }\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                // GeoJSON feature\n                let f = {\n                    type: 'Feature',\n                    geometry: {},\n                    properties: feature.tags\n                };\n\n                if (feature.type === 1) {\n                    f.geometry.coordinates = feature.geometry.map(coord => [coord[0], coord[1]]);\n                    f.geometry.type = 'MultiPoint';\n                }\n                else if (feature.type === 2 || feature.type === 3) {\n                    f.geometry.coordinates = feature.geometry.map(ring =>\n                        ring.map(coord => [coord[0], coord[1]])\n                    );\n\n                    if (feature.type === 2) {\n                        f.geometry.type = 'MultiLineString';\n                    }\n                    else  {\n                        f.geometry = MVTSource.decodeMultiPolygon(f.geometry); // un-flatten rings\n                    }\n                }\n                else {\n                    continue;\n                }\n\n                collection.features.push(f);\n            }\n        }\n\n        return collection;\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\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, this.extra_data);\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\nDataSource.register(GeoJSONTileSource, 'GeoJSON');      // prefered shorter name\nDataSource.register(GeoJSONTileSource, 'GeoJSONTiles'); // for backwards-compatibility\n","import DataSource, {NetworkTileSource} from './data_source';\nimport Geo from '../geo';\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 = MVTSource.decodeMultiPolygon(geometry); // un-flatten rings\n                }\n\n                layer_geojson.features.push(feature_geojson);\n            }\n            layers[l] = layer_geojson;\n        }\n        return layers;\n    }\n\n    // Decode multipolygons, which are encoded as a single set of rings\n    // Winding order of first ring is assumed to indicate exterior ring,\n    // the opposite winding order indicates the start of a new polygon.\n    static decodeMultiPolygon (geom) {\n        let polys = [];\n        let poly = [];\n        let outer_winding;\n        for (let ring of geom.coordinates) {\n            let winding = Geo.ringWinding(ring);\n            if (winding == null) {\n                continue; // skip zero-area rings\n            }\n\n            outer_winding = outer_winding || winding; // assume first ring indicates outer ring winding\n\n            if (winding === outer_winding && 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\n        // Single or multi?\n        if (polys.length === 1) {\n            geom.type = 'Polygon';\n            geom.coordinates = polys[0];\n        }\n        else {\n            geom.type = 'MultiPolygon';\n            geom.coordinates = polys;\n        }\n\n        return geom;\n    }\n\n}\n\nDataSource.register(MVTSource, 'MVT');\n","import DataSource, {NetworkTileSource} from './data_source';\nimport Tile from '../tile';\nimport Geo from '../geo';\n\nexport class RasterTileSource extends NetworkTileSource {\n\n    constructor(source) {\n        super(source);\n\n        if (this.rasters.indexOf(this.name) === -1) {\n            this.rasters.unshift(this.name); // add this raster as the first\n        }\n        this.filtering = source.filtering; // optional texture filtering (nearest, linear, mipmap)\n\n        // save texture objects by tile key, so URL remains stable if tile is built multiple times,\n        // e.g. avoid re-loading the same tile texture under a different subdomain when using tile hosts\n        this.textures = {};\n    }\n\n    load(tile) {\n        tile.source_data = {};\n        tile.source_data.layers = {};\n        tile.pad_scale = this.pad_scale;\n        tile.rasters = [...this.rasters]; // copy list of rasters to load for tile\n\n        // Generate a single quad that fills the entire tile\n        let scale = Geo.tile_scale;\n        tile.source_data.layers = {\n            _default: {\n                type: 'FeatureCollection',\n                features: [{\n                    geometry: {\n                        type: 'Polygon',\n                        coordinates: [[\n                            [0, 0], [scale, 0],\n                            [scale, -scale], [0, -scale], [0, 0]\n                        ]]\n                    },\n                    properties: {}\n                }]\n            }\n        };\n\n        tile.default_winding = 'CW';\n        return Promise.resolve(tile);\n    }\n\n    // Return texture info for a raster tile\n    tileTexture (tile) {\n        let key = tile.coords.key;\n        if (!this.textures[key]) {\n            let coords = Tile.coordinateWithMaxZoom(tile.coords, this.max_zoom);\n            let url = this.formatUrl(this.url, { coords });\n            this.textures[key] = { url, filtering: this.filtering, coords };\n        }\n        return this.textures[key];\n    }\n\n}\n\nDataSource.register(RasterTileSource, 'Raster');\n","import DataSource from './data_source';\nimport {GeoJSONSource, GeoJSONTileSource} from './geojson';\n\nimport topojson from 'topojson';\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\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\nDataSource.register(TopoJSONTileSource, 'TopoJSON');        // prefered shorter name\nDataSource.register(TopoJSONTileSource, 'TopoJSONTiles');   // for backwards-compatibility\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 {buildPolylines} from '../../builders/polylines';\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            // Scaling factor to add precision to line texture V coordinate packed as normalized short\n            this.defines.TANGRAM_V_SCALE_ADJUST = Geo.tile_scale;\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        // Additional single-allocated object used for holding outline style as it is processed\n        // Separate from this.feature_style so that outline properties do not overwrite calculated\n        // inline properties (outline call is made *within* the inline call)\n        this.outline_feature_style = {};\n        this.inline_feature_style = this.feature_style; // save reference to main computed style object\n    },\n\n    // Calculate width at zoom given in `context`\n    calcWidth (width, context) {\n        return (width && StyleParser.cacheDistance(width, context)) || 0;\n    },\n\n    // Calculate width at next zoom (used for line width interpolation)\n    calcWidthNextZoom (width, context) {\n        context.zoom++;\n        let val = this.calcWidth(width, context);\n        context.zoom--;\n        return val;\n    },\n\n    _parseFeature (feature, rule_style, context) {\n        var style = this.feature_style;\n\n        // line width in meters\n        let width = this.calcWidth(rule_style.width, context);\n        if (width < 0) {\n            return; // skip lines with negative width\n        }\n        let next_width = this.calcWidthNextZoom(rule_style.next_width, context);\n\n        if ((width === 0 && next_width === 0) || next_width < 0) {\n            return; // skip lines that don't interpolate to a positive value at next zoom\n        }\n\n        // convert to units and relative change from previous zoom\n        // NB: multiply by 2 because a given width is twice as big in screen space at the next zoom\n        style.width = width * context.units_per_meter;\n        style.next_width = (next_width * 2) - width;\n        style.next_width *= context.units_per_meter;\n        style.next_width /= 2; // NB: divide by 2 because extrusion width is halved in builder - remove?\n\n        style.color = this.parseColor(rule_style.color, context);\n        if (!style.color) {\n            return;\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 = StyleParser.evalProp(rule_style.extrude, context);\n        if (style.extrude) {\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.miter_limit = rule_style.miter_limit;\n        style.tile_edges = rule_style.tile_edges; // usually activated for debugging, or rare visualization needs\n\n        // Construct an outline style\n        // Reusable outline style object, marked as already wrapped in cache objects (preprocessed = true)\n        style.outline = style.outline || { width: {}, next_width: {}, preprocessed: true };\n\n        if (rule_style.outline && rule_style.outline.color && rule_style.outline.width) {\n            // outline width in meters\n            // NB: multiply by 2 because outline is applied on both sides of line\n            let outline_width = this.calcWidth(rule_style.outline.width, context) * 2;\n            let outline_next_width = this.calcWidthNextZoom(rule_style.outline.next_width, context) * 2;\n\n            if ((outline_width === 0 && outline_next_width === 0) || outline_width < 0 || outline_next_width < 0) {\n                // skip lines that don't interpolate between zero or greater width\n                style.outline.width.value = null;\n                style.outline.next_width.value = null;\n                style.outline.color = null;\n            }\n            else {\n                // Maintain consistent outline width around the line fill\n                style.outline.width.value = outline_width + 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.miter_limit = rule_style.outline.miter_limit || rule_style.miter_limit;\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        }\n        else {\n            style.outline.width.value = null;\n            style.outline.next_width.value = null;\n            style.outline.color = null;\n        }\n\n        return style;\n    },\n\n    _preprocess (draw) {\n        draw.color = StyleParser.colorCacheObject(draw.color);\n        draw.width = StyleParser.cacheObject(draw.width, StyleParser.cacheUnits);\n        draw.next_width = StyleParser.cacheObject(draw.width, StyleParser.cacheUnits); // width will be computed for next zoom\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n\n        if (draw.outline) {\n            draw.outline.color = StyleParser.colorCacheObject(draw.outline.color);\n            draw.outline.width = StyleParser.cacheObject(draw.outline.width, StyleParser.cacheUnits);\n            draw.outline.next_width = StyleParser.cacheObject(draw.outline.width, StyleParser.cacheUnits); // width re-computed for next zoom\n        }\n        return draw;\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++] = this.scaleOrder(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        // Outline (build first so that blended geometry without a depth test is drawn first/under the inner line)\n        this.feature_style = this.outline_feature_style; // swap in outline-specific style holder\n        if (style.outline && style.outline.color != null && style.outline.width.value != null) {\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        // Main line\n        this.feature_style = this.inline_feature_style; // restore calculated style for inline\n        let vertex_template = this.makeVertexTemplate(style);\n        buildPolylines(\n            lines,\n            style.width,\n            vertex_data,\n            vertex_template,\n            {\n                cap: style.cap,\n                join: style.join,\n                miter_limit: style.miter_limit,\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    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","// Sets of values to match for directional and corner anchors\nconst lefts = ['left', 'top-left', 'bottom-left'];\nconst rights = ['right', 'top-right', 'bottom-right'];\nconst tops = ['top', 'top-left', 'top-right'];\nconst bottoms = ['bottom', 'bottom-left', 'bottom-right'];\n\nvar PointAnchor;\n\nexport default PointAnchor = {\n\n    computeOffset (offset, size, anchor) {\n        if (!anchor || anchor === 'center') {\n            return offset;\n        }\n\n        let offset2 = [offset[0], offset[1]];\n\n        // An optional left/right offset\n        if (this.isLeftAnchor(anchor)) {\n            offset2[0] -= size[0] / 2;\n        }\n        else if (this.isRightAnchor(anchor)) {\n            offset2[0] += size[0] / 2;\n        }\n\n        // An optional top/bottom offset\n        if (this.isTopAnchor(anchor)) {\n            offset2[1] -= size[1] / 2;\n        }\n        else if (this.isBottomAnchor(anchor)) {\n            offset2[1] += size[1] / 2;\n        }\n\n        return offset2;\n    },\n\n    isLeftAnchor (anchor) {\n        return (lefts.indexOf(anchor) > -1);\n    },\n\n    isRightAnchor (anchor) {\n        return (rights.indexOf(anchor) > -1);\n    },\n\n    isTopAnchor (anchor) {\n        return (tops.indexOf(anchor) > -1);\n    },\n\n    isBottomAnchor (anchor) {\n        return (bottoms.indexOf(anchor) > -1);\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 {buildQuadsForPoints} from '../../builders/points';\nimport Texture from '../../gl/texture';\nimport Geo from '../../geo';\nimport Utils from '../../utils/utils';\nimport Vector from '../../vector';\nimport Collision from '../../labels/collision';\nimport LabelPoint from '../../labels/label_point';\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        this.queues = {};\n    },\n\n    reset () {\n        this.queues = {};\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, draw, context) {\n        let tile = context.tile;\n\n        // Called here because otherwise it will be delayed until the feature queue is parsed,\n        // and we want the preprocessing done before we evaluate text style below\n        draw = this.preprocess(draw);\n        if (!draw) {\n            return;\n        }\n\n        let style = {};\n        style.color = this.parseColor(draw.color, context);\n\n        // require color or texture\n        if (!style.color && !this.texture) {\n            return null;\n        }\n\n        let sprite = style.sprite = StyleParser.evalProp(draw.sprite, context);\n        style.sprite_default = draw.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        else if (sprite) {\n            log.warn(`Style: in style '${this.name}', sprite '${sprite}' was specified, but texture '${this.texture}' has no sprites`);\n            sprite = null;\n        }\n\n        // Sets texcoord scale if needed (e.g. for sprite sub-area)\n        let sprite_info;\n        if (this.texture && sprite) {\n            sprite_info = Texture.getSpriteInfo(this.texture, sprite);\n            style.texcoords = sprite_info.texcoords;\n        } else {\n            style.texcoords = null;\n        }\n\n        // points can be placed off the ground\n        style.z = (draw.z && StyleParser.cacheDistance(draw.z, context)) || StyleParser.defaults.z;\n\n        // point size defined explicitly, or defaults to sprite size, or generic fallback\n        style.size = draw.size;\n        if (!style.size) {\n            if (sprite_info) {\n                style.size = sprite_info.size;\n            }\n            else {\n                style.size = [16, 16];\n            }\n        }\n        else {\n            style.size = StyleParser.cacheProperty(style.size, context);\n        }\n\n        // size will be scaled to 16-bit signed int, so max allowed width + height of 256 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.angle = StyleParser.evalProp(draw.angle, context) || 0;\n\n        // polygons rendering as points will render at the polygon's centroid by default,\n        // but can be set to render at each individual polygon point instead\n        style.centroid = (draw.centroid != null) ? draw.centroid : true;\n\n        this.computeLayout(style, feature, draw, context, tile);\n\n        // Queue the feature for processing\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile);\n        }\n\n        if (!this.queues[tile.key]) {\n            this.queues[tile.key] = [];\n        }\n\n        this.queues[tile.key].push({\n            feature, draw, context, style\n        });\n\n        // Register with collision manager\n        Collision.addStyle(this.name, tile.key);\n    },\n\n    // Override\n    endData (tile) {\n        if (tile.canceled) {\n            Utils.log('trace', `Style ${this.name}: stop tile build because tile was canceled: ${tile.key}`);\n            return;\n        }\n\n        let queue = this.queues[tile.key];\n        this.queues[tile.key] = [];\n\n        // For each feature, create one or more point labels\n        let boxes = [];\n        queue.forEach(q => {\n            let style = q.style;\n            let feature = q.feature;\n            let geometry = feature.geometry;\n\n            let feature_labels = this.buildLabelsFromGeometry(style.size, geometry, style);\n            for (let i = 0; i < feature_labels.length; i++) {\n                let label = feature_labels[i];\n                boxes.push({\n                    feature,\n                    draw: q.draw,\n                    context: q.context,\n                    style,\n                    layout: style,\n                    label\n                });\n            }\n        });\n\n        // Submit point labels for collision, then build geometry for remaining ones\n        return Collision.collide(boxes, this.name, tile.key).then(boxes => {\n            boxes.forEach(q => {\n                this.feature_style = q.style;\n                this.feature_style.label = q.label;\n\n                Style.addFeature.call(this, q.feature, q.draw, q.context);\n            });\n\n            return Style.endData.call(this, tile);\n        });\n    },\n\n    _preprocess (draw) {\n        draw.color = StyleParser.colorCacheObject(draw.color);\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n\n        // Size (1d value or 2d array)\n        draw.size = StyleParser.cacheObject(draw.size, v => Array.isArray(v) ? v.map(parseFloat) : parseFloat(v));\n\n        // Offset (2d array)\n        draw.offset = StyleParser.cacheObject(draw.offset, v => (Array.isArray(v) && v.map(parseFloat)) || 0);\n\n        // Buffer (1d value or 2d array, expand 1d to 2d)\n        draw.buffer = StyleParser.cacheObject(draw.buffer, v => (Array.isArray(v) ? v : [v, v]).map(parseFloat) || 0);\n\n        return draw;\n    },\n\n    // Compute label layout-related properties\n    computeLayout (target, feature, draw, context, tile) {\n        let layout = target || {};\n        layout.id = feature;\n        layout.units_per_pixel = tile.units_per_pixel || 1;\n\n        // collision flag\n        layout.collide = (draw.collide === false) ? false : true;\n\n        // label anchors (point labels only)\n        // label position will be adjusted in the given direction, relative to its original point\n        // one of: left, right, top, bottom, top-left, top-right, bottom-left, bottom-right\n        layout.anchor = draw.anchor;\n\n        // label offset and buffer in pixel (applied in screen space)\n        layout.offset = StyleParser.cacheProperty(draw.offset, context) || StyleParser.zeroPair;\n        layout.buffer = StyleParser.cacheProperty(draw.buffer, context) || StyleParser.zeroPair;\n\n        // label priority (lower is higher)\n        let priority = draw.priority;\n        if (priority != null) {\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        layout.priority = priority;\n\n        return layout;\n    },\n\n    // Builds one or more point labels for a geometry\n    buildLabelsFromGeometry (size, geometry, options) {\n        let labels = [];\n\n        if (geometry.type === \"Point\") {\n            labels.push(new LabelPoint(geometry.coordinates, size, options));\n        }\n        else if (geometry.type === \"MultiPoint\") {\n            let points = geometry.coordinates;\n            for (let i = 0; i < points.length; ++i) {\n                let point = points[i];\n                labels.push(new LabelPoint(point, size, options));\n            }\n        }\n        else if (geometry.type === \"LineString\") {\n            // Point at each line vertex\n            let points = geometry.coordinates;\n            for (let i = 0; i < points.length; ++i) {\n                labels.push(new LabelPoint(points[i], size, options));\n            }\n        }\n        else if (geometry.type === \"MultiLineString\") {\n            // Point at each line vertex\n            let lines = geometry.coordinates;\n            for (let ln = 0; ln < lines.length; ln++) {\n                let points = lines[ln];\n                for (let i = 0; i < points.length; ++i) {\n                    labels.push(new LabelPoint(points[i], size, options));\n                }\n            }\n        }\n        else if (geometry.type === \"Polygon\") {\n            // Point at polygon centroid (of outer ring)\n            if (options.centroid) {\n                let centroid = Geo.centroid(geometry.coordinates[0]);\n                labels.push(new LabelPoint(centroid, size, options));\n            }\n            // Point at each polygon vertex (all rings)\n            else {\n                let rings = geometry.coordinates;\n                for (let ln = 0; ln < rings.length; ln++) {\n                    let points = rings[ln];\n                    for (let i = 0; i < points.length; ++i) {\n                        labels.push(new LabelPoint(points[i], size, options));\n                    }\n                }\n            }\n        }\n        else if (geometry.type === \"MultiPolygon\") {\n            let centroid = Geo.multiCentroid(geometry.coordinates);\n            labels.push(new LabelPoint(centroid, size, options));\n        }\n\n        return labels;\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', this.scaleOrder(style.order), { 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, offset, texcoord_scale, vertex_data, vertex_template) {\n        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,\n                angle: Utils.scaleInt16(angle, 360),\n                texcoord_scale: texcoord_scale,\n                texcoord_normalize: 65535\n            }\n        );\n    },\n\n    // Build quad for point sprite\n    build (style, vertex_data) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let label = style.label;\n\n        this.buildQuad(\n            [label.position],               // position\n            style.size,                     // size in pixels\n            style.angle,                    // angle in degrees\n            label.options.offset,           // offset from center in pixels\n            style.texcoords,                // texture UVs\n            vertex_data, vertex_template    // VBO and data for current vertex\n        );\n    },\n\n    // Override to pass-through to generic point builder\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});\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 {buildPolygons, buildExtrudedPolygons} from '../../builders/polygons';\nimport Geo from '../../geo';\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 = StyleParser.evalProp(rule_style.extrude, context);\n        if (style.extrude) {\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.tile_edges = rule_style.tile_edges; // usually activated for debugging, or rare visualization needs\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 = StyleParser.colorCacheObject(draw.color);\n        draw.z = StyleParser.cacheObject(draw.z, StyleParser.cacheUnits);\n        return draw;\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++] = this.scaleOrder(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, context) {\n        let vertex_template = this.makeVertexTemplate(style);\n        let options = {\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            remove_tile_edges: !style.tile_edges,\n            tile_edge_tolerance: Geo.tile_scale * context.tile.pad_scale * 4,\n            winding: context.winding\n        };\n\n        // Extruded polygons (e.g. 3D buildings)\n        if (style.extrude && style.height) {\n            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                options\n            );\n        }\n        // Regular polygons\n        else {\n            buildPolygons(\n                polygons,\n                vertex_data, vertex_template,\n                options\n            );\n        }\n    }\n\n});\n","// Raster tile rendering style\n\nimport {StyleParser} from '../style_parser';\nimport {Polygons} from '../polygons/polygons';\n\nexport let RasterStyle = Object.create(Polygons);\n\nObject.assign(RasterStyle, {\n    name: 'raster',\n    super: Polygons,\n    built_in: true,\n    selection: false, // no feature selection by default\n\n    init() {\n        // Required for raster tiles\n        this.raster = this.raster || 'color';\n\n        this.super.init.apply(this, arguments);\n    },\n\n    _preprocess (draw) {\n        // Raster tiles default to white vertex color, as this color will tint the underlying texture\n        draw.color = draw.color || StyleParser.defaults.color;\n        return this.super._preprocess.apply(this, arguments);\n    }\n\n});\n","import {Styles} from './style_manager';\nimport mergeObjects from '../utils/merge';\nimport {match} from 'match-feature';\nimport log from 'loglevel';\n\nexport const whiteList = ['filter', 'draw', 'visible', 'data'];\n\nexport let ruleCache = {};\n\nfunction cacheKey (rules) {\n    if (rules.length > 1) {\n        var k = rules[0];\n        for (var i=1; i < rules.length; i++) {\n            k += '/' + rules[i];\n        }\n\n        return k;\n    }\n    return rules[0];\n}\n\n// Merge matching layer rule trees into a final draw group\nexport function mergeTrees(matchingTrees, group) {\n    let draws, treeDepth = 0;\n\n    let draw = {\n        visible: true // visible by default\n    };\n\n    // Find deepest tree\n    for (let 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 (let x=0; x < treeDepth; x++) {\n        // Pull out the requested draw group, for each tree, at this depth\n        draws = matchingTrees.map(tree => tree[x] && tree[x][group]);\n        if (draws.length === 0) {\n            continue;\n        }\n\n        // Sort by layer name before merging, so rules are applied deterministically\n        // when multiple rules modify the same properties\n        draws.sort((a, b) => (a && a.layer_name) > (b && b.layer_name) ? 1 : -1);\n\n        // Merge draw objects\n        mergeObjects(draw, ...draws);\n\n        // Remove layer names, they were only used transiently to sort and calculate final layer\n        // (final merged names will not be accurate since only one tree can win)\n        delete draw.layer_name;\n    }\n\n    // Short-circuit if not visible\n    if (draw.visible === false) {\n        return null;\n    }\n\n    return draw;\n}\n\n\nclass Rule {\n\n    constructor({name, parent, draw, visible, filter}) {\n        this.id = Rule.id++;\n        this.parent = parent;\n        this.name = name;\n        this.full_name = this.parent ? (this.parent.full_name + ':' + this.name) : this.name;\n        this.draw = draw;\n        this.filter = filter;\n        this.visible = visible !== undefined ? visible : (this.parent && this.parent.visible);\n\n        // Denormalize layer name to draw groups\n        if (this.draw) {\n            for (let group in this.draw) {\n                this.draw[group] = this.draw[group] || {};\n                this.draw[group].layer_name = this.full_name;\n            }\n        }\n\n        this.buildFilter();\n        this.buildDraw();\n    }\n\n    buildDraw() {\n        this.calculatedDraw = calculateDraw(this);\n    }\n\n    buildFilter() {\n        let type = typeof this.filter;\n        if (this.filter != null && type !== 'object' && type !== 'function') {\n            // Invalid filter\n            let msg = `Filter for layer ${this.full_name} is invalid, filter value must be an object or function, `;\n            msg += `but was set to \\`filter: ${this.filter}\\` instead`;\n            log.warn(msg);\n            return;\n        }\n\n        try {\n            this.buildZooms();\n            this.filter = this.filter && match(this.filter);\n        }\n        catch(e) {\n            // Invalid filter\n            let msg = `Filter for layer ${this.full_name} is invalid, \\`filter: ${JSON.stringify(this.filter)}\\` `;\n            msg += `failed with error ${e.message}, ${e.stack}`;\n            log.warn(msg);\n        }\n    }\n\n    // Zooms often cull large swaths of the layer rule tree, so they get special treatment and are checked first\n    buildZooms() {\n        let zoom = this.filter && this.filter.$zoom;\n        let ztype = typeof zoom;\n        if (zoom != null && ztype !== 'function') { // don't accelerate function-based filters\n            this.zooms = {};\n\n            if (ztype === 'number') {\n                this.zooms[zoom] = true;\n            }\n            else if (Array.isArray(zoom)) {\n                for (let z=0; z < zoom.length; z++) {\n                    this.zooms[zoom[z]] = true;\n                }\n            }\n            else if (ztype === 'object' && (zoom.min != null || zoom.max != null)) {\n                let zmin = zoom.min || 0;\n                let zmax = zoom.max || 25; // TODO: replace constant for max possible zoom\n                for (let z=zmin; z < zmax; z++) {\n                    this.zooms[z] = true;\n                }\n            }\n\n            delete this.filter.$zoom; // don't process zoom through usual generic filter logic\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}) {\n        super({name, parent, draw, visible, filter});\n    }\n\n}\n\nexport class RuleTree extends Rule {\n    constructor({name, parent, draw, visible, rules, filter}) {\n        super({name, parent, draw, visible, filter});\n        this.rules = rules || [];\n    }\n\n    addRule(rule) {\n        this.rules.push(rule);\n    }\n\n    buildDrawGroups(context) {\n        let rules = [], rule_ids = [];\n        //TODO, should this function take a RuleTree\n        matchFeature(context, [this], rules, rule_ids);\n\n        if (rules.length > 0) {\n            let cache_key = cacheKey(rule_ids);\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                // Find all the unique visible draw blocks for this rule tree\n                let draw_rules = rules.map(x => x && x.visible !== false && x.calculatedDraw);\n                let draw_keys = {};\n\n                for (let r=0; r < draw_rules.length; r++) {\n                    let rule = draw_rules[r];\n                    if (!rule) {\n                        continue;\n                    }\n                    for (let g=0; g < rule.length; g++) {\n                        let group = rule[g];\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);\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                        ruleCache[cache_key][draw_key].layers = rules.map(x => x && x.full_name);\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            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 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' && !Array.isArray(property)) {\n                parseRuleTree(key, property, r);\n            } else {\n                // Invalid layer\n                let msg = `Layer value must be an object: can't create layer '${key}: ${JSON.stringify(property)}'`;\n                msg += `, under parent layer '${r.full_name}'.`;\n\n                // If the parent is a style name, this may be an incorrectly nested layer\n                if (Styles[r.name]) {\n                    msg += ` The parent '${r.name}' is also the name of a style, did you mean to create a 'draw' group`;\n                    if (parent) {\n                        msg += ` under '${parent.name}'`;\n                    }\n                    msg += ` instead?`;\n                }\n                log.warn(msg);\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        if (rule) {\n            ruleTrees[key] = parseRuleTree(key, rule);\n        }\n    }\n\n    return ruleTrees;\n}\n\n\nfunction doesMatch(rule, context) {\n    // zoom pre-filter: skip rest of filter if out of rule zoom range\n    if (rule.zooms != null && !rule.zooms[context.zoom]) {\n        return false;\n    }\n\n    return ((typeof rule.filter === 'function' && rule.filter(context)) || (rule.filter == null));\n}\n\nexport function matchFeature(context, rules, collectedRules, collectedRulesIds) {\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\n        if (current instanceof RuleLeaf) {\n\n            if (doesMatch(current, context)) {\n                matched = true;\n                collectedRules.push(current);\n                collectedRulesIds.push(current.id);\n            }\n\n        } else if (current instanceof RuleTree) {\n            if (doesMatch(current, context)) {\n                matched = true;\n\n                childMatched = matchFeature(\n                    context,\n                    current.rules,\n                    collectedRules,\n                    collectedRulesIds\n                );\n\n                if (!childMatched) {\n                    collectedRules.push(current);\n                    collectedRulesIds.push(current.id);\n                }\n            }\n        }\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 Texture from '../gl/texture';\nimport Material from '../material';\nimport Light from '../light';\nimport {RasterTileSource} from '../sources/raster';\nimport shaderSources from '../gl/shader_sources'; // built-in shaders\nimport Utils from '../utils/utils';\nimport WorkerBroker from '../utils/worker_broker';\n\nimport log from 'loglevel';\n\n// Base class\n\nexport var Style = {\n    init ({ generation, sources = {} } = {}) {\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.sources = sources;                     // data sources for scene\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\n        // Provide a hook for this object to be called from worker threads\n        this.main_thread_target = 'Style-' + this.name;\n        if (Utils.isMainThread) {\n            WorkerBroker.addTarget(this.main_thread_target, this);\n        }\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        if (this.blend_order == null) { // controls order of rendering for styles w/non-opaque blending\n            this.blend_order = -1; // defaults to first\n        }\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        // Setup raster samplers if needed\n        this.setupRasters();\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.key] = {\n            vertex_data: null,\n            uniforms: {},\n            textures: []\n        };\n        return this.tile_data[tile.key];\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.key];\n        this.tile_data[tile.key] = null;\n\n        if (tile_data && tile_data.vertex_data && tile_data.vertex_data.vertex_count > 0) {\n            // Only keep final byte buffer\n            tile_data.vertex_data.end();\n            tile_data.vertex_data = tile_data.vertex_data.buffer;\n\n            // Load raster tiles passed from data source\n            // Blocks mesh completion to avoid flickering\n            return this.buildRasterTextures(tile, tile_data).then(() => tile_data);\n        }\n        else {\n            return Promise.resolve(null); // don't send tile data back if doesn't have geometry\n        }\n    },\n\n    // Has mesh data for a given tile?\n    hasDataForTile (tile_key) {\n        return this.tile_data[tile_key] != 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);\n        }\n\n        let style = this.parseFeature.apply(this, arguments); // allow subclasses to pass extra args\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            rule_style = this.preprocess(rule_style);\n            if (!rule_style) {\n                return;\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                selectable = StyleParser.evalProp(style.interactive, context);\n            }\n\n            // If feature is marked as selectable\n            if (selectable) {\n                style.selection_color = FeatureSelection.makeColor(feature, context.tile, context);\n            }\n            else {\n                style.selection_color = FeatureSelection.defaultColor;\n            }\n\n            // Subclass implementation\n            style = this._parseFeature.apply(this, arguments); // allow subclasses to pass extra args\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        return this.feature_style;\n    },\n\n    preprocess (rule_style) {\n        // Preprocess first time\n        if (!rule_style.preprocessed) {\n            rule_style = this._preprocess(rule_style); // optional subclass implementation\n            if (!rule_style) {\n                return;\n            }\n            rule_style.preprocessed = true;\n        }\n        return rule_style;\n    },\n\n    // optionally implemented by subclass\n    _preprocess (rule_style) {\n        return rule_style;\n    },\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    // Expand final precision for half-layers (for outlines)\n    scaleOrder (order) {\n        return order * 2;\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        this.max_texture_size = Texture.getMaxTextureSize(this.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 = Object.assign({}, 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    // Determines if 'raster' parameter is set to a valid value\n    hasRasters () {\n        return (['color', 'normal', 'custom'].indexOf(this.raster) > -1);\n    },\n\n    // Setup raster access in shaders\n    setupRasters () {\n        if (!this.hasRasters()) {\n            return;\n        }\n\n        // Enable raster textures and configure how first raster is applied\n        if (this.raster === 'color') {\n            this.defines.TANGRAM_RASTER_TEXTURE_COLOR = true;\n        }\n        else if (this.raster === 'normal') {\n            this.defines.TANGRAM_RASTER_TEXTURE_NORMAL = true;\n        }\n        // else custom raster (samplers will be made available but not automatically applied)\n\n        // A given style may be built with multiple data sources, each of which may attach\n        // a variable number of raster sources (0 to N, where N is the max number of raster sources\n        // defined for the scene). This means we don't know *which* or *how many* rasters will be\n        // bound now, at initial compile-time; we only know this at geometry build-time. To ensure\n        // that we can bind as many raster sources as needed, we declare our uniform arrays to hold\n        // the maximum number of possible sources. At render time, only the necessary number of rasters\n        // are bound (the remaining slots aren't intended to be accessed).\n        let num_raster_sources =\n            Object.keys(this.sources)\n            .filter(s => this.sources[s] instanceof RasterTileSource)\n            .length;\n\n        this.defines.TANGRAM_NUM_RASTER_SOURCES = `int(${num_raster_sources})`;\n        if (num_raster_sources > 0) {\n            // Use model position of tile's coordinate zoom for raster tile texture UVs\n            this.defines.TANGRAM_MODEL_POSITION_BASE_ZOOM_VARYING = true;\n\n            // Uniforms and macros for raster samplers\n            this.replaceShaderBlock('raster', shaderSources['gl/shaders/rasters'], 'Raster');\n        }\n    },\n\n    // Load raster tile textures and set uniforms\n    buildRasterTextures (tile, tile_data) {\n        if (!this.hasRasters()) {\n            return Promise.resolve(tile_data);\n        }\n\n        let configs = {}; // texture configs to pass to texture builder, keyed by texture name\n        let index = {};   // index into raster sampler array, keyed by texture name\n\n        // TODO: data source could retrieve raster texture URLs\n        tile.rasters.map(r => this.sources[r]).filter(x => x).forEach((source, i) => {\n            if (source instanceof RasterTileSource) {\n                let config = source.tileTexture(tile);\n                configs[config.url] = config;\n                index[config.url] = i;\n            }\n        });\n\n        if (Object.keys(configs).length === 0) {\n            return Promise.resolve(tile_data);\n        }\n\n        // Load textures on main thread and return when done\n        // We want to block the building of a raster tile mesh until its texture is loaded,\n        // to avoid flickering while loading (texture will render as black)\n        return WorkerBroker.postMessage(this.main_thread_target+'.loadTextures', configs)\n            .then(textures => {\n                if (!textures || textures.length < 1) {\n                    // TODO: warning\n                    return tile_data;\n                }\n\n                // Set texture uniforms (returned after loading from main thread)\n                tile_data.uniforms = tile_data.uniforms || {};\n                tile_data.textures = tile_data.textures || [];\n\n                let u_samplers = tile_data.uniforms['u_rasters'] = [];\n                let u_sizes = tile_data.uniforms['u_raster_sizes'] = [];\n                let u_offsets = tile_data.uniforms['u_raster_offsets'] = [];\n\n                for (let [tname, twidth, theight] of textures) {\n                    let i = index[tname];\n                    let raster_coords = configs[tname].coords; // tile coords of raster tile\n\n                    u_samplers[i] = tname;\n                    tile_data.textures.push(tname);\n\n                    u_sizes[i] = [twidth, theight];\n\n                    // Tile geometry may be at a higher zoom than the raster tile texture,\n                    // (e.g. an overzoomed raster tile), in which case we need to adjust the\n                    // raster texture UVs to offset to the appropriate starting point for\n                    // this geometry tile.\n                    if (tile.coords.z > raster_coords.z) {\n                        let dz = tile.coords.z - raster_coords.z; // # of levels raster source is overzoomed\n                        let dz2 = Math.pow(2, dz);\n                        u_offsets[i] = [\n                            (tile.coords.x % dz2) / dz2,\n                            (dz2 - 1 - (tile.coords.y % dz2)) / dz2, // GL texture coords are +Y up\n                            1 / dz2\n                        ];\n                    }\n                    else {\n                        u_offsets[i] = [0, 0, 1];\n                    }\n                }\n\n                return tile_data;\n            }\n        );\n    },\n\n    // Called on main thread\n    loadTextures (textures) {\n        // NB: only return name and size of textures loaded, because we can't send actual texture objects to worker\n        return Texture.createFromObject(this.gl, textures)\n            .then(() => {\n                return Promise.all(Object.keys(textures).map(t => {\n                    return Texture.textures[t] && Texture.textures[t].load();\n                }).filter(x => x));\n            })\n            .then(textures => {\n                textures.forEach(t => t.retain());\n                return textures.map(t => [t.name, t.width, t.height]);\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    // Render state settings by blend mode\n    render_states: {\n        opaque: { depth_test: true, depth_write: true },\n        add: { depth_test: true, depth_write: false },\n        multiply: { depth_test: true, depth_write: false },\n        inlay: { depth_test: true, depth_write: false },\n        overlay: { depth_test: false, depth_write: false }\n    },\n\n    // Default sort order for blend modes\n    default_blend_orders: {\n        opaque: 0,\n        add: 1,\n        multiply: 2,\n        inlay: 3,\n        overlay: 4\n    },\n\n    // Comparison function for sorting styles by blend\n    blendOrderSort (a, b) {\n        // opaque always comes first\n        if (a.blend === 'opaque' || b.blend === 'opaque') {\n            if (a.blend === 'opaque' && b.blend === 'opaque') { // if both are opaque\n                return a.name < b.name ? -1 : 1; // use name as tie breaker\n            }\n            else if (a.blend === 'opaque') {\n                return -1; // only `a` was opaque\n            }\n            else {\n                return 1; // only `b` was opaque\n            }\n        }\n\n        // use explicit blend order if possible\n        if (a.blend_order < b.blend_order) {\n            return -1;\n        }\n        else if (a.blend_order > b.blend_order) {\n            return 1;\n        }\n\n        // if blend orders are equal, use default order by blend mode\n        if (Style.default_blend_orders[a.blend] < Style.default_blend_orders[b.blend]) {\n            return -1;\n        }\n        else if (Style.default_blend_orders[a.blend] > Style.default_blend_orders[b.blend]) {\n            return 1;\n        }\n\n        return a.name < b.name ? -1 : 1; // use name as tie breaker\n    },\n\n    update () {\n        // Style-specific animation\n        // if (typeof this.animation === 'function') {\n        //     this.animation();\n        // }\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 '../utils/merge';\nimport Geo from '../geo';\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    ShaderProgram.removeBlock('global');\n    ShaderProgram.removeBlock('setup');\n\n    // Unpacking functions (for normalized vertex attributes)\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/unpack']);\n\n    // Model and world position accessors\n    ShaderProgram.addBlock('global', shaderSources['gl/shaders/accessors']);\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    // Feature selection vertex shader support\n    ShaderProgram.replaceBlock('setup', shaderSources['gl/shaders/selection_vertex']);\n\n    // Minimum value for float comparisons\n    ShaderProgram.defines.TANGRAM_EPSILON = 0.00001;\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    // Internal tile scale\n    ShaderProgram.defines.TANGRAM_TILE_SCALE = `vec3(${Geo.tile_scale}., ${Geo.tile_scale}., u_meters_per_pixel * ${Geo.tile_size}.)`;\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\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    style.mixed = {};\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 && x !== style); // TODO: warning on trying to mix into self\n\n        // Track which styles were mixed into this one\n        for (let s of sources) {\n            style.mixed[s.name] = true;\n        }\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    style.raster = sources.map(x => x.raster).filter(x => x != null).pop();\n    if (sources.some(x => x.hasOwnProperty('blend') && x.blend)) {\n        // only mix blend if explicitly set, otherwise let base style choose blending mode\n        // hasOwnProperty check gives preference to base style prototype\n        style.blend = sources.map(x => x.hasOwnProperty('blend') && x.blend).filter(x => x).pop();\n    }\n    style.blend_order = sources.map(x => x.blend_order).filter(x => x != null).pop();\n\n    // Merges - property-specific rules for merging values\n    style.defines = Object.assign({}, ...sources.map(x => x.defines).filter(x => x)); // internal defines (not user-defined)\n    style.material = Object.assign({}, ...sources.map(x => x.material).filter(x => x));\n\n    // Mix shader properties\n    StyleManager.mixShaders(style, styles, sources);\n    return style;\n};\n\n// Mix the propertes in the \"shaders\" block\nStyleManager.mixShaders = function (style, styles, sources) {\n    let shaders = {}; // newly mixed shaders properties\n    let shader_merges = sources.map(x => x.shaders).filter(x => x); // just the source styles with shader properties\n\n    // Defines\n    shaders.defines = Object.assign({}, ...shader_merges.map(x => x.defines).filter(x => x));\n\n    // Uniforms\n    shaders.uniforms = {};  // uniforms for this style, both explicitly defined, and mixed from other styles\n    shaders._uniforms = (style.shaders && style.shaders.uniforms) || {}; // uniforms explicitly defined by *this* style\n    shaders._uniform_scopes = {}; // tracks which style each uniform originated from (this one, or ancestor)\n\n    // Mix in uniforms from ancestors, providing means to access\n    sources\n        .filter(x => x.shaders && x.shaders.uniforms)\n        .forEach(x => {\n            for (let u in x.shaders.uniforms) {\n                shaders._uniform_scopes[u] = x.name;\n\n                // Define getter and setter for this uniform\n                // Getter returns value for this style if present, otherwise asks appropriate ancestor for it\n                // Setter sets the value for this style (whether previously present in this style or not)\n                // Mimics JS prototype/hasOwnProperty behavior, but with multiple ancestors (via mixins)\n                Object.defineProperty(shaders.uniforms, u, {\n                    enumerable: true,\n                    configurable: true,\n                    get: function () {\n                        // Uniform is explicitly defined on this style\n                        if (shaders._uniforms[u] !== undefined) {\n                            return shaders._uniforms[u];\n                        }\n                        // Uniform was mixed from another style, forward request there\n                        // Identify check is needed to prevent infinite recursion if a previously defined uniform\n                        // is set to undefined\n                        else if (styles[shaders._uniform_scopes[u]].shaders.uniforms !== shaders.uniforms) {\n                            return styles[shaders._uniform_scopes[u]].shaders.uniforms[u];\n                        }\n                    },\n                    set: function (v) {\n                        shaders._uniforms[u] = v;\n                    }\n                });\n            }\n        });\n\n    // Extensions: build a list of unique extensions\n    shaders.extensions = Object.keys(shader_merges\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    // Shader blocks\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    let mixed = {}; // all scopes mixed so far\n    for (let source of shader_merges) {\n        if (!source.blocks) {\n            continue;\n        }\n\n        shaders.blocks = shaders.blocks || {};\n        shaders.block_scopes = shaders.block_scopes || {};\n        let mixed_source = {}; // scopes mixed for this source style\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            // standardize on arrays (block can be single or multi-value)\n            block = Array.isArray(block) ? block : [block];\n            block_scope = Array.isArray(block_scope) ? block_scope : [block_scope];\n\n            for (let b=0; b < block.length; b++) {\n                // Skip blocks we've already mixed in from the same scope\n                // Repeating scope indicates a diamond pattern where a style is being mixed multiple times\n                if (mixed[block_scope[b]]) {\n                    continue;\n                }\n                mixed_source[block_scope[b]] = true;\n\n                shaders.blocks[t].push(block[b]);\n                shaders.block_scopes[t].push(block_scope[b]);\n            }\n        }\n\n        // Add styles mixed in from this source - they could be multi-level ancestors,\n        // beyond the first-level \"parents\" defined in this style's `mix` list\n        Object.assign(mixed, mixed_source);\n    }\n\n    Object.assign(style.mixed, mixed); // add all newly mixed styles\n\n    style.shaders = shaders; // assign back to style\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\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_key) {\n    let styles = [];\n    for (let s in Styles) {\n        if (Styles[s].hasDataForTile(tile_key)) {\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';\n\nexport var StyleParser = {};\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// - global: user-defined properties on the `global` object in the scene file\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\nStyleParser.wrapFunction = function (func) {\n    var f = `function(context) {\n                var feature = context.feature.properties;\n                var global = context.global;\n                var $zoom = context.zoom;\n                var $layer = context.layer;\n                var $geometry = context.geometry;\n                var $meters_per_pixel = context.meters_per_pixel;\n\n                var val = (${func}());\n\n                if (typeof val === 'number' && isNaN(val)) {\n                    val = null; // convert NaNs to nulls\n                }\n\n                return val;\n            }`;\n    return f;\n};\n\n\n// Style parsing\n\nStyleParser.zeroPair = Object.freeze([0, 0]); // single allocation for zero values that won't be modified\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// Style macros\nStyleParser.macros = {\n    // pseudo-random color by geometry id\n    'Style.color.pseudoRandomColor': function() {\n        return [\n            0.7 * (parseInt(feature.id, 16) / 100 % 1),     // jshint ignore:line\n            0.7 * (parseInt(feature.id, 16) / 10000 % 1),   // jshint ignore:line\n            0.7 * (parseInt(feature.id, 16) / 1000000 % 1), // jshint ignore:line\n            1\n        ];\n    },\n\n    // random color\n    'Style.color.randomColor': function() {\n        return [0.7 * Math.random(), 0.7 * Math.random(), 0.7 * Math.random(), 1];\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, global) {\n    return {\n        feature,\n        tile,\n        global,\n        zoom: tile.style_zoom,\n        geometry: Geo.geometryType(feature.geometry.type),\n        meters_per_pixel: tile.meters_per_pixel,\n        units_per_meter: tile.units_per_meter\n    };\n};\n\n// Build a style param cache object\n// `value` is raw value, cache methods will add other properties as needed\n// `transform` is optional transform function to run on values (except function values)\nStyleParser.cacheObject = function (obj, transform = null) {\n    if (obj == null) {\n        return;\n    }\n\n    if (obj.value) {\n        return { value: obj.value, zoom: (obj.zoom ? {} : null) }; // clone existing cache object\n    }\n\n    let c = { value: obj };\n\n    if (typeof transform === 'function') {\n        if (Array.isArray(c.value) && Array.isArray(c.value[0])) { // zoom stops\n            c.value = c.value.map(v => [v[0], transform(v[1])]);\n            c.zoom = {}; // will hold values interpolated by zoom\n        }\n        else if (typeof c.value !== 'function') { // don't transform functions\n            c.value = transform(c.value); // single value\n        }\n    }\n\n    return c;\n};\n\n// Convert old-style color macro into a function\n// TODO: deprecate this macro syntax\nStyleParser.colorCacheObject = function (obj) {\n    return StyleParser.cacheObject(obj, v => {\n        if (v === 'Style.color.pseudoRandomColor') {\n            return Utils.stringToFunction(StyleParser.wrapFunction(StyleParser.macros['Style.color.pseudoRandomColor']));\n        }\n        else if (v === 'Style.color.randomColor') {\n            return StyleParser.macros['Style.color.randomColor'];\n        }\n\n        return v;\n    });\n};\n\n// Interpolation and caching for a generic property (not a color or distance)\n// { value: original, static: val, zoom: { 1: val1, 2: val2, ... }, dynamic: function(){...} }\nStyleParser.cacheProperty = function(val, context) {\n    if (val == null) {\n        return;\n    }\n    else if (val.dynamic) { // function, compute each time (no caching)\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.static) { // single static value\n        return val.static;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) { // interpolated, cached\n        return val.zoom[context.zoom];\n    }\n    else { // not yet evaulated for cache\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 if (Array.isArray(val.value) && Array.isArray(val.value[0])) {\n            // Calculate value for current zoom\n            val.zoom = val.zoom || {};\n            val.zoom = {};\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value);\n            return val.zoom[context.zoom];\n        }\n        // Single static value\n        else {\n            val.static = val.value;\n            return val.static;\n        }\n    }\n};\n\nStyleParser.convertUnits = function(val, context) {\n    // pre-parsed units\n    if (val.val != null) {\n        if (val.units === 'px') { // convert from pixels\n            return val.val * Geo.metersPerPixel(context.zoom);\n        }\n        return val.val;\n    }\n    // un-parsed unit string\n    else 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        if (units === 'px') { // convert from pixels\n            val *= Geo.metersPerPixel(context.zoom);\n        }\n    }\n    // multiple values or stops\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 => [v[0], StyleParser.convertUnits(v[1], context)]);\n        }\n        // Array of values\n        else {\n            return val.map(v => StyleParser.convertUnits(v, context));\n        }\n    }\n    return val;\n};\n\n// Pre-parse units from string values\nStyleParser.cacheUnits = function (val) {\n    var obj = { val: parseFloat(val) };\n    if (obj.val !== 0 && typeof val === 'string' && val.trim().slice(-2) === 'px') {\n        obj.units = 'px';\n    }\n    return obj;\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) {\n    if (val.dynamic) {\n        let v = val.dynamic(context);\n        return v;\n    }\n    else if (val.zoom && val.zoom[context.zoom]) {\n        return val.zoom[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 if (val.zoom) {\n            // Calculate value for current zoom\n            // Do final unit conversion as late as possible, when interpolation values have been determined\n            val.zoom[context.zoom] = Utils.interpolate(context.zoom, val.value,\n                v => StyleParser.convertUnits(v, context));\n\n            return val.zoom[context.zoom];\n        }\n        else {\n            return StyleParser.convertUnits(val.value, context);\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    }\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\n        if (typeof v === 'string') {\n            v = StyleParser.colorForString(v);\n        }\n\n        if (v && v[3] == null) {\n            v[3] = 1; // default alpha\n        }\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\n            if (typeof v === 'string') {\n                v = StyleParser.colorForString(v);\n            }\n\n            if (v && v[3] == null) {\n                v[3] = 1; // default alpha\n            }\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 (val.zoom) {\n            // Parse any string colors inside stops, the first time we encounter this property\n            if (!val.zoom_preprocessed) {\n                for (let i=0; i < val.value.length; i++) {\n                    let v = val.value[i];\n                    if (v && typeof v[1] === 'string') {\n                        v[1] = StyleParser.colorForString(v[1]);\n                    }\n                }\n                val.zoom_preprocessed = true;\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            if (val.static && val.static[3] == null) {\n                val.static[3] = 1; // default alpha\n            }\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 = StyleParser.colorForString(val);\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                v[1] = StyleParser.colorForString(v[1]);\n            }\n        }\n\n        if (context.zoom) {\n            val = Utils.interpolate(context.zoom, val);\n        }\n    }\n\n    // Defaults\n    if (val) {\n        // alpha\n        if (val[3] == null) {\n            val[3] = 1;\n        }\n    }\n    else {\n        val = [0, 0, 0, 1];\n    }\n\n    return val;\n};\n\nStyleParser.calculateOrder = function(order, context) {\n    // Computed order\n    if (typeof order === 'function') {\n        order = order(context);\n    }\n    else if (typeof order === 'string') {\n        // Order tied to feature property\n        if (context.feature.properties[order]) {\n            order = context.feature.properties[order];\n        }\n        // Explicit order value\n        else {\n            order = parseFloat(order);\n        }\n    }\n\n    return order;\n};\n\n// Evaluate a function-based property, or pass-through static value\nStyleParser.evalProp = function(prop, context) {\n    if (typeof prop === 'function') {\n        return prop(context);\n    }\n    return prop;\n};\n\n// Substitutes global scene properties (those defined in the `config.global` object) for any style values\n// of the form `global.`, for example `color: global.park_color` would be replaced with the value (if any)\n// defined for the `park_color` property in `config.global.park_color`.\nStyleParser.applyGlobalProperties = function (config) {\n    if (!config.global || Object.keys(config.global).length === 0) {\n        return config; // no global properties to transform\n    }\n\n    const separator = ':';\n    const props = flattenProperties(config.global, separator);\n\n    function applyProps (obj) {\n        // Convert string\n        if (typeof obj === 'string') {\n            let key = (obj.slice(0, 7) === 'global.') && (obj.slice(7).replace(/\\./g, separator));\n            if (key && props[key]) {\n                obj = props[key];\n            }\n        }\n        // Loop through object properties\n        else if (typeof obj === 'object') {\n            for (let p in obj) {\n                obj[p] = applyProps(obj[p]);\n            }\n        }\n        return obj;\n    }\n\n    return applyProps(config);\n};\n\n// Flatten nested properties for simpler string look-ups\n// e.g. global.background.color -> 'global:background:color'\nfunction flattenProperties (obj, separator = ':', prefix = null, props = {}) {\n    prefix = prefix ? (prefix + separator) : '';\n\n    for (let p in obj) {\n        let key = prefix + p;\n        let val = obj[p];\n        props[key] = val;\n\n        if (typeof val === 'object' && !Array.isArray(val)) {\n            flattenProperties(val, separator, key, props);\n        }\n    }\n    return props;\n}\n","import Utils from '../../utils/utils';\nimport Texture from '../../gl/texture';\n\nexport default class CanvasText {\n\n    constructor () {\n        this.canvas = document.createElement('canvas');\n        this.canvas.style.backgroundColor = 'transparent'; // render text on transparent background\n        this.context = this.canvas.getContext('2d');\n    }\n\n    resize (width, height) {\n        this.canvas.width = width;\n        this.canvas.height = height;\n        this.context.clearRect(0, 0, width, height);\n    }\n\n    // Set font style params for canvas drawing\n    setFont ({ font_css, fill, stroke, stroke_width, px_size }) {\n        this.px_size = px_size;\n        this.text_buffer = 8; // pixel padding around text\n        let ctx = this.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    textSizes (texts) {\n        for (let style in texts) {\n            let text_infos = texts[style];\n\n            for (let text in text_infos) {\n                let text_settings = text_infos[text].text_settings;\n                // update text sizes\n                this.setFont(text_settings); // TODO: only set once above\n                Object.assign(\n                    text_infos[text],\n                    this.textSize(\n                        text,\n                        text_settings.transform,\n                        text_settings.text_wrap\n                    )\n                );\n            }\n        }\n\n        return texts;\n    }\n\n    // Computes width and height of text based on current font style\n    // Includes word wrapping, returns size info for whole text block and individual lines\n    textSize (text, transform, text_wrap) {\n        let str = this.applyTextTransform(text, transform);\n        let ctx = this.context;\n        let buffer = this.text_buffer * Utils.device_pixel_ratio;\n        let leading = 2 * Utils.device_pixel_ratio; // make configurable and/or use Canvas TextMetrics when available\n        let line_height = this.px_size + leading; // px_size already in device pixels\n\n        // Word wrapping\n        // Line breaks can be caused by:\n        //  - implicit line break when a maximum character threshold is exceeded per line (text_wrap)\n        //  - explicit line break in the label text (\\n)\n        let words;\n        if (typeof text_wrap === 'number') {\n            words = str.split(' '); // split words on spaces\n        }\n        else {\n            words = [str]; // no max line word wrapping (but new lines will still be in effect)\n        }\n        let new_line_template = { width: 0, chars: 0, text: '' };\n        let line = Object.assign({}, new_line_template); // current line\n        let lines = []; // completed lines\n        let max_width = 0; // max width to fit all lines\n\n        // add current line buffer to completed lines, optionally start new line\n        function addLine (new_line) {\n            line.text = line.text.trim();\n            if (line.text.length > 0) {\n                line.width = ctx.measureText(line.text).width;\n                max_width = Math.max(max_width, Math.ceil(line.width));\n                lines.push(line);\n            }\n            if (new_line) {\n                line = Object.assign({}, new_line_template);\n            }\n        }\n\n        // First iterate on space-break groups (will be one if max line length off), then iterate on line-break groups\n        for (let w=0; w < words.length; w++) {\n            let breaks = words[w].split('\\n'); // split on line breaks\n\n            for (let n=0; n < breaks.length; n++) {\n                let word = breaks[n];\n\n                // if adding current word would overflow, add a new line instead\n                if (line.chars + word.length > text_wrap && line.chars > 0) {\n                    addLine(true);\n                }\n\n                // add current word (plus space)\n                line.chars += word.length + 1;\n                line.text += word + ' ';\n\n                // if line breaks present, add new line (unless on last line)\n                if (breaks.length > 1 && n < breaks.length - 1) {\n                    addLine(true);\n                }\n            }\n        }\n        addLine(false);\n\n        // Final dimensions of text\n        let height = lines.length * line_height;\n\n        let collision_size = [\n            max_width / Utils.device_pixel_ratio,\n            height / Utils.device_pixel_ratio\n        ];\n\n        let texture_size = [\n            max_width + buffer * 2,\n            height + buffer * 2\n        ];\n\n        let logical_size = texture_size.map(v => v / Utils.device_pixel_ratio);\n\n        // Returns lines (w/per-line info for drawing) and text's overall bounding box + canvas size\n        return {\n            lines,\n            size: { collision_size, texture_size, logical_size, line_height }\n        };\n    }\n\n    // Draw one or more lines of text at specified location, adjusting for buffer and baseline\n    drawText (lines, [x, y], size, { stroke, transform, align }) {\n        align = align || 'center';\n\n        for (let line_num=0; line_num < lines.length; line_num++) {\n            let line = lines[line_num];\n            let str = this.applyTextTransform(line.text, transform);\n            let buffer = this.text_buffer * Utils.device_pixel_ratio;\n            let texture_size = size.texture_size;\n            let line_height = size.line_height;\n\n            // Text alignment\n            let tx;\n            if (align === 'left') {\n                tx = x + buffer;\n            }\n            else if (align === 'center') {\n                tx = x + texture_size[0]/2 - line.width/2;\n            }\n            else if (align === 'right') {\n                tx = x + texture_size[0] - line.width - buffer;\n            }\n\n            // In the absence of better Canvas TextMetrics (not supported by browsers yet),\n            // 0.75 buffer produces a better approximate vertical centering of text\n            let ty = y + buffer * 0.75 + (line_num + 1) * line_height;\n\n            if (stroke) {\n                this.context.strokeText(str, tx, ty);\n            }\n            this.context.fillText(str, tx, ty);\n        }\n    }\n\n    rasterize (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(info.text_settings); // TODO: only set once above\n                this.drawText(info.lines, info.position, info.size, {\n                    stroke: info.text_settings.stroke,\n                    transform: info.text_settings.transform,\n                    align: info.text_settings.align\n                });\n\n                info.texcoords = Texture.getTexcoordsForSprite(\n                    info.position,\n                    info.size.texture_size,\n                    texture_size\n                );\n            }\n        }\n    }\n\n    // Place text labels within an atlas of the given max size\n    setTextureTextPositions (texts, max_texture_size) {\n        // Find widest label\n        let widest = 0;\n        for (let style in texts) {\n            let text_infos = texts[style];\n            for (let text in text_infos) {\n                let size = text_infos[text].size.texture_size;\n                if (size[0] > widest) {\n                    widest = size[0];\n                }\n            }\n        }\n\n        // Layout labels, stacked in columns\n        let cx = 0, cy = 0; // current x/y position in atlas\n        let height = 0;     // overall atlas height\n        for (let style in texts) {\n            let text_infos = texts[style];\n            for (let text in text_infos) {\n                let text_info = text_infos[text];\n                let size = text_info.size.texture_size;\n                if (cy + size[1] < max_texture_size) {\n                    text_info.position = [cx, cy]; // add label to current column\n                    cy += size[1];\n                    if (cy > height) {\n                        height = cy;\n                    }\n                }\n                else { // start new column if taller than texture\n                    cx += widest;\n                    cy = 0;\n                    text_info.position = [cx, cy];\n                }\n            }\n        }\n\n        return [cx + widest, height]; // overall atlas size\n    }\n\n    // Called before rasterization\n    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    // Convert font CSS-style size ('12px', '14pt', '1.5em', etc.) to pixel size (adjusted for device pixel ratio)\n    // Defaults units to pixels if not specified\n    static fontPixelSize (size) {\n        if (size == null) {\n            return;\n        }\n        size = (typeof size === 'string') ? size : String(size); // need a string for regex\n\n        let [, px_size, units] = size.match(CanvasText.font_size_re) || [];\n        units = units || 'px';\n\n        if (units === \"em\") {\n            px_size *= 16;\n        } else if (units === \"pt\") {\n            px_size /= 0.75;\n        } else if (units === \"%\") {\n            px_size /= 6.25;\n        }\n\n        px_size = parseFloat(px_size);\n        px_size *= Utils.device_pixel_ratio;\n        return px_size;\n    }\n\n}\n\n// Extract font size and units\nCanvasText.font_size_re = /((?:[0-9]*\\.)?[0-9]+)\\s*(px|pt|em|%)?/;\n","// Text rendering style\n\nimport Texture from '../../gl/texture';\nimport WorkerBroker from '../../utils/worker_broker';\nimport Utils from '../../utils/utils';\nimport Geo from '../../geo';\nimport {Style} from '../style';\nimport {Points} from '../points/points';\nimport CanvasText from './canvas_text';\nimport Collision from '../../labels/collision';\nimport LabelPoint from '../../labels/label_point';\nimport LabelLine from '../../labels/label_line';\nimport TextSettings from './text_settings';\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        this.super.init.apply(this, arguments);\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        this.defines.TANGRAM_UNMULTIPLY_ALPHA = true;\n\n        // Fade out text when tile is zooming out, e.g. acting as proxy tiles\n        this.defines.TANGRAM_FADE_ON_ZOOM_OUT = true;\n        this.defines.TANGRAM_FADE_ON_ZOOM_OUT_RATE = 2; // fade at 2x, e.g. fully transparent at 0.5 zoom level away\n\n        this.reset();\n    },\n\n    reset() {\n        this.super.reset.call(this);\n        if (Utils.isMainThread) {\n            this.canvas = new CanvasText();\n        }\n        else if (Utils.isWorkerThread) {\n            this.texts = {}; // unique texts, grouped by tile, by style\n        }\n    },\n\n    // Called on worker thread to release tile-specific resources\n    freeTile (tile) {\n        delete this.texts[tile.key];\n    },\n\n    // Free tile-specific resources before finshing style construction\n    finishTile(tile) {\n        this.freeTile(tile);\n        return Style.endData.call(this, tile);\n    },\n\n    // Override to queue features instead of processing immediately\n    addFeature (feature, draw, context) {\n        let tile = context.tile;\n        if (tile.generation !== this.generation) {\n            return;\n        }\n\n        // Called here because otherwise it will be delayed until the feature queue is parsed,\n        // and we want the preprocessing done before we evaluate text style below\n        draw = this.preprocess(draw);\n        if (!draw) {\n            return;\n        }\n\n        // Compute label text\n        let text = this.parseTextSource(feature, draw, context);\n        if (text == null) {\n            return; // no text for this feature\n        }\n\n        // Compute text style and layout settings for this feature label\n        let layout = this.computeLayout({}, feature, draw, context, tile, text);\n        let text_settings = TextSettings.compute(feature, draw, context);\n        let text_settings_key = TextSettings.key(text_settings);\n\n        // first label in tile, or with this style?\n        this.texts[tile.key] = this.texts[tile.key] || {};\n        this.texts[tile.key][text_settings_key] = this.texts[tile.key][text_settings_key] || {};\n\n        // unique text strings, grouped by text drawing style\n        if (!this.texts[tile.key][text_settings_key][text]) {\n            // first label with this text/style/tile combination, make a new label entry\n            this.texts[tile.key][text_settings_key][text] = {\n                text_settings,\n                ref: 0 // # of times this text/style combo appears in tile\n            };\n        }\n\n        // Queue the feature for processing\n        if (!this.tile_data[tile.key]) {\n            this.startData(tile);\n        }\n\n        if (!this.queues[tile.key]) {\n            this.queues[tile.key] = [];\n        }\n\n        this.queues[tile.key].push({\n            feature, draw, context,\n            text, text_settings_key, layout\n        });\n\n        // Register with collision manager\n        Collision.addStyle(this.name, tile.key);\n    },\n\n    // Override\n    endData (tile) {\n        let queue = this.queues[tile.key];\n        this.queues[tile.key] = [];\n\n        if (Object.keys(this.texts[tile.key]||{}).length === 0) {\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+'.calcTextSizes', this.texts[tile.key]).then(texts => {\n            if (tile.canceled) {\n                Utils.log('trace', `Style ${this.name}: stop tile build because tile was canceled: ${tile.key}, post-calcTextSizes()`);\n                return;\n            }\n\n            if (!texts) {\n                Collision.collide({}, this.name, tile.key);\n                return this.finishTile(tile);\n            }\n            this.texts[tile.key] = texts;\n\n            let labels = this.createLabels(tile.key, queue);\n\n            return Collision.collide(labels, this.name, tile.key).then(labels => {\n                if (tile.canceled) {\n                    Utils.log('trace', `stop tile build because tile was canceled: ${tile.key}, post-collide()`);\n                    return;\n                }\n\n                if (labels.length === 0) {\n                    return this.finishTile(tile); // no labels visible for this tile\n                }\n\n                this.cullTextStyles(texts, labels);\n\n                // second call to main thread, for rasterizing the set of texts\n                return WorkerBroker.postMessage(this.main_thread_target+'.rasterizeTexts', tile.key, texts).then(({ texts, texture }) => {\n                    if (texts) {\n                        this.texts[tile.key] = texts;\n\n                        // Build queued features\n                        labels.forEach(q => {\n                            let text_settings_key = q.text_settings_key;\n                            let text_info = this.texts[tile.key] && this.texts[tile.key][text_settings_key] && this.texts[tile.key][text_settings_key][q.text];\n\n                            // setup styling object expected by Style class\n                            let style = this.feature_style;\n                            style.label = q.label;\n                            style.size = text_info.size.logical_size;\n                            style.angle = Utils.radToDeg(q.label.angle) || 0;\n                            style.texcoords = text_info.texcoords;\n\n                            Style.addFeature.call(this, q.feature, q.draw, q.context);\n                        });\n                    }\n\n                    return this.finishTile(tile).then(tile_data => {\n                        // Attach tile-specific label atlas to mesh as a texture uniform\n                        if (texture && tile_data) {\n                            tile_data.uniforms.u_texture = texture;\n                            tile_data.textures.push(texture); // assign texture ownership to tile\n                            return tile_data;\n                        }\n                    });\n                });\n            });\n        });\n    },\n\n    createLabels (tile_key, feature_queue) {\n        let labels = [];\n\n        for (let f=0; f < feature_queue.length; f++) {\n            let { feature, draw, context, text, text_settings_key, layout } = feature_queue[f];\n            let text_info = this.texts[tile_key][text_settings_key][text];\n\n            let feature_labels = this.buildLabelsFromGeometry(text_info.size.collision_size, feature.geometry, layout);\n            for (let i = 0; i < feature_labels.length; i++) {\n                let label = feature_labels[i];\n                labels.push({\n                    feature, draw, context,\n                    text, text_settings_key, layout, label\n                });\n            }\n        }\n\n        return labels;\n    },\n\n    // Remove unused text/style combinations to avoid unnecessary rasterization\n    cullTextStyles(texts, labels) {\n        // Count how many times each text/style combination is used\n        for (let i=0; i < labels.length; i++) {\n            texts[labels[i].text_settings_key][labels[i].text].ref++;\n        }\n\n        // Remove text/style combinations that have no visible labels\n        for (let style in texts) {\n            for (let text in texts[style]) {\n                // no labels for this text\n                if (texts[style][text].ref < 1) {\n                    // console.log(`drop label text ${text} in style ${style}`);\n                    delete texts[style][text];\n                }\n            }\n        }\n\n        for (let style in texts) {\n            // no labels for this style\n            if (Object.keys(texts[style]).length === 0) {\n                // console.log(`drop label text style ${style}`);\n                delete texts[style];\n            }\n        }\n    },\n\n    // Called on main thread from worker, to compute the size of each text string,\n    // were it to be rendered. This info is then used to perform initial label culling, *before*\n    // labels are actually rendered.\n    calcTextSizes (texts) {\n        return this.canvas.textSizes(texts);\n    },\n\n    // Called on main thread from worker, to create atlas of labels for a tile\n    rasterizeTexts (tile_key, texts) {\n        let canvas = new CanvasText();\n        let texture_size = canvas.setTextureTextPositions(texts, this.max_texture_size);\n        log.trace(`text summary for tile ${tile_key}: fits in ${texture_size[0]}x${texture_size[1]}px`);\n\n        // fits in max texture size?\n        if (texture_size[0] < this.max_texture_size && texture_size[1] < this.max_texture_size) {\n            // update canvas size & rasterize all the text strings we need\n            canvas.resize(...texture_size);\n            canvas.rasterize(texts, texture_size);\n        }\n        else {\n            log.error([\n                `Label atlas for tile ${tile_key} is ${texture_size[0]}x${texture_size[1]}px, `,\n                `but max GL texture size is ${this.max_texture_size}x${this.max_texture_size}px`].join(''));\n        }\n\n        // create a texture\n        let t = 'labels-' + tile_key + '-' + (TextStyle.texture_id++);\n        Texture.create(this.gl, t, {\n            element: canvas.canvas,\n            filtering: 'linear',\n            UNPACK_PREMULTIPLY_ALPHA_WEBGL: true\n        });\n        Texture.retain(t);\n\n        return { texts, texture: t }; // texture is returned by name (not instance)\n    },\n\n    // Sets up caching for draw rule properties\n    _preprocess (draw) {\n        if (!draw.font) {\n            return;\n        }\n\n        // Colors\n        draw.font.fill = StyleParser.cacheObject(draw.font.fill);\n        if (draw.font.stroke) {\n            draw.font.stroke.color = StyleParser.cacheObject(draw.font.stroke.color);\n        }\n\n        // Convert font and text stroke sizes\n        draw.font.px_size = StyleParser.cacheObject(draw.font.size, CanvasText.fontPixelSize);\n        if (draw.font.stroke && draw.font.stroke.width != null) {\n            draw.font.stroke.width = StyleParser.cacheObject(draw.font.stroke.width, parseFloat);\n        }\n\n        // Offset (2d array)\n        draw.offset = StyleParser.cacheObject(draw.offset, v => (Array.isArray(v) && v.map(parseFloat)) || 0);\n\n        // Buffer (1d value or or 2d array)\n        draw.buffer = StyleParser.cacheObject(draw.buffer, v => (Array.isArray(v) ? v : [v, v]).map(parseFloat) || 0);\n\n        // Repeat rules\n        draw.repeat_distance = StyleParser.cacheObject(draw.repeat_distance, parseFloat);\n\n        return draw;\n    },\n\n    // Compute the label text, default is value of feature.properties.name\n    // - String value indicates a feature property look-up, e.g. `short_name` means use feature.properties.short_name\n    // - Function will use the return value as the label text (for custom labels)\n    // - Array (of strings and/or functions) defines a list of fallbacks, evaluated according to the above rules,\n    //   with the first non-null value used as the label text\n    //   e.g. `[name:es, name:en, name]` prefers Spanish names, followed by English, and last the default local name\n    parseTextSource (feature, draw, context) {\n        let text;\n        let source = draw.text_source || 'name';\n\n        if (Array.isArray(source)) {\n            for (let s=0; s < source.length; s++) {\n                if (typeof source[s] === 'string') {\n                    text = feature.properties[source[s]];\n                } else if (typeof source[s] === 'function') {\n                    text = source[s](context);\n                }\n\n                if (text) {\n                    break; // stop if we found a text property\n                }\n            }\n        }\n        else if (typeof source === 'string') {\n            text = feature.properties[source];\n        } else if (typeof source === 'function') {\n            text = source(context);\n        }\n        return text;\n    },\n\n    // Additional text-specific layout settings\n    computeLayout (target, feature, draw, context, tile, text) {\n        let layout = target || {};\n\n        // common settings w/points\n        layout = Points.computeLayout(layout, feature, draw, context, tile);\n\n        // tile boundary handling\n        layout.cull_from_tile = (draw.cull_from_tile != null) ? draw.cull_from_tile : true;\n        layout.move_into_tile = (draw.move_into_tile != null) ? draw.move_into_tile : true;\n\n        // label line exceed percentage\n        if (draw.line_exceed && draw.line_exceed.substr(-1) === '%') {\n            layout.line_exceed = parseFloat(draw.line_exceed.substr(0,draw.line_exceed.length-1));\n        }\n        else {\n            layout.line_exceed = 80;\n        }\n\n        // repeat minimum distance\n        layout.repeat_distance = StyleParser.cacheProperty(draw.repeat_distance, context);\n        if (layout.repeat_distance == null) {\n            layout.repeat_distance = Geo.tile_size;\n        }\n        layout.repeat_distance *= layout.units_per_pixel;\n\n        // repeat group key\n        if (typeof draw.repeat_group === 'function') {\n            layout.repeat_group = draw.repeat_group(context);\n        }\n        else if (typeof draw.repeat_group === 'string') {\n            layout.repeat_group = draw.repeat_group;\n        }\n        else {\n            layout.repeat_group = draw.key; // default to unique set of matching layers\n        }\n        layout.repeat_group += '/' + text;\n\n        // Max number of subdivisions to try\n        layout.subdiv = tile.overzoom2;\n\n        return layout;\n    },\n\n    // Builds one or more labels for a geometry\n    buildLabelsFromGeometry (size, geometry, options) {\n        let labels = [];\n\n        if (geometry.type === \"LineString\") {\n            this.buildLineLabels(size, geometry.coordinates, options, labels);\n        } else if (geometry.type === \"MultiLineString\") {\n            let lines = geometry.coordinates;\n            for (let i = 0; i < lines.length; ++i) {\n                this.buildLineLabels(size, lines[i], options, labels);\n            }\n        } else if (geometry.type === \"Point\") {\n            labels.push(new LabelPoint(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                labels.push(new LabelPoint(points[i], size, options));\n            }\n        } else if (geometry.type === \"Polygon\") {\n            let centroid = Geo.centroid(geometry.coordinates[0]);\n            labels.push(new LabelPoint(centroid, size, options));\n        } else if (geometry.type === \"MultiPolygon\") {\n            let centroid = Geo.multiCentroid(geometry.coordinates);\n            labels.push(new LabelPoint(centroid, size, options));\n        }\n\n        return labels;\n    },\n\n    // Build one or more labels for a line geometry\n    buildLineLabels (size, line, options, labels) {\n        let subdiv = Math.min(options.subdiv, line.length - 1);\n        if (subdiv > 1) {\n            // Create multiple labels for line, with each allotted a range of segments\n            // in which it will attempt to place\n            let seg_per_div = (line.length - 1) / subdiv;\n            for (let i=0; i < subdiv; i++) {\n                options.segment_start = Math.floor(i * seg_per_div);\n                options.segment_end = Math.floor((i+1) * seg_per_div);\n                labels.push(new LabelLine(size, line, options));\n            }\n            options.segment_start = null;\n            options.segment_end = null;\n        }\n        else {\n            labels.push(new LabelLine(size, line, options));\n        }\n    }\n\n});\n\nTextStyle.texture_id = 0; // namespaces per-tile label textures\n","import Utils from '../../utils/utils';\nimport Geo from '../../geo';\nimport {StyleParser} from '../style_parser';\nimport PointAnchor from '../points/point_anchor';\n\nvar TextSettings;\n\nexport default TextSettings = {\n\n    // A key for grouping all labels of the same text style (e.g. same Canvas state, to minimize state changes)\n    key (settings) {\n        return [\n            settings.style,\n            settings.weight,\n            settings.family,\n            settings.px_size,\n            settings.fill,\n            settings.stroke,\n            settings.stroke_width,\n            settings.transform,\n            settings.text_wrap,\n            settings.align\n        ].join('/');\n    },\n\n    defaults: {\n        style: 'normal',\n        weight: null,\n        size: '12px',\n        px_size: 12,\n        family: 'Helvetica',\n        fill: 'white',\n        text_wrap: 15,\n        align: 'center'\n    },\n\n    compute (feature, draw, context) {\n        let style = {};\n\n        draw.font = draw.font || this.defaults;\n\n        // Use fill if specified, or default\n        style.fill = (draw.font.fill && Utils.toCSSColor(StyleParser.cacheColor(draw.font.fill, context))) || this.defaults.fill;\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 = draw.font.style || this.defaults.style;\n        style.weight = draw.font.weight || this.defaults.weight;\n        if (draw.font.family) {\n            style.family = draw.font.family;\n            if (style.family !== this.defaults.family) {\n                style.family += ', ' + this.defaults.family;\n            }\n        }\n        else {\n            style.family = this.defaults.family;\n        }\n\n        style.transform = draw.font.transform;\n\n        // original size (not currently used, but useful for debugging)\n        style.size = draw.font.size || this.defaults.size;\n\n        // calculated pixel size\n        style.px_size = StyleParser.cacheProperty(draw.font.px_size, context) || this.defaults.px_size;\n\n        // Use stroke if specified\n        if (draw.font.stroke && draw.font.stroke.color) {\n            style.stroke = Utils.toCSSColor(StyleParser.cacheColor(draw.font.stroke.color, context) || this.defaults.stroke);\n            style.stroke_width = StyleParser.cacheProperty(draw.font.stroke.width, context) || this.defaults.stroke_width;\n            style.stroke_width *= Utils.device_pixel_ratio;\n        }\n\n        style.font_css = this.fontCSS(style);\n\n        // Word wrap and text alignment\n        // Not a font properties, but affect atlas of unique text textures\n        let text_wrap = draw.text_wrap; // use explicitly set value\n        if (text_wrap == null && Geo.geometryType(feature.geometry.type) !== 'line') {\n            // point labels (for point and polygon features) have word wrap on w/default max length,\n            // line labels default off\n            text_wrap = true;\n        }\n\n        // setting to 'true' causes default wrap value to be used\n        if (text_wrap === true) {\n            text_wrap = this.defaults.text_wrap;\n        }\n        style.text_wrap = text_wrap;\n\n        // default alignment to match anchor\n        if (!draw.align && draw.anchor && draw.anchor !== 'center') {\n            if (PointAnchor.isLeftAnchor(draw.anchor)) {\n                draw.align = 'right';\n            }\n            else if (PointAnchor.isRightAnchor(draw.anchor)) {\n                draw.align = 'left';\n            }\n        }\n\n        style.align = draw.align || this.defaults.align;\n\n        return style;\n    },\n\n    // Build CSS-style font string (to set Canvas draw state)\n    fontCSS ({ style, weight, px_size, family }) {\n        return [style, weight, px_size + 'px', family]\n            .filter(x => x) // remove null props\n            .join(' ');\n    }\n\n};\n","import Geo from './geo';\nimport {StyleParser} from './styles/style_parser';\nimport {StyleManager} from './styles/style_manager';\nimport Collision from './labels/collision';\nimport WorkerBroker from './utils/worker_broker';\nimport Texture from './gl/texture';\n\nimport {mat4, vec3} from './utils/gl-matrix';\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, style_zoom, source, worker, view }) {\n        this.worker = worker;\n        this.view = view;\n        this.source = source;\n        this.generation = null;\n\n        this.visible = false;\n        this.proxy = null;\n        this.proxy_depth = 0;\n        this.loading = false;\n        this.loaded = false;\n        this.error = null;\n        this.debug = {};\n\n        this.coords = Tile.coordinateWithMaxZoom(coords, this.source.max_zoom);\n        this.style_zoom = style_zoom; // zoom level to be used for styling\n        this.overzoom = Math.max(this.style_zoom - this.coords.z, 0); // number of levels of overzooming\n        this.overzoom2 = Math.pow(2, this.overzoom);\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        this.center_dist = 0;\n\n        // Units per pixel needs to account for over-zooming\n        this.units_per_pixel = Geo.units_per_pixel / this.overzoom2;\n\n        this.meters_per_pixel = Geo.metersPerPixel(this.coords.z);\n        this.units_per_meter = Geo.unitsPerMeter(this.coords.z);\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 coord(c) {\n        return {x: c.x, y: c.y, z: c.z, key: Tile.coordKey(c)};\n    }\n\n    static coordKey({x, y, z}) {\n        return x + '/' + y + '/' + z;\n    }\n\n    static key (coords, source, style_zoom) {\n        coords = Tile.coordinateWithMaxZoom(coords, source.max_zoom);\n        if (coords.y < 0 || coords.y >= (1 << coords.z) || coords.z < 0) {\n            return; // cull tiles out of range (x will wrap)\n        }\n        return [source.name, style_zoom, coords.x, coords.y, coords.z].join('/');\n    }\n\n    static coordinateAtZoom({x, y, z, key}, 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            z = zoom;\n        }\n        return Tile.coord({x, y, z});\n    }\n\n    static coordinateWithMaxZoom({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 Tile.coord({x, y, z});\n    }\n\n    static childrenForCoordinate({x, y, z, key}) {\n        if (!Tile.coord_children[key]) {\n            z++;\n            x *= 2;\n            y *= 2;\n            Tile.coord_children[key] = [\n                Tile.coord({x, y,      z}), Tile.coord({x: x+1, y,      z}),\n                Tile.coord({x, y: y+1, z}), Tile.coord({x: x+1, y: y+1, z})\n            ];\n        }\n        return Tile.coord_children[key];\n    }\n\n    static isDescendant(parent, descendant) {\n        if (descendant.z > parent.z) {\n            let {x, y} = Tile.coordinateAtZoom(descendant, parent.z);\n            return (parent.x === x && parent.y === y);\n        }\n        return false;\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    // Free resources owned by tile\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                Texture.release(t);\n            }\n        }\n\n        this.meshes = {};\n        this.textures = [];\n    }\n\n    destroy() {\n        this.workerMessage('self.removeTile', this.key);\n        this.freeResources();\n        this.worker = null;\n    }\n\n    buildAsMessage() {\n        return {\n            key: this.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            meters_per_pixel: this.meters_per_pixel,\n            units_per_meter: this.units_per_meter,\n            style_zoom: this.style_zoom,\n            overzoom: this.overzoom,\n            overzoom2: this.overzoom2,\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('self.buildTile', { tile: this.buildAsMessage() }).catch(e => { throw e; });\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            tile.canceled = true;\n            if (tile.source_data && tile.source_data.request) {\n                tile.source_data.request.abort();\n            }\n            Tile.abortBuild(tile);\n        }\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, global }) {\n        tile.debug.rendering = +new Date();\n        tile.debug.features = 0;\n\n        let data = tile.source_data;\n\n        Collision.startTile(tile.key);\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 || !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\n            // Render features in layer\n            for (let s=0; s < source_layers.length; s++) {\n                let source_layer = source_layers[s];\n                let geom = source_layer.geom;\n                if (!geom) {\n                    continue;\n                }\n\n                for (let f = 0; f < geom.features.length; f++) {\n                    let feature = geom.features[f];\n                    if (feature.geometry == null) {\n                        continue; // skip features w/o geometry (valid GeoJSON)\n                    }\n\n                    let context = StyleParser.getFeatureParseContext(feature, tile, global);\n                    context.winding = tile.default_winding;\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.layers = group.layers;  // add matching draw layers\n\n                        style.addFeature(feature, group, context);\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 s=0; s < tile_styles.length; s++) {\n            let style_name = tile_styles[s];\n            let style = styles[style_name];\n            queue.push(style.endData(tile).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            Collision.resetTile(tile.key);\n\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        // Debug\n        this.debug.geometries = 0;\n        this.debug.buffer_size = 0;\n\n        // Create VBOs\n        let meshes = {}, textures = []; // new resources, to be swapped in\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                        break;\n                    }\n                    meshes[s] = styles[s].makeMesh(mesh_data[s].vertex_data, mesh_data[s]);\n                    this.debug.geometries += meshes[s].geometry_count;\n                }\n\n                // Assign texture ownership to tiles\n                // Note that it's valid for a single texture to be referenced from multiple styles\n                // (e.g. same raster texture attached to multiple sources). This means the same\n                // texture may be added to the tile's texture list more than once, which ensures\n                // that it is properly released (to match its retain count).\n                if (mesh_data[s].textures) {\n                    mesh_data[s].textures.forEach(t => {\n                        textures.push(t);\n                    });\n                }\n            }\n        }\n        delete this.mesh_data; // TODO: might want to preserve this for rebuilding geometries when styles/etc. change?\n\n        // Swap in new data, free old data\n        this.freeResources();\n        this.meshes = meshes;\n        this.textures = textures;\n\n        this.debug.geom_ratio = (this.debug.geometries / this.debug.features).toFixed(1);\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(`releasing texture ${t} for tile ${tile.key}`);\n                            texture.release();\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    // Update relative to view\n    update () {\n        let coords = this.coords;\n        if (coords.z !== this.view.center.tile.z) {\n            coords = Tile.coordinateAtZoom(coords, this.view.center.tile.z);\n        }\n        this.center_dist = Math.abs(this.view.center.tile.x - coords.x) + Math.abs(this.view.center.tile.y - coords.y);\n    }\n\n    // Set as a proxy tile for another tile\n    setProxyFor (tile) {\n        this.proxy = tile;\n        if (tile) {\n            this.visible = true;\n            this.proxy_depth = 1; // draw proxies a half-layer back (order is scaled 2x to avoid integer truncation)\n            this.update();\n        }\n        else {\n            this.proxy_depth = 0;\n        }\n    }\n\n    // Update model matrix and tile uniforms\n    setupProgram ({ model, model32 }, program) {\n        // Tile origin\n        program.uniform('4f', 'u_tile_origin', this.min.x, this.min.y, this.style_zoom, this.coords.z);\n        program.uniform('1f', 'u_tile_proxy_depth', this.proxy_depth);\n\n        // Model - transform tile space into world space (meters, absolute mercator position)\n        mat4.identity(model);\n        mat4.translate(model, model, vec3.fromValues(this.min.x, this.min.y, 0));\n        mat4.scale(model, model, vec3.fromValues(this.span.x / Geo.tile_scale, -1 * this.span.y / Geo.tile_scale, 1)); // scale tile local coords to meters\n        mat4.copy(model32, model);\n        program.uniform('Matrix4fv', 'u_model', false, model32);\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    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    printDebug () {\n        log.debug(`Tile: debug for ${this.key}: [  ${JSON.stringify(this.debug)} ]`);\n    }\n\n}\n\nTile.coord_children = {}; // only allocate children coordinates once per coordinate\n","import Tile from './tile';\nimport TilePyramid from './tile_pyramid';\n\nimport log from 'loglevel';\n\nconst TileManager = {\n\n    init({ scene, view }) {\n        this.scene = scene;\n        this.view = view;\n        this.tiles = {};\n        this.pyramid = TilePyramid;\n        this.pyramid.reset();\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.pyramid.reset();\n        this.visible_coords = {};\n        this.queued_coords = [];\n        this.scene = null;\n        this.view = null;\n    },\n\n    keepTile(tile) {\n        this.tiles[tile.key] = tile;\n        this.pyramid.addTile(tile);\n    },\n\n    hasTile(key) {\n        return this.tiles[key] !== undefined;\n    },\n\n    forgetTile(key) {\n        if (this.hasTile(key)) {\n            let tile = this.tiles[key];\n            this.pyramid.removeTile(tile);\n        }\n\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        let prev_coords = Object.keys(this.visible_coords);\n        this.visible_coords = {};\n        let tile_coords = this.view.findVisibleTileCoordinates();\n        for (let coords of tile_coords) {\n            this.queueCoordinate(coords);\n            this.visible_coords[coords.key] = coords;\n        }\n\n        // Check if visible coords changed\n        // TODO: move to a new view manager object\n        let new_coords = Object.keys(this.visible_coords);\n        let coords_changed = false;\n        if (prev_coords.length !== new_coords.length) {\n            coords_changed = true;\n        }\n        else {\n            prev_coords.sort();\n            new_coords.sort();\n            if (!prev_coords.every((c, i) => new_coords[i] === c)) {\n                coords_changed = true;\n            }\n        }\n\n        this.updateTileStates();\n    },\n\n    updateTileStates () {\n        this.forEachTile(tile => {\n            this.updateVisibility(tile);\n            tile.update();\n        });\n\n        this.loadQueuedCoordinates();\n        this.updateProxyTiles();\n        this.view.pruneTilesForView();\n    },\n\n    updateProxyTiles () {\n        if (this.view.zoom_direction === 0) {\n            return;\n        }\n\n        // Clear previous proxies\n        this.forEachTile(tile => tile.setProxyFor(null));\n\n        let proxy = false;\n        this.forEachTile(tile => {\n            if (this.view.zoom_direction === 1) {\n                if (tile.visible && tile.loading && tile.coords.z > 0) {\n                    let p = this.pyramid.getAncestor(tile);\n                    if (p) {\n                        p.setProxyFor(tile);\n                        proxy = true;\n                    }\n                }\n            }\n            else if (this.view.zoom_direction === -1) {\n                if (tile.visible && tile.loading) {\n                    let d = this.pyramid.getDescendants(tile);\n                    for (let t of d) {\n                        t.setProxyFor(tile);\n                        proxy = true;\n                    }\n                }\n            }\n        });\n\n        if (!proxy) {\n            this.view.zoom_direction = 0;\n        }\n    },\n\n    updateVisibility(tile) {\n        tile.visible = false;\n        if (tile.style_zoom === this.view.tile_zoom) {\n            if (this.visible_coords[tile.coords.key]) {\n                tile.visible = true;\n            }\n            else {\n                // brute force\n                for (let key in this.visible_coords) {\n                    if (Tile.isDescendant(tile.coords, this.visible_coords[key])) {\n                        tile.visible = true;\n                        break;\n                    }\n                }\n            }\n        }\n    },\n\n    // Remove tiles that aren't visible, and flag remaining visible ones to be updated (for loading, proxy, etc.)\n    pruneToVisibleTiles () {\n        this.removeTiles(tile => !tile.visible);\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    isLoadingVisibleTiles() {\n        return Object.keys(this.tiles).some(k => this.tiles[k].visible && this.tiles[k].loading);\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.view.center.tile.x - a.x) + Math.abs(this.view.center.tile.y - a.y);\n            let bd = Math.abs(this.view.center.tile.x - b.x) + Math.abs(this.view.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.view.center.tile.z) {\n            return;\n        }\n\n        // Determine necessary tiles for each source\n        for (let s in this.scene.sources) {\n            let source = this.scene.sources[s];\n            if (!source.tiled || !source.geometry_tiles) {\n                continue;\n            }\n\n            let key = Tile.key(coords, source, this.view.tile_zoom);\n            if (key && !this.hasTile(key)) {\n                let tile = Tile.create({\n                    source,\n                    coords,\n                    worker: this.scene.nextWorker(),\n                    style_zoom: this.view.styleZoom(coords.z),\n                    view: this.view\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();\n        tile.build(this.scene.generation)\n            .then(message => {\n                if (message) { // empty message means tile build was aborted\n                    this.buildTileCompleted(message);\n                }\n            })\n            .catch(e => {\n                log.error(`Error building tile ${tile.key}:`, e);\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.updateTileStates();\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.updateTileStates();\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            tile.buildMeshes(this.scene.styles);\n            this.updateTileStates();\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\nexport default TileManager;\n","import Geo from './geo';\nimport Tile from './tile';\n\nconst TilePyramid = {\n\n    coords: {},\n    max_proxy_descendant_depth: 3, // # of levels deep to search for descendant proxy tiles\n\n    reset() {\n        this.coords = {};\n    },\n\n    sourceTiles(coord, source) {\n        return (\n            this.coords[coord.key] &&\n            this.coords[coord.key].sources &&\n            this.coords[coord.key].sources.get(source.name));\n    },\n\n    addTile(tile) {\n        // Add target tile\n        let key = tile.coords.key;\n        let coord = this.coords[key];\n        if (!coord) {\n            coord = this.coords[key] = { descendants: 0 };\n        }\n\n        if (!coord.sources) {\n            coord.sources = new Map();\n        }\n\n        if (!coord.sources.get(tile.source.name)) {\n            coord.sources.set(tile.source.name, new Map());\n        }\n        coord.sources.get(tile.source.name).set(tile.style_zoom, tile);\n\n        // Increment reference count up the tile pyramid\n        for (let z = tile.coords.z - 1; z >= 0; z--) {\n            let up = Tile.coordinateAtZoom(tile.coords, z);\n            if (!this.coords[up.key]) {\n                this.coords[up.key] = { descendants: 0 };\n            }\n            this.coords[up.key].descendants++;\n        }\n    },\n\n    removeTile(tile) {\n        // Remove target tile\n        let source_tiles = this.sourceTiles(tile.coords, tile.source);\n        let key = tile.coords.key;\n\n        if (source_tiles) {\n            source_tiles.delete(tile.style_zoom);\n            if (source_tiles.size === 0) {\n                // remove source\n                this.coords[key].sources.delete(tile.source.name);\n                if (this.coords[key].sources.size === 0) {\n                    delete this.coords[key].sources;\n\n                    if (this.coords[key].descendants === 0) {\n                        // remove whole coord\n                        delete this.coords[key];\n                    }\n                }\n            }\n        }\n\n        // Decrement reference count up the tile pyramid\n        for (let z = tile.coords.z - 1; z >= 0; z--) {\n            let down = Tile.coordinateAtZoom(tile.coords, z);\n            if (this.coords[down.key] && this.coords[down.key].descendants > 0) {\n                this.coords[down.key].descendants--;\n                if (this.coords[down.key].descendants === 0 && !this.coords[down.key].sources) {\n                    delete this.coords[down.key];\n                }\n            }\n        }\n    },\n\n    getAncestor ({ coords, style_zoom, source }) {\n        // First check overzoomed tiles at same coordinate zoom\n        if (style_zoom > source.max_zoom) {\n            let source_tiles = this.sourceTiles(coords, source);\n            if (source_tiles) {\n                for (let z = style_zoom - 1; z >= source.max_zoom; z--) {\n                    if (source_tiles.has(z) && source_tiles.get(z).loaded) {\n                        return source_tiles.get(z);\n                    }\n                }\n            }\n            style_zoom = source.max_zoom;\n        }\n\n        // Check tiles at next zoom up\n        style_zoom--;\n        let parent = Tile.coordinateAtZoom(coords, coords.z - 1);\n        let parent_tiles = this.sourceTiles(parent, source);\n        if (parent_tiles && parent_tiles.has(style_zoom) && parent_tiles.get(style_zoom).loaded) {\n            return parent_tiles.get(style_zoom);\n        }\n        // didn't find ancestor, try next level\n        // TODO: max depth levels to check\n        if (parent.z > 0) {\n            return this.getAncestor({ coords: parent, style_zoom, source });\n        }\n    },\n\n    getDescendants ({ coords, style_zoom, source }, level = 1) {\n        let descendants = [];\n\n        // First check overzoomed tiles at same coordinate zoom\n        if (style_zoom >= source.max_zoom) {\n            let source_tiles = this.sourceTiles(coords, source);\n            if (source_tiles) {\n                let search_max_zoom = Math.max(Geo.default_view_max_zoom, style_zoom + this.max_proxy_descendant_depth);\n                for (let z = style_zoom + 1; z <= search_max_zoom; z++) {\n                    if (source_tiles.has(z) && source_tiles.get(z).loaded) {\n                        descendants.push(source_tiles.get(z));\n                        return descendants;\n                    }\n                }\n            }\n            return descendants;\n        }\n\n        // Check tiles at next zoom down\n        if (this.coords[coords.key] && this.coords[coords.key].descendants > 0) {\n            style_zoom++;\n            for (let child of Tile.childrenForCoordinate(coords)) {\n                let child_tiles = this.sourceTiles(child, source);\n                if (child_tiles && child_tiles.has(style_zoom) && child_tiles.get(style_zoom).loaded) {\n                    descendants.push(child_tiles.get(style_zoom));\n                }\n                // didn't find child, try next level\n                else if (level <= this.max_proxy_descendant_depth && child.z <= source.max_zoom) {\n                    descendants.push(...this.getDescendants({ coords: child, source, style_zoom }, level + 1));\n                }\n            }\n        }\n\n        return descendants;\n    }\n\n};\n\nexport default TilePyramid;\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","// Partial import of gl-matrix via modularized stack-gl forks\n// https://github.com/toji/gl-matrix\n// https://github.com/stackgl\n\n// vec3\n\n// Substitute 64-bit version\n// We need the extra precision when multiplying matrices w/mercator projected values\nconst vec3 = {\n    fromValues (x, y, z) {\n        var out = new Float64Array(3);\n        out[0] = x;\n        out[1] = y;\n        out[2] = z;\n        return out;\n    }\n};\n\n\n// mat3\n\nimport {default as mat3_normalFromMat4} from 'gl-mat3/normal-from-mat4';\nimport {default as mat3_invert} from 'gl-mat3/invert';\n\nconst mat3 = {\n    normalFromMat4: mat3_normalFromMat4,\n    invert: mat3_invert\n};\n\n\n// mat4\n\nimport {default as mat4_multiply} from 'gl-mat4/multiply';\nimport {default as mat4_translate} from 'gl-mat4/translate';\nimport {default as mat4_scale} from 'gl-mat4/scale';\nimport {default as mat4_perspective} from 'gl-mat4/perspective';\nimport {default as mat4_lookAt} from 'gl-mat4/lookAt';\nimport {default as mat4_identity} from 'gl-mat4/identity';\nimport {default as mat4_copy} from 'gl-mat4/copy';\n\nconst mat4 = {\n    multiply: mat4_multiply,\n    translate: mat4_translate,\n    scale: mat4_scale,\n    perspective: mat4_perspective,\n    lookAt: mat4_lookAt,\n    identity: mat4_identity,\n    copy: mat4_copy\n};\n\n\nexport {vec3, mat3, mat4};\n","// Deep/recursive merge of one or more source objects into a destination object\nexport default function mergeObjects (dest, ...sources) {\n    for (let s=0; s < sources.length; s++) {\n        let source = sources[s];\n        if (!source) {\n            continue;\n        }\n        for (let key in source) {\n            let value = source[key];\n            // Recursively merge the source into the destination if it is a a non-null key/value object\n            // (e.g. don't merge arrays, those are treated as scalar values; null values will overwrite/erase\n            // the previous destination value)\n            if (value !== null && typeof value === 'object' && !Array.isArray(value)) {\n                dest[key] = mergeObjects(dest[key] || {}, value);\n            }\n            // Overwrite the previous destination value if the source property is: a scalar (number/string),\n            // an array, or a null value\n            else if (value !== undefined) {\n                dest[key] = value;\n            }\n            // Undefined source properties are ignored\n        }\n\n    }\n    return dest;\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 && 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    if (url.indexOf('?') > -1) {\n        url += '&' + (+new Date());\n    }\n    else {\n        url += '?' + (+new Date());\n    }\n    return url;\n};\n\n// Add a set of query string params to a URL\n// params: hash of key/value pairs of query string parameters\nUtils.addParamsToURL = function (url, params) {\n    if (!params || Object.keys(params).length === 0) {\n        return url;\n    }\n\n    var qs_index = url.indexOf('?');\n    var hash_index = url.indexOf('#');\n\n    // Save and trim hash\n    var hash = '';\n    if (hash_index > -1) {\n        hash = url.slice(hash_index);\n        url = url.slice(0, hash_index);\n    }\n\n    // Start query string\n    if (qs_index === -1) {\n        qs_index = url.length;\n        url += '?';\n    }\n    qs_index++; // advanced past '?'\n\n    // Build query string params\n    var url_params = '';\n    for (var p in params) {\n        url_params += `${p}=${params[p]}&`;\n    }\n\n    // Insert new query string params and restore hash\n    // NOTE: doesn't replace any values already present on query string, just inserts dupe values\n    url = url.slice(0, qs_index) + url_params + url.slice(qs_index) + hash;\n\n    return url;\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        // jsyaml 'json' option allows duplicate keys\n        // Keeping this for backwards compatibility, but should consider migrating to requiring\n        // unique keys, as this is YAML spec. But Tangram ES currently accepts dupe keys as well,\n        // so should consider how best to unify.\n        data = yaml.safeLoad(body, { json: true });\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(JSON.stringify({\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\n// Returns true if display density changed\nUtils.use_high_density_display = true;\nUtils.updateDevicePixelRatio = function () {\n    let prev = Utils.device_pixel_ratio;\n    Utils.device_pixel_ratio = (Utils.use_high_density_display && window.devicePixelRatio) || 1;\n    return Utils.device_pixel_ratio !== prev;\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, transform) {\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, y1, y2;\n\n    // Min bounds\n    if (x <= points[0][0]) {\n        y = points[0][1];\n        if (typeof transform === 'function') {\n            y = transform(y);\n        }\n    }\n    // Max bounds\n    else if (x >= points[points.length-1][0]) {\n        y = points[points.length-1][1];\n        if (typeof transform === 'function') {\n            y = transform(y);\n        }\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                        if (typeof transform === 'function') {\n                            y1 = transform(points[i][1][c]);\n                            y2 = transform(points[i+1][1][c]);\n                            d = y2 - y1;\n                            y[c] = d * (x - x1) / (x2 - x1) + y1;\n                        }\n                        else {\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                }\n                // Single value\n                else {\n                    if (typeof transform === 'function') {\n                        y1 = transform(points[i][1]);\n                        y2 = transform(points[i+1][1]);\n                        d = y2 - y1;\n                        y = d * (x - x1) / (x2 - x1) + y1;\n                    }\n                    else {\n                        d = points[i+1][1] - points[i][1];\n                        y = d * (x - x1) / (x2 - x1) + points[i][1];\n                    }\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.toCSSColor = function (color) {\n    if (color[3] === 1) { // full opacity\n        return `rgb(${color.slice(0, 3).map(c => Math.round(c * 255)).join(', ')})`;\n    }\n    // RGB is between [0, 255] opacity is between [0, 1]\n    return `rgba(${color.map((c, i) => (i < 3 && Math.round(c * 255)) || c).join(', ')})`;\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\nUtils.debounce = function (func, wait, immediate) {\n    let timeout;\n    return function() {\n        let context = this,\n            args = arguments;\n        let later = function() {\n            timeout = null;\n            if (!immediate) {\n                func.apply(context, args);\n            }\n        };\n        let callNow = immediate && !timeout;\n        clearTimeout(timeout);\n        timeout = setTimeout(later, wait);\n        if (callNow) {\n            func.apply(context, args);\n        }\n    };\n};\n","var version;\nexport default version = {\n    get string() { return `v${version.major}.${version.minor}.${version.patch}`; },\n    major: 0,\n    minor: 7,\n    patch: 2,\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, register self as target define a method:\n//\n//     WorkerBroker.addTarget('self', self);\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, 'self.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, 'self.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// Calling from worker to main thread:\n//\n// The same style of calls can be made *from* a web worker, to the main thread. The API is the same\n// with the exception that the first argument, 'worker', is not needed for WorkerBroker.postMessage(),\n// since the main thread is the implicit target.\n//\n// In main thread, define a method and register it:\n//\n//     var geometry = {\n//         length: function(x, y) {\n//             return Math.sqrt(x * x + y * y);\n//         }\n//     };\n//\n//     WorkerBroker.addTarget('geometry', geometry);\n//\n// In worker thread:\n//\n//     WorkerBroker.postMessage('geometry.length', 3, 4).then(function(d) {\n//         console.log(d);\n//     });\n//\n//     -> prints 5\n//\n\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// Register an object to receive calls from other thread\nvar targets = {};\nWorkerBroker.addTarget = function (name, target) {\n    targets[name] = target;\n};\n\n// Given a dot-notation-style method name, e.g. 'Object.object.method',\n// find the object to call the method on from the list of registered targets\nfunction findTarget (method) {\n    var chain = [];\n    if (typeof method === 'string') {\n        chain = method.split('.');\n        method = chain.pop();\n    }\n\n    // target = target || (Utils.isMainThread && window) || (Utils.isWorkerThread && self);\n    var target = targets;\n\n    for (let m=0; m < chain.length; m++) {\n        if (target[chain[m]]) {\n            target = target[chain[m]];\n        }\n        else {\n            return [];\n        }\n    }\n\n    return [method, target];\n}\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: one or more web worker instances to send the message to (single value or array)\n    //   - method: the method with this name, specified with dot-notation, will be invoked in the worker\n    //   - message: will be passed to the method call\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        // If more than one worker specified, post to multiple\n        if (Array.isArray(worker)) {\n            return Promise.all(\n                worker.map(w => WorkerBroker.postMessage(w, method, ...message))\n            );\n        }\n\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(JSON.stringify({\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 = new Map();\n\n    WorkerBroker.addWorker = function (worker) {\n\n        // Keep track of all registered workers\n        workers.set(worker, worker_id++);\n\n        // Listen for messages coming back from the worker, and fulfill that message's promise\n        worker.addEventListener('message', (event) => {\n            let data = maybeDecode(event.data);\n            if (data.type !== 'worker_reply') {\n                return;\n            }\n\n            // Pass the result to the promise\n            var id = data.message_id;\n            if (messages[id]) {\n                if (data.error) {\n                    messages[id].reject(data.error);\n                }\n                else {\n                    messages[id].resolve(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            let data = maybeDecode(event.data);\n\n            // Unique id for this message & return call to main thread\n            var id = data.message_id;\n            if (data.type !== 'worker_send' || id == null) {\n                return;\n            }\n\n            // Call the requested method and save the return value\n            // var target = targets[data.target];\n            var [method_name, target] = findTarget(data.method);\n            if (!target) {\n                throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because no object with that name is registered on main thread`);\n            }\n\n            var method = (typeof target[method_name] === 'function') && target[method_name];\n            if (!method) {\n                throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because object has no method with that name`);\n            }\n\n            var result, error;\n            try {\n                result = method.apply(target, 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            let payload, transferables = [];\n\n            // Async result\n            if (result instanceof Promise) {\n                result.then((value) => {\n                    if (value instanceof WorkerBroker.returnWithTransferables) {\n                        transferables = value.transferables;\n                        value = value.value;\n                    }\n\n                    payload = {\n                        type: 'main_reply',\n                        message_id: id,\n                        message: value\n                    };\n                    payload = maybeEncode(payload, transferables);\n                    worker.postMessage(payload, transferables.map(t => t.object));\n                    freeTransferables(transferables);\n                    // if (transferables.length > 0) {\n                    //     Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to worker thread`);\n                    // }\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                if (result instanceof WorkerBroker.returnWithTransferables) {\n                    transferables = result.transferables;\n                    result = result.value;\n                }\n\n                payload = {\n                    type: 'main_reply',\n                    message_id: id,\n                    message: result,\n                    error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n                };\n                payload = maybeEncode(payload, transferables);\n                worker.postMessage(payload, transferables.map(t => t.object));\n                freeTransferables(transferables);\n                // if (transferables.length > 0) {\n                //     Utils.log('trace', `'${method_name}' transferred ${transferables.length} objects to worker thread`);\n                // }\n            }\n        });\n\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    //   - method: the method with this name, specified with dot-notation, will be invoked on the main thread\n    //   - message: will be passed to the method call\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 (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        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            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        let data = maybeDecode(event.data);\n        if (data.type !== 'main_reply') {\n            return;\n        }\n\n        // Pass the result to the promise\n        var id = data.message_id;\n        if (messages[id]) {\n            if (data.error) {\n                messages[id].reject(data.error);\n            }\n            else {\n                messages[id].resolve(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        let data = maybeDecode(event.data);\n\n        // Unique id for this message & return call to main thread\n        var id = data.message_id;\n        if (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, target] = findTarget(data.method);\n        if (!target) {\n            throw Error(`Worker broker could not dispatch message type ${data.method} on target ${data.target} because no object with that name is registered on main thread`);\n        }\n\n        var method = (typeof target[method_name] === 'function') && target[method_name];\n\n        if (!method) {\n            throw Error(`Worker broker could not dispatch message type ${data.method} because worker has no method with that name`);\n        }\n\n        var result, error;\n        try {\n            result = method.apply(target, 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 payload, transferables = [];\n\n        // Async result\n        if (result instanceof Promise) {\n            result.then((value) => {\n                if (value instanceof WorkerBroker.returnWithTransferables) {\n                    transferables = value.transferables;\n                    value = value.value;\n                }\n\n                payload = {\n                    type: 'worker_reply',\n                    message_id: id,\n                    message: value\n                };\n                payload = maybeEncode(payload, transferables);\n                self.postMessage(payload, transferables.map(t => t.object));\n                freeTransferables(transferables);\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            if (result instanceof WorkerBroker.returnWithTransferables) {\n                transferables = result.transferables;\n                result = result.value;\n            }\n\n            payload = {\n                type: 'worker_reply',\n                message_id: id,\n                message: result,\n                error: (error instanceof Error ? `${error.message}: ${error.stack}` : error)\n            };\n            payload = maybeEncode(payload, transferables);\n            self.postMessage(payload, transferables.map(t => t.object));\n            freeTransferables(transferables);\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// Special return value wrapper, to indicate that we want to find and include\n// transferable objects in the response message\nWorkerBroker.returnWithTransferables = function (value) {\n    if (!(this instanceof WorkerBroker.returnWithTransferables)) {\n        return new WorkerBroker.returnWithTransferables(value);\n    }\n\n    this.value = value;\n    this.transferables = findTransferables(this.value);\n};\n\n// Build a list of transferable objects from a source object\n// Returns a list of info about each transferable:\n//   - object: the actual transferable object\n//   - parent: the parent object that the transferable is a property of (if any)\n//   - property: the property name of the transferable on the parent object (if any)\n// TODO: add option in case you DON'T want to transfer objects\nfunction findTransferables(source, parent = null, property = null, list = []) {\n    if (!source) {\n         return list;\n    }\n\n    if (Array.isArray(source)) {\n        // Check each array element\n        source.forEach((x, i) => findTransferables(x, source, i, list));\n    }\n    else if (typeof source === 'object') {\n        // Is the object a transferable array buffer?\n        if (source instanceof ArrayBuffer) {\n            list.push({ object: source, parent, property });\n        }\n        // Or looks like a typed array (has an array buffer property)?\n        else if (source.buffer instanceof ArrayBuffer) {\n            list.push({ object: source.buffer, parent, property });\n        }\n        // Otherwise check each property\n        else {\n            for (let prop in source) {\n                findTransferables(source[prop], source, prop, list);\n            }\n        }\n    }\n    return list;\n}\n\n// Remove neutered transferables from parent objects, as they should no longer be accessed after transfer\nfunction freeTransferables(transferables) {\n    if (!Array.isArray(transferables)) {\n        return;\n    }\n    transferables.filter(t => t.parent && t.property).forEach(t => delete t.parent[t.property]);\n}\n\n// Message payload can be stringified for faster transfer, if it does not include transferable objects\nfunction maybeEncode (payload, transferables) {\n    if (transferables.length === 0) {\n        payload = JSON.stringify(payload);\n    }\n    return payload;\n}\n\n// Parse stringified message payload\nfunction maybeDecode (data) {\n    return (typeof data === 'string' ? JSON.parse(data) : data);\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 c = Math.cos(a);\n    var s = Math.sin(a);\n    return [v[0] * c - v[1] * s,\n            v[0] * s + v[1] * c];\n};\n\n// Get 2D heading angle\nVector.angle = function ([x, y]) {\n    return Math.atan2(y,x);\n};\n\n// Get angle between two vectors\nVector.angleBetween = function(A, B){\n    var delta = Vector.dot(A, B);\n    if (delta < -1) {\n        delta = -1;\n    }\n    return Math.acos(delta);\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","import Geo from './geo';\nimport Tile from './tile';\nimport Camera from './camera';\nimport Utils from './utils/utils';\nimport subscribeMixin from './utils/subscribe';\n\nimport log from 'loglevel';\n\nexport default class View {\n\n    constructor (scene, options) {\n        subscribeMixin(this);\n\n        this.scene = scene;\n        this.createMatrices();\n\n        this.zoom = null;\n        this.center = null;\n        this.bounds = null;\n        this.meters_per_pixel = null;\n\n        this.panning = false;\n        this.zooming = false;\n        this.zoom_direction = 0;\n\n        // Size of viewport in CSS pixels, device pixels, and mercator meters\n        this.size = {\n            css: {},\n            device: {},\n            meters: {}\n        };\n        this.aspect = null;\n\n        this.buffer = 0;\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.preserve_tiles_within_zoom = 1;\n\n        this.reset();\n    }\n\n    // Reset state before scene config is updated\n    reset () {\n        this.createCamera();\n    }\n\n    // Create camera\n    createCamera () {\n        let active_camera = this.getActiveCamera();\n        if (active_camera) {\n            this.camera = Camera.create(active_camera, this, this.scene.config.cameras[active_camera]);\n            this.camera.updateView();\n        }\n    }\n\n    // Get active camera - for public API\n    getActiveCamera () {\n        if (this.scene.config && this.scene.config.cameras) {\n            for (let name in this.scene.config.cameras) {\n                if (this.scene.config.cameras[name].active) {\n                    return name;\n                }\n            }\n        }\n    }\n\n    // Set active camera and recompile - for public API\n    setActiveCamera (name) {\n        let prev = this.getActiveCamera();\n        if (this.scene.config.cameras[name]) {\n            this.scene.config.cameras[name].active = true;\n\n            // Clear previously active camera\n            if (prev && prev !== name && this.scene.config.cameras[prev]) {\n                delete this.scene.config.cameras[prev].active;\n            }\n        }\n\n        this.scene.updateConfig();\n        return this.getActiveCamera();\n    }\n\n    // Update method called once per frame\n    update () {\n        this.camera.update();\n    }\n\n    // Set logical pixel size of viewport\n    setViewportSize (width, height) {\n        this.size.css = { width, height };\n        this.size.device = {\n            width: Math.round(this.size.css.width * Utils.device_pixel_ratio),\n            height: Math.round(this.size.css.height * Utils.device_pixel_ratio)\n        };\n        this.aspect = this.size.css.width / this.size.css.height;\n        this.updateBounds();\n    }\n\n    // Set the map view, can be passed an object with lat/lng and/or zoom\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    setZoom (zoom) {\n        if (this.zooming) {\n            this.zooming = false;\n        }\n        else {\n            this.last_zoom = this.zoom;\n        }\n\n        let last_tile_zoom = this.tile_zoom;\n        let tile_zoom = this.tileZoom(zoom);\n        if (!this.continuous_zoom) {\n            zoom = tile_zoom;\n        }\n\n        if (tile_zoom !== last_tile_zoom) {\n            this.zoom_direction = tile_zoom > last_tile_zoom ? 1 : -1;\n        }\n\n        this.last_zoom = this.zoom;\n        this.zoom = zoom;\n        this.tile_zoom = tile_zoom;\n\n        this.updateBounds();\n        this.scene.requestRedraw();\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    ready () {\n        // TODO: better concept of \"readiness\" state?\n        if (this.size.css == null || this.center == null || this.zoom == null) {\n             return false;\n        }\n        return true;\n    }\n\n    // Calculate viewport bounds based on current center and zoom\n    updateBounds () {\n        if (!this.ready()) {\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.size.meters = {\n            x: this.size.css.width * this.meters_per_pixel,\n            y: this.size.css.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        this.center.tile = Geo.tileForMeters([this.center.meters.x, this.center.meters.y], this.tile_zoom);\n\n        // Bounds in meters\n        this.bounds = {\n            sw: {\n                x: this.center.meters.x - this.size.meters.x / 2,\n                y: this.center.meters.y - this.size.meters.y / 2\n            },\n            ne: {\n                x: this.center.meters.x + this.size.meters.x / 2,\n                y: this.center.meters.y + this.size.meters.y / 2\n            }\n        };\n\n        this.scene.tile_manager.updateTilesForView();\n\n        this.trigger('move');\n        this.scene.requestRedraw(); // TODO automate via move event?\n    }\n\n    findVisibleTileCoordinates () {\n        if (!this.bounds) {\n            return [];\n        }\n\n        let z = this.tile_zoom;\n        let sw = Geo.tileForMeters([this.bounds.sw.x, this.bounds.sw.y], z);\n        let ne = Geo.tileForMeters([this.bounds.ne.x, this.bounds.ne.y], z);\n\n        let coords = [];\n        for (let x = sw.x - this.buffer; x <= ne.x + this.buffer; x++) {\n            for (let y = ne.y - this.buffer; y <= sw.y + this.buffer; y++) {\n                coords.push(Tile.coord({ x, y, z }));\n            }\n        }\n        return coords;\n    }\n\n    // Remove tiles too far outside of view\n    pruneTilesForView () {\n        // TODO: will this function ever be called when view isn't ready?\n        if (!this.ready()) {\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.size.css.width / Geo.tile_size) + 2) / 2),\n            Math.ceil((Math.floor(this.size.css.height / Geo.tile_size) + 2) / 2)\n        ];\n\n        this.scene.tile_manager.removeTiles(tile => {\n            // Ignore visible tiles\n            if (tile.visible || tile.proxy) {\n                return false;\n            }\n\n            // Remove tiles outside given zoom that are still loading\n            if (tile.loading && tile.style_zoom !== this.tile_zoom) {\n                return true;\n            }\n\n            // Discard if too far from current zoom\n            let zdiff = Math.abs(tile.style_zoom - this.tile_zoom);\n            if (zdiff > this.preserve_tiles_within_zoom) {\n                return true;\n            }\n\n            // Handle tiles at different zooms\n            let coords = Tile.coordinateAtZoom(tile.coords, this.tile_zoom);\n\n            // Discard tiles outside an area surrounding the viewport\n            if (Math.abs(coords.x - this.center.tile.x) - border_tiles[0] > this.buffer) {\n                log.trace(`View: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${this.tile_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] > this.buffer) {\n                log.trace(`View: remove tile ${tile.key} (as ${coords.x}/${coords.y}/${this.tile_zoom}) for being too far out of visible area ***`);\n                return true;\n            }\n            return false;\n        });\n    }\n\n    // Allocate model-view matrices\n    // 64-bit versions are for CPU calcuations\n    // 32-bit versions are downsampled and sent to GPU\n    createMatrices () {\n        this.matrices = {};\n        this.matrices.model = new Float64Array(16);\n        this.matrices.model32 = new Float32Array(16);\n        this.matrices.model_view = new Float64Array(16);\n        this.matrices.model_view32 = new Float32Array(16);\n        this.matrices.normal = new Float64Array(9);\n        this.matrices.normal32 = new Float32Array(9);\n        this.matrices.inverse_normal32 = new Float32Array(9);\n    }\n\n    // Calculate and set model/view and normal matrices for a tile\n    setupTile (tile, program) {\n        // Tile-specific state\n        // TODO: calc these once per tile (currently being needlessly re-calculated per-tile-per-style)\n        tile.setupProgram(this.matrices, program);\n\n        // Model-view and normal matrices\n        this.camera.setupMatrices(this.matrices, program);\n    }\n\n    // Set general uniforms that must be updated once per program\n    setupProgram (program) {\n        program.uniform('2f', 'u_resolution', this.size.device.width, this.size.device.height);\n        program.uniform('3f', 'u_map_position', this.center.meters.x, this.center.meters.y, this.zoom);\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        this.camera.setupProgram(program);\n    }\n\n}\n"]} -Tangram.debug.commit = 'd0facba8b41d43eac689ee4058af3e83d9f8e146'; +Tangram.debug.commit = '6135986d09b48905d4dd2340e536b89c12ce238c'; diff --git a/dist/tangram.min.js b/dist/tangram.min.js index 8a98d3a43..0971e07d7 100644 --- a/dist/tangram.min.js +++ b/dist/tangram.min.js @@ -3,12 +3,12 @@ r.Buffer=n,r.SlowBuffer=n,r.INSPECT_MAX_BYTES=50,n.poolSize=8192;var I=107374182 },{"./$.add-to-unscopables":57,"./$.iter-define":85,"./$.iter-step":87,"./$.iterators":88,"./$.to-iobject":108}],118:[function(e){"use strict";var t=e("./$.collection-strong");e("./$.collection")("Map",function(e){return function(){return e(this,arguments.length>0?arguments[0]:void 0)}},{get:function(e){var r=t.getEntry(this,e);return r&&r.v},set:function(e,r){return t.def(this,0===e?0:e,r)}},t,!0)},{"./$.collection":63,"./$.collection-strong":61}],119:[function(e){var t=e("./$.export");t(t.S,"Math",{log2:function(e){return Math.log(e)/Math.LN2}})},{"./$.export":70}],120:[function(e){var t=e("./$.export");t(t.S+t.F,"Object",{assign:e("./$.object-assign")})},{"./$.export":70,"./$.object-assign":93}],121:[function(e){var t=e("./$.is-object");e("./$.object-sap")("freeze",function(e){return function(r){return e&&t(r)?e(r):r}})},{"./$.is-object":82,"./$.object-sap":94}],122:[function(e){var t=e("./$.to-iobject");e("./$.object-sap")("getOwnPropertyDescriptor",function(e){return function(r,n){return e(t(r),n)}})},{"./$.object-sap":94,"./$.to-iobject":108}],123:[function(e){var t=e("./$.to-object");e("./$.object-sap")("keys",function(e){return function(r){return e(t(r))}})},{"./$.object-sap":94,"./$.to-object":110}],124:[function(e){var t=e("./$.export");t(t.S,"Object",{setPrototypeOf:e("./$.set-proto").set})},{"./$.export":70,"./$.set-proto":99}],125:[function(e,t){t.exports=e(37)},{"/Users/bcamper/Documents/dev/vector-map/node_modules/browser-resolve/empty.js":37}],126:[function(e){"use strict";var t,r=e("./$"),n=e("./$.library"),i=e("./$.global"),o=e("./$.ctx"),a=e("./$.classof"),s=e("./$.export"),l=e("./$.is-object"),u=e("./$.an-object"),c=e("./$.a-function"),f=e("./$.strict-new"),h=e("./$.for-of"),d=e("./$.set-proto").set,p=e("./$.same-value"),m=e("./$.wks")("species"),g=e("./$.species-constructor"),v=e("./$.microtask"),_="Promise",y=i.process,b="process"==a(y),x=i[_],w=function(e){var t=new x(function(){});return e&&(t.constructor=Object),x.resolve(t)===t},A=function(){function t(e){var r=new x(e);return d(r,t.prototype),r}var n=!1;try{if(n=x&&x.resolve&&w(),d(t,x),t.prototype=r.create(x.prototype,{constructor:{value:t}}),t.resolve(5).then(function(){})instanceof t||(n=!1),n&&e("./$.descriptors")){var i=!1;x.resolve(r.setDesc({},"then",{get:function(){i=!0}})),n=i}}catch(o){n=!1}return n}(),T=function(e,r){return n&&e===x&&r===t?!0:p(e,r)},k=function(e){var t=u(e)[m];return void 0!=t?t:e},E=function(e){var t;return l(e)&&"function"==typeof(t=e.then)?t:!1},S=function(e){var t,r;this.promise=new e(function(e,n){if(void 0!==t||void 0!==r)throw TypeError("Bad Promise constructor");t=e,r=n}),this.resolve=c(t),this.reject=c(r)},R=function(e){try{e()}catch(t){return{error:t}}},M=function(e,t){if(!e.n){e.n=!0;var r=e.c;v(function(){for(var n=e.v,o=1==e.s,a=0,s=function(t){var r,i,a=o?t.ok:t.fail,s=t.resolve,l=t.reject;try{a?(o||(e.h=!0),r=a===!0?n:a(n),r===t.promise?l(TypeError("Promise-chain cycle")):(i=E(r))?i.call(r,s,l):s(r)):l(n)}catch(u){l(u)}};r.length>a;)s(r[a++]);r.length=0,e.n=!1,t&&setTimeout(function(){var t,r,o=e.p;j(o)&&(b?y.emit("unhandledRejection",n,o):(t=i.onunhandledrejection)?t({promise:o,reason:n}):(r=i.console)&&r.error&&r.error("Unhandled promise rejection",n)),e.a=void 0},1)})}},j=function(e){var t,r=e._d,n=r.a||r.c,i=0;if(r.h)return!1;for(;n.length>i;)if(t=n[i++],t.fail||!j(t.promise))return!1;return!0},P=function(e){var t=this;t.d||(t.d=!0,t=t.r||t,t.v=e,t.s=2,t.a=t.c.slice(),M(t,!0))},z=function(e){var t,r=this;if(!r.d){r.d=!0,r=r.r||r;try{if(r.p===e)throw TypeError("Promise can't be resolved itself");(t=E(e))?v(function(){var n={r:r,d:!1};try{t.call(e,o(z,n,1),o(P,n,1))}catch(i){P.call(n,i)}}):(r.v=e,r.s=1,M(r,!1))}catch(n){P.call({r:r,d:!1},n)}}};A||(x=function(e){c(e);var t=this._d={p:f(this,x,_),c:[],a:void 0,s:0,d:!1,v:void 0,h:!1,n:!1};try{e(o(z,t,1),o(P,t,1))}catch(r){P.call(t,r)}},e("./$.redefine-all")(x.prototype,{then:function(e,t){var r=new S(g(this,x)),n=r.promise,i=this._d;return r.ok="function"==typeof e?e:!0,r.fail="function"==typeof t&&t,i.c.push(r),i.a&&i.a.push(r),i.s&&M(i,!1),n},"catch":function(e){return this.then(void 0,e)}})),s(s.G+s.W+s.F*!A,{Promise:x}),e("./$.set-to-string-tag")(x,_),e("./$.set-species")(_),t=e("./$.core")[_],s(s.S+s.F*!A,_,{reject:function(e){var t=new S(this),r=t.reject;return r(e),t.promise}}),s(s.S+s.F*(!A||w(!0)),_,{resolve:function(e){if(e instanceof x&&T(e.constructor,this))return e;var t=new S(this),r=t.resolve;return r(e),t.promise}}),s(s.S+s.F*!(A&&e("./$.iter-detect")(function(e){x.all(e)["catch"](function(){})})),_,{all:function(e){var t=k(this),n=new S(t),i=n.resolve,o=n.reject,a=[],s=R(function(){h(e,!1,a.push,a);var n=a.length,s=Array(n);n?r.each.call(a,function(e,r){var a=!1;t.resolve(e).then(function(e){a||(a=!0,s[r]=e,--n||i(s))},o)}):i(s)});return s&&o(s.error),n.promise},race:function(e){var t=k(this),r=new S(t),n=r.reject,i=R(function(){h(e,!1,function(e){t.resolve(e).then(r.resolve,n)})});return i&&n(i.error),r.promise}})},{"./$":89,"./$.a-function":56,"./$.an-object":58,"./$.classof":59,"./$.core":64,"./$.ctx":65,"./$.descriptors":67,"./$.export":70,"./$.for-of":72,"./$.global":74,"./$.is-object":82,"./$.iter-detect":86,"./$.library":91,"./$.microtask":92,"./$.redefine-all":96,"./$.same-value":98,"./$.set-proto":99,"./$.set-species":100,"./$.set-to-string-tag":101,"./$.species-constructor":103,"./$.strict-new":104,"./$.wks":112}],127:[function(e){"use strict";var t=e("./$.collection-strong");e("./$.collection")("Set",function(e){return function(){return e(this,arguments.length>0?arguments[0]:void 0)}},{add:function(e){return t.def(this,e=0===e?0:e,e)}},t)},{"./$.collection":63,"./$.collection-strong":61}],128:[function(e){"use strict";var t=e("./$.string-at")(!0);e("./$.iter-define")(String,"String",function(e){this._t=String(e),this._i=0},function(){var e,r=this._t,n=this._i;return n>=r.length?{value:void 0,done:!0}:(e=t(r,n),this._i+=e.length,{value:e,done:!1})})},{"./$.iter-define":85,"./$.string-at":105}],129:[function(e){"use strict";var t=e("./$"),r=e("./$.global"),n=e("./$.has"),i=e("./$.descriptors"),o=e("./$.export"),a=e("./$.redefine"),s=e("./$.fails"),l=e("./$.shared"),u=e("./$.set-to-string-tag"),c=e("./$.uid"),f=e("./$.wks"),h=e("./$.keyof"),d=e("./$.get-names"),p=e("./$.enum-keys"),m=e("./$.is-array"),g=e("./$.an-object"),v=e("./$.to-iobject"),_=e("./$.property-desc"),y=t.getDesc,b=t.setDesc,x=t.create,w=d.get,A=r.Symbol,T=r.JSON,k=T&&T.stringify,E=!1,S=f("_hidden"),R=t.isEnum,M=l("symbol-registry"),j=l("symbols"),P="function"==typeof A,z=Object.prototype,N=i&&s(function(){return 7!=x(b({},"a",{get:function(){return b(this,"a",{value:7}).a}})).a})?function(e,t,r){var n=y(z,t);n&&delete z[t],b(e,t,r),n&&e!==z&&b(z,t,n)}:b,O=function(e){var t=j[e]=x(A.prototype);return t._k=e,i&&E&&N(z,e,{configurable:!0,set:function(t){n(this,S)&&n(this[S],e)&&(this[S][e]=!1),N(this,e,_(1,t))}}),t},L=function(e){return"symbol"==typeof e},I=function(e,t,r){return r&&n(j,t)?(r.enumerable?(n(e,S)&&e[S][t]&&(e[S][t]=!1),r=x(r,{enumerable:_(0,!1)})):(n(e,S)||b(e,S,_(1,{})),e[S][t]=!0),N(e,t,r)):b(e,t,r)},U=function(e,t){g(e);for(var r,n=p(t=v(t)),i=0,o=n.length;o>i;)I(e,r=n[i++],t[r]);return e},F=function(e,t){return void 0===t?x(e):U(x(e),t)},D=function(e){var t=R.call(this,e);return t||!n(this,e)||!n(j,e)||n(this,S)&&this[S][e]?t:!0},$=function(e,t){var r=y(e=v(e),t);return!r||!n(j,t)||n(e,S)&&e[S][t]||(r.enumerable=!0),r},C=function(e){for(var t,r=w(v(e)),i=[],o=0;r.length>o;)n(j,t=r[o++])||t==S||i.push(t);return i},G=function(e){for(var t,r=w(v(e)),i=[],o=0;r.length>o;)n(j,t=r[o++])&&i.push(j[t]);return i},B=function(e){if(void 0!==e&&!L(e)){for(var t,r,n=[e],i=1,o=arguments;o.length>i;)n.push(o[i++]);return t=n[1],"function"==typeof t&&(r=t),(r||!m(t))&&(t=function(e,t){return r&&(t=r.call(this,e,t)),L(t)?void 0:t}),n[1]=t,k.apply(T,n)}},q=s(function(){var e=A();return"[null]"!=k([e])||"{}"!=k({a:e})||"{}"!=k(Object(e))});P||(A=function(){if(L(this))throw TypeError("Symbol is not a constructor");return O(c(arguments.length>0?arguments[0]:void 0))},a(A.prototype,"toString",function(){return this._k}),L=function(e){return e instanceof A},t.create=F,t.isEnum=D,t.getDesc=$,t.setDesc=I,t.setDescs=U,t.getNames=d.get=C,t.getSymbols=G,i&&!e("./$.library")&&a(z,"propertyIsEnumerable",D,!0));var V={"for":function(e){return n(M,e+="")?M[e]:M[e]=A(e)},keyFor:function(e){return h(M,e)},useSetter:function(){E=!0},useSimple:function(){E=!1}};t.each.call("hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables".split(","),function(e){var t=f(e);V[e]=P?t:O(t)}),E=!0,o(o.G+o.W,{Symbol:A}),o(o.S,"Symbol",V),o(o.S+o.F*!P,"Object",{create:F,defineProperty:I,defineProperties:U,getOwnPropertyDescriptor:$,getOwnPropertyNames:C,getOwnPropertySymbols:G}),T&&o(o.S+o.F*(!P||q),"JSON",{stringify:B}),u(A,"Symbol"),u(Math,"Math",!0),u(r.JSON,"JSON",!0)},{"./$":89,"./$.an-object":58,"./$.descriptors":67,"./$.enum-keys":69,"./$.export":70,"./$.fails":71,"./$.get-names":73,"./$.global":74,"./$.has":75,"./$.is-array":81,"./$.keyof":90,"./$.library":91,"./$.property-desc":95,"./$.redefine":97,"./$.set-to-string-tag":101,"./$.shared":102,"./$.to-iobject":108,"./$.uid":111,"./$.wks":112}],130:[function(e){var t=e("./$.export");t(t.P,"Map",{toJSON:e("./$.collection-to-json")("Map")})},{"./$.collection-to-json":62,"./$.export":70}],131:[function(e){var t=e("./$.export");t(t.P,"Set",{toJSON:e("./$.collection-to-json")("Set")})},{"./$.collection-to-json":62,"./$.export":70}],132:[function(e){e("./es6.array.iterator");var t=e("./$.iterators");t.NodeList=t.HTMLCollection=t.Array},{"./$.iterators":88,"./es6.array.iterator":117}],133:[function(e,t,r){function n(e){return e=Math.round(e),0>e?0:e>255?255:e}function i(e){return 0>e?0:e>1?1:e}function o(e){return n("%"===e[e.length-1]?parseFloat(e)/100*255:parseInt(e))}function a(e){return i("%"===e[e.length-1]?parseFloat(e)/100:parseFloat(e))}function s(e,t,r){return 0>r?r+=1:r>1&&(r-=1),1>6*r?e+(t-e)*r*6:1>2*r?t:2>3*r?e+(t-e)*(2/3-r)*6:e}function l(e){var t=e.replace(/ /g,"").toLowerCase();if(t in u)return u[t].slice();if("#"===t[0]){if(4===t.length){var r=parseInt(t.substr(1),16);return r>=0&&4095>=r?[(3840&r)>>4|(3840&r)>>8,240&r|(240&r)>>4,15&r|(15&r)<<4,1]:null}if(7===t.length){var r=parseInt(t.substr(1),16);return r>=0&&16777215>=r?[(16711680&r)>>16,(65280&r)>>8,255&r,1]:null}return null}var i=t.indexOf("("),l=t.indexOf(")");if(-1!==i&&l+1===t.length){var c=t.substr(0,i),f=t.substr(i+1,l-(i+1)).split(","),h=1;switch(c){case"rgba":if(4!==f.length)return null;h=a(f.pop());case"rgb":return 3!==f.length?null:[o(f[0]),o(f[1]),o(f[2]),h];case"hsla":if(4!==f.length)return null;h=a(f.pop());case"hsl":if(3!==f.length)return null;var d=(parseFloat(f[0])%360+360)%360/360,p=a(f[1]),m=a(f[2]),g=.5>=m?m*(p+1):m+p-m*p,v=2*m-g;return[n(255*s(v,g,d+1/3)),n(255*s(v,g,d)),n(255*s(v,g,d-1/3)),h];default:return null}}return null}var u={transparent:[0,0,0,0],aliceblue:[240,248,255,1],antiquewhite:[250,235,215,1],aqua:[0,255,255,1],aquamarine:[127,255,212,1],azure:[240,255,255,1],beige:[245,245,220,1],bisque:[255,228,196,1],black:[0,0,0,1],blanchedalmond:[255,235,205,1],blue:[0,0,255,1],blueviolet:[138,43,226,1],brown:[165,42,42,1],burlywood:[222,184,135,1],cadetblue:[95,158,160,1],chartreuse:[127,255,0,1],chocolate:[210,105,30,1],coral:[255,127,80,1],cornflowerblue:[100,149,237,1],cornsilk:[255,248,220,1],crimson:[220,20,60,1],cyan:[0,255,255,1],darkblue:[0,0,139,1],darkcyan:[0,139,139,1],darkgoldenrod:[184,134,11,1],darkgray:[169,169,169,1],darkgreen:[0,100,0,1],darkgrey:[169,169,169,1],darkkhaki:[189,183,107,1],darkmagenta:[139,0,139,1],darkolivegreen:[85,107,47,1],darkorange:[255,140,0,1],darkorchid:[153,50,204,1],darkred:[139,0,0,1],darksalmon:[233,150,122,1],darkseagreen:[143,188,143,1],darkslateblue:[72,61,139,1],darkslategray:[47,79,79,1],darkslategrey:[47,79,79,1],darkturquoise:[0,206,209,1],darkviolet:[148,0,211,1],deeppink:[255,20,147,1],deepskyblue:[0,191,255,1],dimgray:[105,105,105,1],dimgrey:[105,105,105,1],dodgerblue:[30,144,255,1],firebrick:[178,34,34,1],floralwhite:[255,250,240,1],forestgreen:[34,139,34,1],fuchsia:[255,0,255,1],gainsboro:[220,220,220,1],ghostwhite:[248,248,255,1],gold:[255,215,0,1],goldenrod:[218,165,32,1],gray:[128,128,128,1],green:[0,128,0,1],greenyellow:[173,255,47,1],grey:[128,128,128,1],honeydew:[240,255,240,1],hotpink:[255,105,180,1],indianred:[205,92,92,1],indigo:[75,0,130,1],ivory:[255,255,240,1],khaki:[240,230,140,1],lavender:[230,230,250,1],lavenderblush:[255,240,245,1],lawngreen:[124,252,0,1],lemonchiffon:[255,250,205,1],lightblue:[173,216,230,1],lightcoral:[240,128,128,1],lightcyan:[224,255,255,1],lightgoldenrodyellow:[250,250,210,1],lightgray:[211,211,211,1],lightgreen:[144,238,144,1],lightgrey:[211,211,211,1],lightpink:[255,182,193,1],lightsalmon:[255,160,122,1],lightseagreen:[32,178,170,1],lightskyblue:[135,206,250,1],lightslategray:[119,136,153,1],lightslategrey:[119,136,153,1],lightsteelblue:[176,196,222,1],lightyellow:[255,255,224,1],lime:[0,255,0,1],limegreen:[50,205,50,1],linen:[250,240,230,1],magenta:[255,0,255,1],maroon:[128,0,0,1],mediumaquamarine:[102,205,170,1],mediumblue:[0,0,205,1],mediumorchid:[186,85,211,1],mediumpurple:[147,112,219,1],mediumseagreen:[60,179,113,1],mediumslateblue:[123,104,238,1],mediumspringgreen:[0,250,154,1],mediumturquoise:[72,209,204,1],mediumvioletred:[199,21,133,1],midnightblue:[25,25,112,1],mintcream:[245,255,250,1],mistyrose:[255,228,225,1],moccasin:[255,228,181,1],navajowhite:[255,222,173,1],navy:[0,0,128,1],oldlace:[253,245,230,1],olive:[128,128,0,1],olivedrab:[107,142,35,1],orange:[255,165,0,1],orangered:[255,69,0,1],orchid:[218,112,214,1],palegoldenrod:[238,232,170,1],palegreen:[152,251,152,1],paleturquoise:[175,238,238,1],palevioletred:[219,112,147,1],papayawhip:[255,239,213,1],peachpuff:[255,218,185,1],peru:[205,133,63,1],pink:[255,192,203,1],plum:[221,160,221,1],powderblue:[176,224,230,1],purple:[128,0,128,1],red:[255,0,0,1],rosybrown:[188,143,143,1],royalblue:[65,105,225,1],saddlebrown:[139,69,19,1],salmon:[250,128,114,1],sandybrown:[244,164,96,1],seagreen:[46,139,87,1],seashell:[255,245,238,1],sienna:[160,82,45,1],silver:[192,192,192,1],skyblue:[135,206,235,1],slateblue:[106,90,205,1],slategray:[112,128,144,1],slategrey:[112,128,144,1],snow:[255,250,250,1],springgreen:[0,255,127,1],steelblue:[70,130,180,1],tan:[210,180,140,1],teal:[0,128,128,1],thistle:[216,191,216,1],tomato:[255,99,71,1],turquoise:[64,224,208,1],violet:[238,130,238,1],wheat:[245,222,179,1],white:[255,255,255,1],whitesmoke:[245,245,245,1],yellow:[255,255,0,1],yellowgreen:[154,205,50,1]};try{r.parseCSSColor=l}catch(c){}},{}],134:[function(e,t){"use strict";function r(e,t,n){var i=0|e[n];if(0>=i)return[];var o,a=new Array(i);if(n===e.length-1)for(o=0;i>o;++o)a[o]=t;else for(o=0;i>o;++o)a[o]=r(e,t,n+1);return a}function n(e,t){var r,n;for(r=new Array(e),n=0;e>n;++n)r[n]=t;return r}function i(e,t){switch("undefined"==typeof t&&(t=0),typeof e){case"number":if(e>0)return n(0|e,t);break;case"object":if("number"==typeof e.length)return r(e,t,0)}return[]}t.exports=i},{}],135:[function(e,t){"use strict";function r(e){for(var t,r,i,a,s,u,c,f,h=n(e[0],!0),d=0,p=80,m=0;p>d&&m=p){t=h.next,r=a=t.p[0],i=s=t.p[1];do u=t.p[0],c=t.p[1],r>u&&(r=u),i>c&&(i=c),u>a&&(a=u),c>s&&(s=c),t=t.next;while(t!==h);f=Math.max(a-r,s-i)}e.length>1&&(h=l(e,h));var g=[];return h&&o(h,g,r,i,f),g}function n(e,t){var r,n,i,o=0,a=e.length;for(r=0,n=a-1;a>r;n=r++){var s=e[r],l=e[n];o+=(l[0]-s[0])*(s[1]+l[1])}if(t===o>0)for(r=0;a>r;r++)i=T(e[r],i);else for(r=a-1;r>=0;r--)i=T(e[r],i);return i}function i(e){var t,r=e;do if(t=!1,v(r.p,r.next.p)||0===g(r.prev.p,r.p,r.next.p)){if(r.prev.next=r.next,r.next.prev=r.prev,r.prevZ&&(r.prevZ.nextZ=r.nextZ),r.nextZ&&(r.nextZ.prevZ=r.prevZ),r=e=r.prev,r===r.next)return null;t=!0}else r=r.next;while(t||r!==e);return e}function o(e,t,r,n,l,u){if(e=i(e)){u||void 0===r||f(e,r,n,l);for(var c,h,d=e;e.prev!==e.next;)if(c=e.prev,h=e.next,a(e,r,n,l))t.push(c.p,e.p,h.p),h.prev=c,c.next=h,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ),e=h.next,d=h.next;else if(e=h,e===d){u?s(e,t,r,n,l):o(e,t,r,n,l,!0);break}}}function a(e,t,r,n){var i=e.prev.p,o=e.p,a=e.next.p,s=i[0],l=o[0],u=a[0],c=i[1],f=o[1],h=a[1],p=s*f-c*l,m=s*h-c*u,g=u*f-h*l,v=p-m-g;if(0>=v)return!1;var _,y,b,x,w,A,T,k=h-c,E=s-u,S=c-f,R=l-s;if(void 0!==t){var M=l>s?u>s?s:u:u>l?l:u,j=f>c?h>c?c:h:h>f?f:h,P=s>l?s>u?s:u:l>u?l:u,z=c>f?c>h?c:h:f>h?f:h,N=d(M,j,t,r,n),O=d(P,z,t,r,n);for(T=e.nextZ;T&&T.z<=O;)if(_=T.p,T=T.nextZ,_!==i&&_!==a&&(y=_[0],b=_[1],x=k*y+E*b-m,x>=0&&(w=S*y+R*b+p,w>=0&&(A=v-x-w,A>=0&&(x&&w||x&&A||w&&A)))))return!1;for(T=e.prevZ;T&&T.z>=N;)if(_=T.p,T=T.prevZ,_!==i&&_!==a&&(y=_[0],b=_[1],x=k*y+E*b-m,x>=0&&(w=S*y+R*b+p,w>=0&&(A=v-x-w,A>=0&&(x&&w||x&&A||w&&A)))))return!1}else for(T=e.next.next;T!==e.prev;)if(_=T.p,T=T.next,y=_[0],b=_[1],x=k*y+E*b-m,x>=0&&(w=S*y+R*b+p,w>=0&&(A=v-x-w,A>=0&&(x&&w||x&&A||w&&A))))return!1;return!0}function s(e,t,r,n,i){var a=e;do{for(var s=a.next.next;s!==a.prev;){if(m(a,s)){var l=A(a,s);return o(a,t,r,n,i),void o(l,t,r,n,i)}s=s.next}a=a.next}while(a!==e)}function l(e,t){for(var r=e.length,o=[],a=1;r>a;a++){var s=i(n(e[a],!1));s&&o.push(p(s))}for(o.sort(w),a=0;a=i[1]){var c=n[0]+(l-n[1])*(i[0]-n[0])/(i[1]-n[1]);s>=c&&c>u&&(u=c,r=n[0]=E?-1:1,R=r,M=1/0;for(o=r.next;o!==R;)f=o.p[0],h=o.p[1],d=s-f,d>=0&&f>=v&&(p=(w*f+A*h-x)*S,p>=0&&(m=(T*f+k*h+y)*S,m>=0&&E*S-p-m>=0&&(g=Math.abs(l-h)/d,M>g&&b(o,e)&&(r=o,M=g)))),o=o.next;return r}function f(e,t,r,n){var i=e;do i.z=i.z||d(i.p[0],i.p[1],t,r,n),i.prevZ=i.prev,i.nextZ=i.next,i=i.next;while(i!==e);i.prevZ.nextZ=null,i.prevZ=null,h(i)}function h(e){for(var t,r,n,i,o,a,s,l,u=1;;){for(r=e,e=null,o=null,a=0;r;){for(a++,n=r,s=0,t=0;u>t&&(s++,n=n.nextZ,n);t++);for(l=u;s>0||l>0&&n;)0===s?(i=n,n=n.nextZ,l--):0!==l&&n?r.z<=n.z?(i=r,r=r.nextZ,s--):(i=n,n=n.nextZ,l--):(i=r,r=r.nextZ,s--),o?o.nextZ=i:e=i,i.prevZ=o,o=i;r=n}if(o.nextZ=null,1>=a)return e;u*=2}}function d(e,t,r,n,i){return e=1e3*(e-r)/i,e=16711935&(e|e<<8),e=252645135&(e|e<<4),e=858993459&(e|e<<2),e=1431655765&(e|e<<1),t=1e3*(t-n)/i,t=16711935&(t|t<<8),t=252645135&(t|t<<4),t=858993459&(t|t<<2),t=1431655765&(t|t<<1),e|t<<1}function p(e){var t=e,r=e;do t.p[0]0?1:0>n?-1:0}function v(e,t){return e[0]===t[0]&&e[1]===t[1]}function _(e,t,r,n){return g(e,t,r)!==g(e,t,n)&&g(r,n,e)!==g(r,n,t)}function y(e,t,r){var n=e;do{var i=n.p,o=n.next.p;if(i!==t&&o!==t&&i!==r&&o!==r&&_(i,o,t,r))return!0;n=n.next}while(n!==e);return!1}function b(e,t){return-1===g(e.prev.p,e.p,e.next.p)?-1!==g(e.p,t.p,e.next.p)&&-1!==g(e.p,e.prev.p,t.p):-1===g(e.p,t.p,e.prev.p)||-1===g(e.p,e.next.p,t.p)}function x(e,t,r){var n=e,i=!1,o=(t[0]+r[0])/2,a=(t[1]+r[1])/2;do{var s=n.p,l=n.next.p;s[1]>a!=l[1]>a&&o<(l[0]-s[0])*(a-s[1])/(l[1]-s[1])+s[0]&&(i=!i),n=n.next}while(n!==e);return i}function w(e,t){return e.p[0]-t.p[0]}function A(e,t){var r=new k(e.p),n=new k(t.p),i=e.next,o=t.prev;return e.next=t,t.prev=e,r.next=i,i.prev=r,n.next=r,r.prev=n,o.next=n,n.prev=o,r}function T(e,t){var r=new k(e);return t?(r.next=t.next,r.prev=t,t.next.prev=r,t.next=r):(r.prev=r,r.next=r),r}function k(e){this.p=e,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null}t.exports=r},{}],136:[function(e,t){"use strict";function r(e,t,r,o,a,s,l,u){if(r/=t,o/=t,l>=r&&o>=u)return e;if(l>o||r>u)return null;for(var c=[],f=0;f=r&&o>=d)c.push(p);else if(!(h>o||r>d)){var v=1===g?n(m,r,o,a):i(m,r,o,a,s,3===g);v.length&&c.push({geometry:v,type:g,tags:e[f].tags||null,min:p.min,max:p.max})}}return c.length?c:null}function n(e,t,r,n){for(var i=[],o=0;o=t&&r>=s&&i.push(a)}return i}function i(e,t,r,n,i,a){for(var s=[],l=0;lc;c++)u=p||m[c],p=m[c+1],h=d||u[n],d=p[n],t>h?d>r?(y.push(i(u,p,t),i(u,p,r)),a||(y=o(s,y,g,v))):d>=t&&y.push(i(u,p,t)):h>r?t>d?(y.push(i(u,p,r),i(u,p,t)),a||(y=o(s,y,g,v))):r>=d&&y.push(i(u,p,r)):(y.push(u),t>d?(y.push(i(u,p,t)),a||(y=o(s,y,g,v))):d>r&&(y.push(i(u,p,r)),a||(y=o(s,y,g,v))));u=m[_-1],h=u[n],h>=t&&r>=h&&y.push(u),f=y[y.length-1],a&&f&&(y[0][0]!==f[0]||y[0][1]!==f[1])&&y.push(y[0]),o(s,y,g,v)}return s}function o(e,t,r,n){return t.length&&(t.area=r,t.dist=n,e.push(t)),[]}t.exports=r},{}],137:[function(e,t){"use strict";function r(e,t){var r=[];if("FeatureCollection"===e.type)for(var i=0;in?-1:n>1?1:n,[r,n,0]}function s(e){for(var t,r,n=0,i=0,o=0;o1)return!1;var a=i.geometry[0].length;if(5!==a)return!1;for(var s=0;a>s;s++){var l=o(i.geometry[0][s],t,e.z2,e.x,e.y);if(l[0]!==-r&&l[0]!==t+r||l[1]!==-r&&l[1]!==t+r)return!1}return!0}t.exports=r;var f=e("./convert"),h=e("./clip"),d=e("./wrap"),p=e("./tile");n.prototype.options={maxZoom:14,indexMaxZoom:5,indexMaxPoints:1e5,solidChildren:!1,tolerance:3,extent:4096,buffer:64,debug:0},n.prototype.splitTile=function(e,t,r,n,i,o,u){for(var f=[e,t,r,n],d=this.options,m=d.debug;f.length;){n=f.pop(),r=f.pop(),t=f.pop(),e=f.pop();var g=1<1&&console.time("creation"),_=this.tiles[v]=p(e,g,r,n,y,t===d.maxZoom),this.tileCoords.push({z:t,x:r,y:n}),m)){m>1&&(console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)",t,r,n,_.numFeatures,_.numPoints,_.numSimplified),console.timeEnd("creation"));var b="z"+t;this.stats[b]=(this.stats[b]||0)+1,this.total++}if(_.source=e,d.solidChildren||!c(_,d.extent,d.buffer)){if(i){if(t===d.maxZoom||t===i)continue;var x=1<1&&console.time("clipping");var w,A,T,k,E,S,R=.5*d.buffer/d.extent,M=.5-R,j=.5+R,P=1+R;w=A=T=k=null,E=h(e,g,r-R,r+j,0,s,_.min[0],_.max[0]),S=h(e,g,r+M,r+P,0,s,_.min[0],_.max[0]),E&&(w=h(E,g,n-R,n+j,1,l,_.min[1],_.max[1]),A=h(E,g,n+M,n+P,1,l,_.min[1],_.max[1])),S&&(T=h(S,g,n-R,n+j,1,l,_.min[1],_.max[1]),k=h(S,g,n+M,n+P,1,l,_.min[1],_.max[1])),m>1&&console.timeEnd("clipping"),w&&f.push(w,t+1,2*r,2*n),A&&f.push(A,t+1,2*r,2*n+1),T&&f.push(T,t+1,2*r+1,2*n),k&&f.push(k,t+1,2*r+1,2*n+1)}}},n.prototype.getTile=function(e,t,r){var n=this.options,o=n.extent,s=n.debug,l=1<1&&console.log("drilling down to z%d-%d-%d",e,t,r);for(var f,h=e,d=t,p=r;!f&&h>0;)h--,d=Math.floor(d/2),p=Math.floor(p/2),f=this.tiles[a(h,d,p)];if(!f)return null;if(s>1&&console.log("found parent tile z%d-%d-%d",h,d,p),f.source){if(c(f,o,n.buffer))return i(f,o);s>1&&console.time("drilling down"),this.splitTile(f.source,h,d,p,e,t,r),s>1&&console.timeEnd("drilling down")}return this.tiles[u]?i(this.tiles[u],o):null}},{"./clip":136,"./convert":137,"./tile":140,"./wrap":141}],139:[function(e,t){"use strict";function r(e,t){var r,i,o,a,s=t*t,l=e.length,u=0,c=l-1,f=[];for(e[u][2]=1,e[c][2]=1;c;){for(i=0,r=u+1;c>r;r++)o=n(e[r],e[u],e[c]),o>i&&(a=r,i=o);i>s?(e[a][2]=i,f.push(u),f.push(a),u=a):(c=f.pop(),u=f.pop())}}function n(e,t,r){var n=t[0],i=t[1],o=r[0],a=r[1],s=e[0],l=e[1],u=o-n,c=a-i;if(0!==u||0!==c){var f=((s-n)*u+(l-i)*c)/(u*u+c*c);f>1?(n=o,i=a):f>0&&(n+=u*f,i+=c*f)}return u=s-n,c=l-i,u*u+c*c}t.exports=r},{}],140:[function(e,t){"use strict";function r(e,t,r,i,o,a){for(var s={features:[],numPoints:0,numSimplified:0,numFeatures:0,source:null,x:r,y:i,z2:t,transformed:!1,min:[2,1],max:[-1,0]},l=0;ls.max[0]&&(s.max[0]=c[0]),c[1]>s.max[1]&&(s.max[1]=c[1])}return s}function n(e,t,r,n){var i,o,a,s,l=t.geometry,u=t.type,c=[],f=r*r;if(1===u)for(i=0;if)&&(h.push(s),e.numSimplified++),e.numPoints++;c.push(h)}else e.numPoints+=a.length;c.length&&e.features.push({geometry:c,type:u,tags:t.tags||null})}t.exports=r},{}],141:[function(e,t){"use strict";function r(e,t,r){var i=e,a=o(e,1,-1-t,t,0,r,-1,2),s=o(e,1,1-t,2+t,0,r,-1,2);return(a||s)&&(i=o(e,1,-t,1+t,0,r,-1,2),a&&(i=n(a,1).concat(i)),s&&(i=i.concat(n(s,-1)))),i}function n(e,t){for(var r=[],n=0;n>1,c=-7,f=r?i-1:0,h=r?-1:1,d=e[t+f];for(f+=h,o=d&(1<<-c)-1,d>>=-c,c+=s;c>0;o=256*o+e[t+f],f+=h,c-=8);for(a=o&(1<<-c)-1,o>>=-c,c+=n;c>0;a=256*a+e[t+f],f+=h,c-=8);if(0===o)o=1-u;else{if(o===l)return a?0/0:1/0*(d?-1:1);a+=Math.pow(2,n),o-=u}return(d?-1:1)*a*Math.pow(2,o-n)},r.write=function(e,t,r,n,i,o){var a,s,l,u=8*o-i-1,c=(1<>1,h=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,d=n?0:o-1,p=n?1:-1,m=0>t||0===t&&0>1/t?1:0;for(t=Math.abs(t),isNaN(t)||1/0===t?(s=isNaN(t)?1:0,a=c):(a=Math.floor(Math.log(t)/Math.LN2),t*(l=Math.pow(2,-a))<1&&(a--,l*=2),t+=a+f>=1?h/l:h*Math.pow(2,1-f),t*l>=2&&(a++,l/=2),a+f>=c?(s=0,a=c):a+f>=1?(s=(t*l-1)*Math.pow(2,i),a+=f):(s=t*Math.pow(2,f-1)*Math.pow(2,i),a=0));i>=8;e[r+d]=255&s,d+=p,s/=256,i-=8);for(a=a<0;e[r+d]=255&a,d+=p,a/=256,u-=8);e[r+d-p]|=128*m}},{}],153:[function(e,t){var r=Array.isArray,n=Object.prototype.toString;t.exports=r||function(e){return!!e&&"[object Array]"==n.call(e)}},{}],154:[function(e,t){"use strict";var r=e("./lib/js-yaml.js");t.exports=r},{"./lib/js-yaml.js":155}],155:[function(e,t){"use strict";function r(e){return function(){throw new Error("Function "+e+" is deprecated and cannot be used.")}}var n=e("./js-yaml/loader");t.exports.Type=e("./js-yaml/type"),t.exports.Schema=e("./js-yaml/schema"),t.exports.FAILSAFE_SCHEMA=e("./js-yaml/schema/failsafe"),t.exports.JSON_SCHEMA=e("./js-yaml/schema/json"),t.exports.CORE_SCHEMA=e("./js-yaml/schema/core"),t.exports.DEFAULT_SAFE_SCHEMA=e("./js-yaml/schema/default_safe"),t.exports.DEFAULT_FULL_SCHEMA=e("./js-yaml/schema/default_full"),t.exports.load=n.load,t.exports.loadAll=n.loadAll,t.exports.safeLoad=n.safeLoad,t.exports.safeLoadAll=n.safeLoadAll,t.exports.YAMLException=e("./js-yaml/exception"),t.exports.MINIMAL_SCHEMA=e("./js-yaml/schema/failsafe"),t.exports.SAFE_SCHEMA=e("./js-yaml/schema/default_safe"),t.exports.DEFAULT_SCHEMA=e("./js-yaml/schema/default_full"),t.exports.scan=r("scan"),t.exports.parse=r("parse"),t.exports.compose=r("compose"),t.exports.addConstructor=r("addConstructor")},{"./js-yaml/exception":157,"./js-yaml/loader":158,"./js-yaml/schema":160,"./js-yaml/schema/core":161,"./js-yaml/schema/default_full":162,"./js-yaml/schema/default_safe":163,"./js-yaml/schema/failsafe":164,"./js-yaml/schema/json":165,"./js-yaml/type":166}],156:[function(e,t){"use strict";function r(e){return"undefined"==typeof e||null===e}function n(e){return"object"==typeof e&&null!==e}function i(e){return Array.isArray(e)?e:r(e)?[]:[e]}function o(e,t){var r,n,i,o;if(t)for(o=Object.keys(t),r=0,n=o.length;n>r;r+=1)i=o[r],e[i]=t[i];return e}function a(e,t){var r,n="";for(r=0;t>r;r+=1)n+=e;return n}function s(e){return 0===e&&Number.NEGATIVE_INFINITY===1/e}t.exports.isNothing=r,t.exports.isObject=n,t.exports.toArray=i,t.exports.repeat=a,t.exports.isNegativeZero=s,t.exports.extend=o},{}],157:[function(e,t){"use strict";function r(e,t){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=(new Error).stack||"",this.name="YAMLException",this.reason=e,this.mark=t,this.message=(this.reason||"(unknown reason)")+(this.mark?" "+this.mark.toString():"")}r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r.prototype.toString=function(e){var t=this.name+": ";return t+=this.reason||"(unknown reason)",!e&&this.mark&&(t+=" "+this.mark.toString()),t},t.exports=r},{}],158:[function(e,t){"use strict";function r(e){return 10===e||13===e}function n(e){return 9===e||32===e}function i(e){return 9===e||32===e||10===e||13===e}function o(e){return 44===e||91===e||93===e||123===e||125===e}function a(e){var t;return e>=48&&57>=e?e-48:(t=32|e,t>=97&&102>=t?t-97+10:-1)}function s(e){return 120===e?2:117===e?4:85===e?8:0}function l(e){return e>=48&&57>=e?e-48:-1}function u(e){return 48===e?"\x00":97===e?"":98===e?"\b":116===e?" ":9===e?" ":110===e?"\n":118===e?" ":102===e?"\f":114===e?"\r":101===e?"":32===e?" ":34===e?'"':47===e?"/":92===e?"\\":78===e?"…":95===e?" ":76===e?"\u2028":80===e?"\u2029":""}function c(e){return 65535>=e?String.fromCharCode(e):String.fromCharCode((e-65536>>10)+55296,(e-65536&1023)+56320)}function f(e,t){this.input=e,this.filename=t.filename||null,this.schema=t.schema||B,this.onWarning=t.onWarning||null,this.legacy=t.legacy||!1,this.json=t.json||!1,this.listener=t.listener||null,this.implicitTypes=this.schema.compiledImplicit,this.typeMap=this.schema.compiledTypeMap,this.length=e.length,this.position=0,this.line=0,this.lineStart=0,this.lineIndent=0,this.documents=[]}function h(e,t){return new $(t,new C(e.filename,e.input,e.position,e.line,e.position-e.lineStart))}function d(e,t){throw h(e,t)}function p(e,t){e.onWarning&&e.onWarning.call(null,h(e,t))}function m(e,t,r,n){var i,o,a,s;if(r>t){if(s=e.input.slice(t,r),n)for(i=0,o=s.length;o>i;i+=1)a=s.charCodeAt(i),9===a||a>=32&&1114111>=a||d(e,"expected valid JSON character");else K.test(s)&&d(e,"the stream contains non-printable characters");e.result+=s}}function g(e,t,r,n){var i,o,a,s;for(D.isObject(r)||d(e,"cannot merge mappings; the provided source object is unacceptable"),i=Object.keys(r),a=0,s=i.length;s>a;a+=1)o=i[a],q.call(t,o)||(t[o]=r[o],n[o]=!0)}function v(e,t,r,n,i,o){var a,s;if(i=String(i),null===t&&(t={}),"tag:yaml.org,2002:merge"===n)if(Array.isArray(o))for(a=0,s=o.length;s>a;a+=1)g(e,t,o[a],r);else g(e,t,o,r);else e.json||q.call(r,i)||!q.call(t,i)||d(e,"duplicated mapping key"),t[i]=o,delete r[i];return t}function _(e){var t;t=e.input.charCodeAt(e.position),10===t?e.position++:13===t?(e.position++,10===e.input.charCodeAt(e.position)&&e.position++):d(e,"a line break is expected"),e.line+=1,e.lineStart=e.position}function y(e,t,i){for(var o=0,a=e.input.charCodeAt(e.position);0!==a;){for(;n(a);)a=e.input.charCodeAt(++e.position);if(t&&35===a)do a=e.input.charCodeAt(++e.position);while(10!==a&&13!==a&&0!==a);if(!r(a))break;for(_(e),a=e.input.charCodeAt(e.position),o++,e.lineIndent=0;32===a;)e.lineIndent++,a=e.input.charCodeAt(++e.position)}return-1!==i&&0!==o&&e.lineIndent1&&(e.result+=D.repeat("\n",t-1))}function w(e,t,a){var s,l,u,c,f,h,d,p,g,v=e.kind,_=e.result;if(g=e.input.charCodeAt(e.position),i(g)||o(g)||35===g||38===g||42===g||33===g||124===g||62===g||39===g||34===g||37===g||64===g||96===g)return!1;if((63===g||45===g)&&(l=e.input.charCodeAt(e.position+1),i(l)||a&&o(l)))return!1;for(e.kind="scalar",e.result="",u=c=e.position,f=!1;0!==g;){if(58===g){if(l=e.input.charCodeAt(e.position+1),i(l)||a&&o(l))break}else if(35===g){if(s=e.input.charCodeAt(e.position-1),i(s))break}else{if(e.position===e.lineStart&&b(e)||a&&o(g))break;if(r(g)){if(h=e.line,d=e.lineStart,p=e.lineIndent,y(e,!1,-1),e.lineIndent>=t){f=!0,g=e.input.charCodeAt(e.position);continue}e.position=c,e.line=h,e.lineStart=d,e.lineIndent=p;break}}f&&(m(e,u,c,!1),x(e,e.line-h),u=c=e.position,f=!1),n(g)||(c=e.position+1),g=e.input.charCodeAt(++e.position)}return m(e,u,c,!1),e.result?!0:(e.kind=v,e.result=_,!1)}function A(e,t){var n,i,o;if(n=e.input.charCodeAt(e.position),39!==n)return!1;for(e.kind="scalar",e.result="",e.position++,i=o=e.position;0!==(n=e.input.charCodeAt(e.position));)if(39===n){if(m(e,i,e.position,!0),n=e.input.charCodeAt(++e.position),39!==n)return!0;i=o=e.position,e.position++}else r(n)?(m(e,i,o,!0),x(e,y(e,!1,t)),i=o=e.position):e.position===e.lineStart&&b(e)?d(e,"unexpected end of the document within a single quoted scalar"):(e.position++,o=e.position);d(e,"unexpected end of the stream within a single quoted scalar")}function T(e,t){var n,i,o,l,u,f;if(f=e.input.charCodeAt(e.position),34!==f)return!1;for(e.kind="scalar",e.result="",e.position++,n=i=e.position;0!==(f=e.input.charCodeAt(e.position));){if(34===f)return m(e,n,e.position,!0),e.position++,!0;if(92===f){if(m(e,n,e.position,!0),f=e.input.charCodeAt(++e.position),r(f))y(e,!1,t);else if(256>f&&nt[f])e.result+=it[f],e.position++;else if((u=s(f))>0){for(o=u,l=0;o>0;o--)f=e.input.charCodeAt(++e.position),(u=a(f))>=0?l=(l<<4)+u:d(e,"expected hexadecimal character");e.result+=c(l),e.position++}else d(e,"unknown escape sequence");n=i=e.position}else r(f)?(m(e,n,i,!0),x(e,y(e,!1,t)),n=i=e.position):e.position===e.lineStart&&b(e)?d(e,"unexpected end of the document within a double quoted scalar"):(e.position++,i=e.position)}d(e,"unexpected end of the stream within a double quoted scalar")}function k(e,t){var r,n,o,a,s,l,u,c,f,h,p,m=!0,g=e.tag,_=e.anchor,b={};if(p=e.input.charCodeAt(e.position),91===p)a=93,u=!1,n=[];else{if(123!==p)return!1;a=125,u=!0,n={}}for(null!==e.anchor&&(e.anchorMap[e.anchor]=n),p=e.input.charCodeAt(++e.position);0!==p;){if(y(e,!0,t),p=e.input.charCodeAt(e.position),p===a)return e.position++,e.tag=g,e.anchor=_,e.kind=u?"mapping":"sequence",e.result=n,!0;m||d(e,"missed comma between flow collection entries"),f=c=h=null,s=l=!1,63===p&&(o=e.input.charCodeAt(e.position+1),i(o)&&(s=l=!0,e.position++,y(e,!0,t))),r=e.line,z(e,t,V,!1,!0),f=e.tag,c=e.result,y(e,!0,t),p=e.input.charCodeAt(e.position),!l&&e.line!==r||58!==p||(s=!0,p=e.input.charCodeAt(++e.position),y(e,!0,t),z(e,t,V,!1,!0),h=e.result),u?v(e,n,b,f,c,h):n.push(s?v(e,null,b,f,c,h):c),y(e,!0,t),p=e.input.charCodeAt(e.position),44===p?(m=!0,p=e.input.charCodeAt(++e.position)):m=!1}d(e,"unexpected end of the stream within a flow collection")}function E(e,t){var i,o,a,s,u=Z,c=!1,f=t,h=0,p=!1;if(s=e.input.charCodeAt(e.position),124===s)o=!1;else{if(62!==s)return!1;o=!0}for(e.kind="scalar",e.result="";0!==s;)if(s=e.input.charCodeAt(++e.position),43===s||45===s)Z===u?u=43===s?J:Y:d(e,"repeat of a chomping mode identifier");else{if(!((a=l(s))>=0))break;0===a?d(e,"bad explicit indentation width of a block scalar; it cannot be less than one"):c?d(e,"repeat of an indentation width identifier"):(f=t+a-1,c=!0)}if(n(s)){do s=e.input.charCodeAt(++e.position);while(n(s));if(35===s)do s=e.input.charCodeAt(++e.position);while(!r(s)&&0!==s)}for(;0!==s;){for(_(e),e.lineIndent=0,s=e.input.charCodeAt(e.position);(!c||e.lineIndentf&&(f=e.lineIndent),r(s))h++;else{if(e.lineIndentt)&&0!==o)d(e,"bad indentation of a sequence entry");else if(e.lineIndentt)&&(z(e,t,X,!0,a)&&(_?m=e.result:g=e.result),_||(v(e,f,h,p,m,g),p=m=g=null),y(e,!0,-1),l=e.input.charCodeAt(e.position)),e.lineIndent>t&&0!==l)d(e,"bad indentation of a mapping entry");else if(e.lineIndentt?p=1:e.lineIndent===t?p=0:e.lineIndentt?p=1:e.lineIndent===t?p=0:e.lineIndentl;l+=1)if(c=e.implicitTypes[l],c.resolve(e.result)){e.result=c.construct(e.result),e.tag=c.tag,null!==e.anchor&&(e.anchorMap[e.anchor]=e.result);break}}else q.call(e.typeMap,e.tag)?(c=e.typeMap[e.tag],null!==e.result&&c.kind!==e.kind&&d(e,"unacceptable node kind for !<"+e.tag+'> tag; it should be "'+c.kind+'", not "'+e.kind+'"'),c.resolve(e.result)?(e.result=c.construct(e.result),null!==e.anchor&&(e.anchorMap[e.anchor]=e.result)):d(e,"cannot resolve a node with !<"+e.tag+"> explicit tag")):d(e,"unknown tag !<"+e.tag+">");return null!==e.listener&&e.listener("close",e),null!==e.tag||null!==e.anchor||g}function N(e){var t,o,a,s,l=e.position,u=!1;for(e.version=null,e.checkLineBreaks=e.legacy,e.tagMap={},e.anchorMap={};0!==(s=e.input.charCodeAt(e.position))&&(y(e,!0,-1),s=e.input.charCodeAt(e.position),!(e.lineIndent>0||37!==s));){for(u=!0,s=e.input.charCodeAt(++e.position),t=e.position;0!==s&&!i(s);)s=e.input.charCodeAt(++e.position);for(o=e.input.slice(t,e.position),a=[],o.length<1&&d(e,"directive name must not be less than one character in length");0!==s;){for(;n(s);)s=e.input.charCodeAt(++e.position);if(35===s){do s=e.input.charCodeAt(++e.position);while(0!==s&&!r(s));break}if(r(s))break;for(t=e.position;0!==s&&!i(s);)s=e.input.charCodeAt(++e.position);a.push(e.input.slice(t,e.position))}0!==s&&_(e),q.call(at,o)?at[o](e,o,a):p(e,'unknown document directive "'+o+'"')}return y(e,!0,-1),0===e.lineIndent&&45===e.input.charCodeAt(e.position)&&45===e.input.charCodeAt(e.position+1)&&45===e.input.charCodeAt(e.position+2)?(e.position+=3,y(e,!0,-1)):u&&d(e,"directives end mark is expected"),z(e,e.lineIndent-1,X,!1,!0),y(e,!0,-1),e.checkLineBreaks&&Q.test(e.input.slice(l,e.position))&&p(e,"non-ASCII line breaks are interpreted as content"),e.documents.push(e.result),e.position===e.lineStart&&b(e)?void(46===e.input.charCodeAt(e.position)&&(e.position+=3,y(e,!0,-1))):void(e.positionn;n+=1)t(o[n])}function I(e,t){var r=O(e,t);if(0===r.length)return void 0;if(1===r.length)return r[0];throw new $("expected a single document in the stream, but found more")}function U(e,t,r){L(e,t,D.extend({schema:G},r))}function F(e,t){return I(e,D.extend({schema:G},t))}for(var D=e("./common"),$=e("./exception"),C=e("./mark"),G=e("./schema/default_safe"),B=e("./schema/default_full"),q=Object.prototype.hasOwnProperty,V=1,W=2,H=3,X=4,Z=1,Y=2,J=3,K=/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/,Q=/[\x85\u2028\u2029]/,et=/[,\[\]\{\}]/,tt=/^(?:!|!!|![a-z\-]+!)$/i,rt=/^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i,nt=new Array(256),it=new Array(256),ot=0;256>ot;ot++)nt[ot]=u(ot)?1:0,it[ot]=u(ot);var at={YAML:function(e,t,r){var n,i,o;null!==e.version&&d(e,"duplication of %YAML directive"),1!==r.length&&d(e,"YAML directive accepts exactly one argument"),n=/^([0-9]+)\.([0-9]+)$/.exec(r[0]),null===n&&d(e,"ill-formed argument of the YAML directive"),i=parseInt(n[1],10),o=parseInt(n[2],10),1!==i&&d(e,"unacceptable YAML version of the document"),e.version=r[0],e.checkLineBreaks=2>o,1!==o&&2!==o&&p(e,"unsupported YAML version of the document")},TAG:function(e,t,r){var n,i;2!==r.length&&d(e,"TAG directive accepts exactly two arguments"),n=r[0],i=r[1],tt.test(n)||d(e,"ill-formed tag handle (first argument) of the TAG directive"),q.call(e.tagMap,n)&&d(e,'there is a previously declared suffix for "'+n+'" tag handle'),rt.test(i)||d(e,"ill-formed tag prefix (second argument) of the TAG directive"),e.tagMap[n]=i}};t.exports.loadAll=L,t.exports.load=I,t.exports.safeLoadAll=U,t.exports.safeLoad=F},{"./common":156,"./exception":157,"./mark":159,"./schema/default_full":162,"./schema/default_safe":163}],159:[function(e,t){"use strict";function r(e,t,r,n,i){this.name=e,this.buffer=t,this.position=r,this.line=n,this.column=i}var n=e("./common");r.prototype.getSnippet=function(e,t){var r,i,o,a,s;if(!this.buffer)return null;for(e=e||4,t=t||75,r="",i=this.position;i>0&&-1==="\x00\r\n…\u2028\u2029".indexOf(this.buffer.charAt(i-1));)if(i-=1,this.position-i>t/2-1){r=" ... ",i+=5;break}for(o="",a=this.position;at/2-1){o=" ... ",a-=5;break}return s=this.buffer.slice(i,a),n.repeat(" ",e)+r+s+o+"\n"+n.repeat(" ",e+this.position-i+r.length)+"^"},r.prototype.toString=function(e){var t,r="";return this.name&&(r+='in "'+this.name+'" '),r+="at line "+(this.line+1)+", column "+(this.column+1),e||(t=this.getSnippet(),t&&(r+=":\n"+t)),r},t.exports=r},{"./common":156}],160:[function(e,t){"use strict";function r(e,t,n){var i=[];return e.include.forEach(function(e){n=r(e,t,n)}),e[t].forEach(function(e){n.forEach(function(t,r){t.tag===e.tag&&i.push(r)}),n.push(e)}),n.filter(function(e,t){return-1===i.indexOf(t)})}function n(){function e(e){n[e.tag]=e}var t,r,n={};for(t=0,r=arguments.length;r>t;t+=1)arguments[t].forEach(e);return n}function i(e){this.include=e.include||[],this.implicit=e.implicit||[],this.explicit=e.explicit||[],this.implicit.forEach(function(e){if(e.loadKind&&"scalar"!==e.loadKind)throw new a("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.")}),this.compiledImplicit=r(this,"implicit",[]),this.compiledExplicit=r(this,"explicit",[]),this.compiledTypeMap=n(this.compiledImplicit,this.compiledExplicit)}var o=e("./common"),a=e("./exception"),s=e("./type");i.DEFAULT=null,i.create=function(){var e,t;switch(arguments.length){case 1:e=i.DEFAULT,t=arguments[0];break;case 2:e=arguments[0],t=arguments[1];break;default:throw new a("Wrong number of arguments for Schema.create function")}if(e=o.toArray(e),t=o.toArray(t),!e.every(function(e){return e instanceof i}))throw new a("Specified list of super schemas (or a single Schema object) contains a non-Schema object.");if(!t.every(function(e){return e instanceof s}))throw new a("Specified list of YAML types (or a single Type object) contains a non-Type object.");return new i({include:e,explicit:t})},t.exports=i},{"./common":156,"./exception":157,"./type":166}],161:[function(e,t){"use strict";var r=e("../schema");t.exports=new r({include:[e("./json")]})},{"../schema":160,"./json":165}],162:[function(e,t){"use strict";var r=e("../schema");t.exports=r.DEFAULT=new r({include:[e("./default_safe")],explicit:[e("../type/js/undefined"),e("../type/js/regexp"),e("../type/js/function")]})},{"../schema":160,"../type/js/function":171,"../type/js/regexp":172,"../type/js/undefined":173,"./default_safe":163}],163:[function(e,t){"use strict";var r=e("../schema");t.exports=new r({include:[e("./core")],implicit:[e("../type/timestamp"),e("../type/merge")],explicit:[e("../type/binary"),e("../type/omap"),e("../type/pairs"),e("../type/set")]})},{"../schema":160,"../type/binary":167,"../type/merge":175,"../type/omap":177,"../type/pairs":178,"../type/set":180,"../type/timestamp":182,"./core":161}],164:[function(e,t){"use strict";var r=e("../schema");t.exports=new r({explicit:[e("../type/str"),e("../type/seq"),e("../type/map")]})},{"../schema":160,"../type/map":174,"../type/seq":179,"../type/str":181}],165:[function(e,t){"use strict";var r=e("../schema");t.exports=new r({include:[e("./failsafe")],implicit:[e("../type/null"),e("../type/bool"),e("../type/int"),e("../type/float")]})},{"../schema":160,"../type/bool":168,"../type/float":169,"../type/int":170,"../type/null":176,"./failsafe":164}],166:[function(e,t){"use strict";function r(e){var t={};return null!==e&&Object.keys(e).forEach(function(r){e[r].forEach(function(e){t[String(e)]=r})}),t}function n(e,t){if(t=t||{},Object.keys(t).forEach(function(t){if(-1===o.indexOf(t))throw new i('Unknown option "'+t+'" is met in definition of "'+e+'" YAML type.')}),this.tag=e,this.kind=t.kind||null,this.resolve=t.resolve||function(){return!0},this.construct=t.construct||function(e){return e},this.instanceOf=t.instanceOf||null,this.predicate=t.predicate||null,this.represent=t.represent||null,this.defaultStyle=t.defaultStyle||null,this.styleAliases=r(t.styleAliases||null),-1===a.indexOf(this.kind))throw new i('Unknown kind "'+this.kind+'" is specified for "'+e+'" YAML type.')}var i=e("./exception"),o=["kind","resolve","construct","instanceOf","predicate","represent","defaultStyle","styleAliases"],a=["scalar","sequence","mapping"];t.exports=n},{"./exception":157}],167:[function(e,t){"use strict";function r(e){if(null===e)return!1;var t,r,n=0,i=e.length,o=l;for(r=0;i>r;r++)if(t=o.indexOf(e.charAt(r)),!(t>64)){if(0>t)return!1;n+=6}return n%8===0}function n(e){var t,r,n=e.replace(/[\r\n=]/g,""),i=n.length,o=l,s=0,u=[];for(t=0;i>t;t++)t%4===0&&t&&(u.push(s>>16&255),u.push(s>>8&255),u.push(255&s)),s=s<<6|o.indexOf(n.charAt(t));return r=i%4*6,0===r?(u.push(s>>16&255),u.push(s>>8&255),u.push(255&s)):18===r?(u.push(s>>10&255),u.push(s>>2&255)):12===r&&u.push(s>>4&255),a?new a(u):u}function i(e){var t,r,n="",i=0,o=e.length,a=l;for(t=0;o>t;t++)t%3===0&&t&&(n+=a[i>>18&63],n+=a[i>>12&63],n+=a[i>>6&63],n+=a[63&i]),i=(i<<8)+e[t];return r=o%3,0===r?(n+=a[i>>18&63],n+=a[i>>12&63],n+=a[i>>6&63],n+=a[63&i]):2===r?(n+=a[i>>10&63],n+=a[i>>4&63],n+=a[i<<2&63],n+=a[64]):1===r&&(n+=a[i>>2&63],n+=a[i<<4&63],n+=a[64],n+=a[64]),n}function o(e){return a&&a.isBuffer(e)}var a=e("buffer").Buffer,s=e("../type"),l="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n\r";t.exports=new s("tag:yaml.org,2002:binary",{kind:"scalar",resolve:r,construct:n,predicate:o,represent:i})},{"../type":166,buffer:37}],168:[function(e,t){"use strict";function r(e){if(null===e)return!1;var t=e.length;return 4===t&&("true"===e||"True"===e||"TRUE"===e)||5===t&&("false"===e||"False"===e||"FALSE"===e)}function n(e){return"true"===e||"True"===e||"TRUE"===e}function i(e){return"[object Boolean]"===Object.prototype.toString.call(e)}var o=e("../type");t.exports=new o("tag:yaml.org,2002:bool",{kind:"scalar",resolve:r,construct:n,predicate:i,represent:{lowercase:function(e){return e?"true":"false"},uppercase:function(e){return e?"TRUE":"FALSE"},camelcase:function(e){return e?"True":"False"}},defaultStyle:"lowercase"})},{"../type":166}],169:[function(e,t){"use strict";function r(e){return null===e?!1:l.test(e)?!0:!1}function n(e){var t,r,n,i;return t=e.replace(/_/g,"").toLowerCase(),r="-"===t[0]?-1:1,i=[],"+-".indexOf(t[0])>=0&&(t=t.slice(1)),".inf"===t?1===r?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY:".nan"===t?0/0:t.indexOf(":")>=0?(t.split(":").forEach(function(e){i.unshift(parseFloat(e,10))}),t=0,n=1,i.forEach(function(e){t+=e*n,n*=60}),r*t):r*parseFloat(t,10)}function i(e,t){var r;if(isNaN(e))switch(t){case"lowercase":return".nan";case"uppercase":return".NAN";case"camelcase":return".NaN"}else if(Number.POSITIVE_INFINITY===e)switch(t){case"lowercase":return".inf";case"uppercase":return".INF";case"camelcase":return".Inf"}else if(Number.NEGATIVE_INFINITY===e)switch(t){case"lowercase":return"-.inf";case"uppercase":return"-.INF";case"camelcase":return"-.Inf"}else if(a.isNegativeZero(e))return"-0.0";return r=e.toString(10),u.test(r)?r.replace("e",".e"):r}function o(e){return"[object Number]"===Object.prototype.toString.call(e)&&(e%1!==0||a.isNegativeZero(e))}var a=e("../common"),s=e("../type"),l=new RegExp("^(?:[-+]?(?:[0-9][0-9_]*)\\.[0-9_]*(?:[eE][-+][0-9]+)?|\\.[0-9_]+(?:[eE][-+][0-9]+)?|[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+\\.[0-9_]*|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$"),u=/^[-+]?[0-9]+e/;t.exports=new s("tag:yaml.org,2002:float",{kind:"scalar",resolve:r,construct:n,predicate:o,represent:i,defaultStyle:"lowercase"})},{"../common":156,"../type":166}],170:[function(e,t){"use strict";function r(e){return e>=48&&57>=e||e>=65&&70>=e||e>=97&&102>=e}function n(e){return e>=48&&55>=e}function i(e){return e>=48&&57>=e}function o(e){if(null===e)return!1;var t,o=e.length,a=0,s=!1;if(!o)return!1;if(t=e[a],("-"===t||"+"===t)&&(t=e[++a]),"0"===t){if(a+1===o)return!0;if(t=e[++a],"b"===t){for(a++;o>a;a++)if(t=e[a],"_"!==t){if("0"!==t&&"1"!==t)return!1;s=!0}return s}if("x"===t){for(a++;o>a;a++)if(t=e[a],"_"!==t){if(!r(e.charCodeAt(a)))return!1;s=!0}return s}for(;o>a;a++)if(t=e[a],"_"!==t){if(!n(e.charCodeAt(a)))return!1;s=!0}return s}for(;o>a;a++)if(t=e[a],"_"!==t){if(":"===t)break;if(!i(e.charCodeAt(a)))return!1;s=!0}return s?":"!==t?!0:/^(:[0-5]?[0-9])+$/.test(e.slice(a)):!1}function a(e){var t,r,n=e,i=1,o=[];return-1!==n.indexOf("_")&&(n=n.replace(/_/g,"")),t=n[0],("-"===t||"+"===t)&&("-"===t&&(i=-1),n=n.slice(1),t=n[0]),"0"===n?0:"0"===t?"b"===n[1]?i*parseInt(n.slice(2),2):"x"===n[1]?i*parseInt(n,16):i*parseInt(n,8):-1!==n.indexOf(":")?(n.split(":").forEach(function(e){o.unshift(parseInt(e,10))}),n=0,r=1,o.forEach(function(e){n+=e*r,r*=60}),i*n):i*parseInt(n,10)}function s(e){return"[object Number]"===Object.prototype.toString.call(e)&&e%1===0&&!l.isNegativeZero(e)}var l=e("../common"),u=e("../type");t.exports=new u("tag:yaml.org,2002:int",{kind:"scalar",resolve:o,construct:a,predicate:s,represent:{binary:function(e){return"0b"+e.toString(2)},octal:function(e){return"0"+e.toString(8)},decimal:function(e){return e.toString(10)},hexadecimal:function(e){return"0x"+e.toString(16).toUpperCase()}},defaultStyle:"decimal",styleAliases:{binary:[2,"bin"],octal:[8,"oct"],decimal:[10,"dec"],hexadecimal:[16,"hex"]}})},{"../common":156,"../type":166}],171:[function(e,t){"use strict";function r(e){if(null===e)return!1;try{var t="("+e+")",r=a.parse(t,{range:!0});return"Program"!==r.type||1!==r.body.length||"ExpressionStatement"!==r.body[0].type||"FunctionExpression"!==r.body[0].expression.type?!1:!0}catch(n){return!1}}function n(e){var t,r="("+e+")",n=a.parse(r,{range:!0}),i=[];if("Program"!==n.type||1!==n.body.length||"ExpressionStatement"!==n.body[0].type||"FunctionExpression"!==n.body[0].expression.type)throw new Error("Failed to resolve function");return n.body[0].expression.params.forEach(function(e){i.push(e.name)}),t=n.body[0].expression.body.range,new Function(i,r.slice(t[0]+1,t[1]-1))}function i(e){return e.toString()}function o(e){return"[object Function]"===Object.prototype.toString.call(e)}var a;try{var s=e;a=s("esprima")}catch(l){"undefined"!=typeof window&&(a=window.esprima)}var u=e("../../type");t.exports=new u("tag:yaml.org,2002:js/function",{kind:"scalar",resolve:r,construct:n,predicate:o,represent:i})},{"../../type":166}],172:[function(e,t){"use strict";function r(e){if(null===e)return!1;if(0===e.length)return!1;var t=e,r=/\/([gim]*)$/.exec(e),n="";if("/"===t[0]){if(r&&(n=r[1]),n.length>3)return!1;if("/"!==t[t.length-n.length-1])return!1}return!0}function n(e){var t=e,r=/\/([gim]*)$/.exec(e),n="";return"/"===t[0]&&(r&&(n=r[1]),t=t.slice(1,t.length-n.length-1)),new RegExp(t,n)}function i(e){var t="/"+e.source+"/";return e.global&&(t+="g"),e.multiline&&(t+="m"),e.ignoreCase&&(t+="i"),t}function o(e){return"[object RegExp]"===Object.prototype.toString.call(e)}var a=e("../../type");t.exports=new a("tag:yaml.org,2002:js/regexp",{kind:"scalar",resolve:r,construct:n,predicate:o,represent:i})},{"../../type":166}],173:[function(e,t){"use strict";function r(){return!0}function n(){return void 0}function i(){return""}function o(e){return"undefined"==typeof e}var a=e("../../type");t.exports=new a("tag:yaml.org,2002:js/undefined",{kind:"scalar",resolve:r,construct:n,predicate:o,represent:i})},{"../../type":166}],174:[function(e,t){"use strict";var r=e("../type");t.exports=new r("tag:yaml.org,2002:map",{kind:"mapping",construct:function(e){return null!==e?e:{}}})},{"../type":166}],175:[function(e,t){"use strict";function r(e){return"<<"===e||null===e}var n=e("../type");t.exports=new n("tag:yaml.org,2002:merge",{kind:"scalar",resolve:r})},{"../type":166}],176:[function(e,t){"use strict";function r(e){if(null===e)return!0;var t=e.length;return 1===t&&"~"===e||4===t&&("null"===e||"Null"===e||"NULL"===e)}function n(){return null}function i(e){return null===e}var o=e("../type");t.exports=new o("tag:yaml.org,2002:null",{kind:"scalar",resolve:r,construct:n,predicate:i,represent:{canonical:function(){return"~"},lowercase:function(){return"null"},uppercase:function(){return"NULL"},camelcase:function(){return"Null"}},defaultStyle:"lowercase"}) },{"../type":166}],177:[function(e,t){"use strict";function r(e){if(null===e)return!0;var t,r,n,i,s,l=[],u=e;for(t=0,r=u.length;r>t;t+=1){if(n=u[t],s=!1,"[object Object]"!==a.call(n))return!1;for(i in n)if(o.call(n,i)){if(s)return!1;s=!0}if(!s)return!1;if(-1!==l.indexOf(i))return!1;l.push(i)}return!0}function n(e){return null!==e?e:[]}var i=e("../type"),o=Object.prototype.hasOwnProperty,a=Object.prototype.toString;t.exports=new i("tag:yaml.org,2002:omap",{kind:"sequence",resolve:r,construct:n})},{"../type":166}],178:[function(e,t){"use strict";function r(e){if(null===e)return!0;var t,r,n,i,a,s=e;for(a=new Array(s.length),t=0,r=s.length;r>t;t+=1){if(n=s[t],"[object Object]"!==o.call(n))return!1;if(i=Object.keys(n),1!==i.length)return!1;a[t]=[i[0],n[i[0]]]}return!0}function n(e){if(null===e)return[];var t,r,n,i,o,a=e;for(o=new Array(a.length),t=0,r=a.length;r>t;t+=1)n=a[t],i=Object.keys(n),o[t]=[i[0],n[i[0]]];return o}var i=e("../type"),o=Object.prototype.toString;t.exports=new i("tag:yaml.org,2002:pairs",{kind:"sequence",resolve:r,construct:n})},{"../type":166}],179:[function(e,t){"use strict";var r=e("../type");t.exports=new r("tag:yaml.org,2002:seq",{kind:"sequence",construct:function(e){return null!==e?e:[]}})},{"../type":166}],180:[function(e,t){"use strict";function r(e){if(null===e)return!0;var t,r=e;for(t in r)if(o.call(r,t)&&null!==r[t])return!1;return!0}function n(e){return null!==e?e:{}}var i=e("../type"),o=Object.prototype.hasOwnProperty;t.exports=new i("tag:yaml.org,2002:set",{kind:"mapping",resolve:r,construct:n})},{"../type":166}],181:[function(e,t){"use strict";var r=e("../type");t.exports=new r("tag:yaml.org,2002:str",{kind:"scalar",construct:function(e){return null!==e?e:""}})},{"../type":166}],182:[function(e,t){"use strict";function r(e){return null===e?!1:null===a.exec(e)?!1:!0}function n(e){var t,r,n,i,o,s,l,u,c,f,h=0,d=null;if(t=a.exec(e),null===t)throw new Error("Date resolve error");if(r=+t[1],n=+t[2]-1,i=+t[3],!t[4])return new Date(Date.UTC(r,n,i));if(o=+t[4],s=+t[5],l=+t[6],t[7]){for(h=t[7].slice(0,3);h.length<3;)h+="0";h=+h}return t[9]&&(u=+t[10],c=+(t[11]||0),d=6e4*(60*u+c),"-"===t[9]&&(d=-d)),f=new Date(Date.UTC(r,n,i,o,s,l,h)),d&&f.setTime(f.getTime()-d),f}function i(e){return e.toISOString()}var o=e("../type"),a=new RegExp("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?)?$");t.exports=new o("tag:yaml.org,2002:timestamp",{kind:"scalar",resolve:r,construct:n,instanceOf:Date,represent:i})},{"../type":166}],183:[function(e,t){!function(r,n){"object"==typeof t&&t.exports&&"function"==typeof e?t.exports=n():"function"==typeof define&&"object"==typeof define.amd?define(n):r.log=n()}(this,function(){function e(e){return typeof console===l?!1:void 0!==console[e]?t(console,e):void 0!==console.log?t(console,"log"):s}function t(e,t){var r=e[t];if("function"==typeof r.bind)return r.bind(e);try{return Function.prototype.bind.call(r,e)}catch(n){return function(){return Function.prototype.apply.apply(r,[e,arguments])}}}function r(e,t){return function(){typeof console!==l&&(n(t),a[e].apply(a,arguments))}}function n(e){for(var t=0;tt?s:a.methodFactory(r,e)}}function i(e){var t=(u[e]||"silent").toUpperCase();try{return void(window.localStorage.loglevel=t)}catch(r){}try{window.document.cookie="loglevel="+t+";"}catch(r){}}function o(){var e;try{e=window.localStorage.loglevel}catch(t){}if(typeof e===l)try{e=/loglevel=([^;]+)/.exec(window.document.cookie)[1]}catch(t){}void 0===a.levels[e]&&(e="WARN"),a.setLevel(a.levels[e])}var a={},s=function(){},l="undefined",u=["trace","debug","info","warn","error"];a.levels={TRACE:0,DEBUG:1,INFO:2,WARN:3,ERROR:4,SILENT:5},a.methodFactory=function(t,n){return e(t)||r(t,n)},a.setLevel=function(e){if("string"==typeof e&&void 0!==a.levels[e.toUpperCase()]&&(e=a.levels[e.toUpperCase()]),!("number"==typeof e&&e>=0&&e<=a.levels.SILENT))throw"log.setLevel() called with invalid level: "+e;return i(e),n(e),typeof console===l&&e0?u(t.map(g),"||"):"true"}function f(e,t){return t&&t.length>0?u(t.map(g),"&&"):"true"}function h(e,t){return"!"+n(g(t).join(" && "))}function d(e,t){return"!"+n(c(null,t))}function p(e,t){return n(o(e)+(t?" != ":" == ")+"null")}function m(e,t){var r=[];return t.max&&r.push(""+o(e)+" < "+t.max),t.min&&r.push(""+o(e)+" >= "+t.min),n(r.join(" && "))}function g(e){var t=[];if("function"==typeof e)return[n(e.toString()+"(context)")];if(Array.isArray(e))return[c(null,e)];if(null==e)return["true"];for(var r=Object.keys(e),i=0;io;o++){if(t=e.charCodeAt(o),t>55295&&57344>t){if(!r){t>56319||o+1===n?i.push(239,191,189):r=t;continue}if(56320>t){i.push(239,191,189),r=t;continue}t=r-55296<<10|t-56320|65536,r=null}else r&&(i.push(239,191,189),r=null);128>t?i.push(t):2048>t?i.push(t>>6|192,63&t|128):65536>t?i.push(t>>12|224,t>>6&63|128,63&t|128):i.push(t>>18|240,t>>12&63|128,t>>6&63|128,63&t|128)}return i}t.exports=r;var i,o,a,s=e("ieee754");i={readUInt32LE:function(e){return(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},writeUInt32LE:function(e,t){this[t]=e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24},readInt32LE:function(e){return(this[e]|this[e+1]<<8|this[e+2]<<16)+(this[e+3]<<24)},readFloatLE:function(e){return s.read(this,e,!0,23,4)},readDoubleLE:function(e){return s.read(this,e,!0,52,8)},writeFloatLE:function(e,t){return s.write(this,e,t,!0,23,4)},writeDoubleLE:function(e,t){return s.write(this,e,t,!0,52,8)},toString:function(e,t,r){var n="",i="";t=t||0,r=Math.min(this.length,r||this.length);for(var o=t;r>o;o++){var a=this[o];127>=a?(n+=decodeURIComponent(i)+String.fromCharCode(a),i=""):i+="%"+a.toString(16)}return n+=decodeURIComponent(i)},write:function(e,t){for(var r=e===o?a:n(e),i=0;i>3,o=this.pos;e(i,t,this),this.pos===o&&this.skip(n)}return t},readMessage:function(e,t){return this.readFields(e,t,this.readVarint()+this.pos)},readFixed32:function(){var e=this.buf.readUInt32LE(this.pos);return this.pos+=4,e},readSFixed32:function(){var e=this.buf.readInt32LE(this.pos);return this.pos+=4,e},readFixed64:function(){var e=this.buf.readUInt32LE(this.pos)+this.buf.readUInt32LE(this.pos+4)*p;return this.pos+=8,e},readSFixed64:function(){var e=this.buf.readUInt32LE(this.pos)+this.buf.readInt32LE(this.pos+4)*p;return this.pos+=8,e},readFloat:function(){var e=this.buf.readFloatLE(this.pos);return this.pos+=4,e},readDouble:function(){var e=this.buf.readDoubleLE(this.pos);return this.pos+=8,e},readVarint:function(){var e,t,r,n,i,o,a=this.buf;if(r=a[this.pos++],128>r)return r;if(r=127&r,n=a[this.pos++],128>n)return r|n<<7;if(n=(127&n)<<7,i=a[this.pos++],128>i)return r|n|i<<14;if(i=(127&i)<<14,o=a[this.pos++],128>o)return r|n|i|o<<21;if(e=r|n|i|(127&o)<<21,t=a[this.pos++],e+=268435456*(127&t),128>t)return e;if(t=a[this.pos++],e+=34359738368*(127&t),128>t)return e;if(t=a[this.pos++],e+=4398046511104*(127&t),128>t)return e;if(t=a[this.pos++],e+=562949953421312*(127&t),128>t)return e;if(t=a[this.pos++],e+=72057594037927940*(127&t),128>t)return e;if(t=a[this.pos++],e+=0x8000000000000000*(127&t),128>t)return e;throw new Error("Expected varint not more than 10 bytes")},readVarint64:function(){var e=this.pos,t=this.readVarint();if(g>t)return t;for(var r=this.pos-2;255===this.buf[r];)r--;e>r&&(r=e),t=0;for(var n=0;r-e+1>n;n++){var i=127&~this.buf[e+n];t+=4>n?i<<7*n:i*Math.pow(2,7*n)}return-t-1},readSVarint:function(){var e=this.readVarint();return e%2===1?(e+1)/-2:e/2},readBoolean:function(){return Boolean(this.readVarint())},readString:function(){var e=this.readVarint()+this.pos,t=this.buf.toString("utf8",this.pos,e);return this.pos=e,t},readBytes:function(){var e=this.readVarint()+this.pos,t=this.buf.slice(this.pos,e);return this.pos=e,t},readPackedVarint:function(){for(var e=this.readVarint()+this.pos,t=[];this.pos127;);else if(t===n.Bytes)this.pos=this.readVarint()+this.pos;else if(t===n.Fixed32)this.pos+=4;else{if(t!==n.Fixed64)throw new Error("Unimplemented type: "+t);this.pos+=8}},writeTag:function(e,t){this.writeVarint(e<<3|t)},realloc:function(e){for(var t=this.length||16;t=e)this.realloc(1),this.buf[this.pos++]=e;else if(16383>=e)this.realloc(2),this.buf[this.pos++]=e>>>0&127|128,this.buf[this.pos++]=e>>>7&127;else if(2097151>=e)this.realloc(3),this.buf[this.pos++]=e>>>0&127|128,this.buf[this.pos++]=e>>>7&127|128,this.buf[this.pos++]=e>>>14&127;else if(268435455>=e)this.realloc(4),this.buf[this.pos++]=e>>>0&127|128,this.buf[this.pos++]=e>>>7&127|128,this.buf[this.pos++]=e>>>14&127|128,this.buf[this.pos++]=e>>>21&127;else{for(var t=this.pos;e>=128;)this.realloc(1),this.buf[this.pos++]=255&e|128,e/=128;if(this.realloc(1),this.buf[this.pos++]=0|e,this.pos-t>10)throw new Error("Given varint doesn't fit into 10 bytes")}},writeSVarint:function(e){this.writeVarint(0>e?2*-e-1:2*e)},writeBoolean:function(e){this.writeVarint(Boolean(e))},writeString:function(e){e=String(e);var t=d.byteLength(e);this.writeVarint(t),this.realloc(t),this.buf.write(e,this.pos),this.pos+=t},writeFloat:function(e){this.realloc(4),this.buf.writeFloatLE(e,this.pos),this.pos+=4},writeDouble:function(e){this.realloc(8),this.buf.writeDoubleLE(e,this.pos),this.pos+=8},writeBytes:function(e){var t=e.length;this.writeVarint(t),this.realloc(t);for(var r=0;t>r;r++)this.buf[this.pos++]=e[r]},writeMessage:function(e,t,r){this.writeTag(e,n.Bytes),this.pos++;var i=this.pos;t(r,this);var o=this.pos-i,a=127>=o?1:16383>=o?2:2097151>=o?3:268435455>=o?4:Math.ceil(Math.log(o)/(7*Math.LN2));if(a>1){this.realloc(a-1);for(var s=this.pos-1;s>=i;s--)this.buf[s+a-1]=this.buf[s]}this.pos=i-1,this.writeVarint(o),this.pos+=o},writePackedVarint:function(e,t){this.writeMessage(e,i,t)},writePackedSVarint:function(e,t){this.writeMessage(e,o,t)},writePackedBoolean:function(e,t){this.writeMessage(e,l,t)},writePackedFloat:function(e,t){this.writeMessage(e,a,t)},writePackedDouble:function(e,t){this.writeMessage(e,s,t)},writePackedFixed32:function(e,t){this.writeMessage(e,u,t)},writePackedSFixed32:function(e,t){this.writeMessage(e,c,t)},writePackedFixed64:function(e,t){this.writeMessage(e,f,t)},writePackedSFixed64:function(e,t){this.writeMessage(e,h,t)},writeBytesField:function(e,t){this.writeTag(e,n.Bytes),this.writeBytes(t)},writeFixed32Field:function(e,t){this.writeTag(e,n.Fixed32),this.writeFixed32(t)},writeSFixed32Field:function(e,t){this.writeTag(e,n.Fixed32),this.writeSFixed32(t)},writeFixed64Field:function(e,t){this.writeTag(e,n.Fixed64),this.writeFixed64(t)},writeSFixed64Field:function(e,t){this.writeTag(e,n.Fixed64),this.writeSFixed64(t)},writeVarintField:function(e,t){this.writeTag(e,n.Varint),this.writeVarint(t)},writeSVarintField:function(e,t){this.writeTag(e,n.Varint),this.writeSVarint(t)},writeStringField:function(e,t){this.writeTag(e,n.Bytes),this.writeString(t)},writeFloatField:function(e,t){this.writeTag(e,n.Fixed32),this.writeFloat(t)},writeDoubleField:function(e,t){this.writeTag(e,n.Fixed64),this.writeDouble(t)},writeBooleanField:function(e,t){this.writeVarintField(e,Boolean(t))}}}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./buffer":185}],187:[function(e,t){"use strict";function r(e,t){this.x=e,this.y=t}t.exports=r,r.prototype={clone:function(){return new r(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}},r.convert=function(e){return e instanceof r?e:Array.isArray(e)?new r(e[0],e[1]):e}},{}],188:[function(e,t){function r(){}var n=t.exports={};n.nextTick=function(){var e="undefined"!=typeof window&&window.setImmediate,t="undefined"!=typeof window&&window.MutationObserver,r="undefined"!=typeof window&&window.postMessage&&window.addEventListener;if(e)return function(e){return window.setImmediate(e)};var n=[];if(t){var i=document.createElement("div"),o=new MutationObserver(function(){var e=n.slice();n.length=0,e.forEach(function(e){e()})});return o.observe(i,{attributes:!0}),function(e){n.length||i.setAttribute("yes","no"),n.push(e)}}return r?(window.addEventListener("message",function(e){var t=e.source;if((t===window||null===t)&&"process-tick"===e.data&&(e.stopPropagation(),n.length>0)){var r=n.shift();r()}},!0),function(e){n.push(e),window.postMessage("process-tick","*")}):function(e){setTimeout(e,0)}}(),n.title="browser",n.browser=!0,n.env={},n.argv=[],n.on=r,n.addListener=r,n.once=r,n.off=r,n.removeListener=r,n.removeAllListeners=r,n.emit=r,n.binding=function(){throw new Error("process.binding is not supported")},n.cwd=function(){return"/"},n.chdir=function(){throw new Error("process.chdir is not supported")}},{}],189:[function(e,t){"use stric";var r="\\/\\*",n="\\/\\*(?!\\*?\\!)",i="(.|[\\r\\n]|\\n)*?\\*\\/\\n?\\n?",o=/(^|[^\S\n])(?:\/\/)([\s\S]+?)$/gm,a=/(^|[^\S\n])(?:\/\/[^!])([\s\S]+?)$/gm,s=t.exports=function(e,t){return e?s.block(s.line(e,t),t):""};s.block=function(e,t){t=t||{};var o=new RegExp(r+i,"gm");return t.safe&&(o=new RegExp(n+i,"gm")),e?e.replace(o,""):""},s.line=function(e,t){t=t||{};var r=o;return t.safe&&(r=a),e?e.replace(r,""):""}},{}],190:[function(e,t){!function(){function e(e,t){function r(t){var r,n=e.arcs[0>t?~t:t],i=n[0];return e.transform?(r=[0,0],n.forEach(function(e){r[0]+=e[0],r[1]+=e[1]})):r=n[n.length-1],0>t?[r,i]:[i,r]}function n(e,t){for(var r in e){var n=e[r];delete t[n.start],delete n.start,delete n.end,n.forEach(function(e){i[0>e?~e:e]=1}),s.push(n)}}var i={},o={},a={},s=[],l=-1;return t.forEach(function(r,n){var i,o=e.arcs[0>r?~r:r];o.length<3&&!o[1][0]&&!o[1][1]&&(i=t[++l],t[l]=r,t[n]=i)}),t.forEach(function(e){var t,n,i=r(e),s=i[0],l=i[1];if(t=a[s])if(delete a[t.end],t.push(e),t.end=l,n=o[l]){delete o[n.start];var u=n===t?t:t.concat(n);o[u.start=t.start]=a[u.end=n.end]=u}else o[t.start]=a[t.end]=t;else if(t=o[l])if(delete o[t.start],t.unshift(e),t.start=s,n=a[s]){delete a[n.end];var c=n===t?t:n.concat(t);o[c.start=n.start]=a[c.end=t.end]=c}else o[t.start]=a[t.end]=t;else t=[e],o[t.start=s]=a[t.end=l]=t}),n(a,o),n(o,a),t.forEach(function(e){i[0>e?~e:e]||s.push([e])}),s}function r(t,r,n){function i(e){var t=0>e?~e:e;(c[t]||(c[t]=[])).push({i:e,g:u})}function o(e){e.forEach(i)}function a(e){e.forEach(o)}function s(e){"GeometryCollection"===e.type?e.geometries.forEach(s):e.type in f&&(u=e,f[e.type](e.arcs))}var l=[];if(arguments.length>1){var u,c=[],f={LineString:o,MultiLineString:a,Polygon:a,MultiPolygon:function(e){e.forEach(a)}};s(r),c.forEach(arguments.length<3?function(e){l.push(e[0].i)}:function(e){n(e[0].g,e[e.length-1].g)&&l.push(e[0].i)})}else for(var h=0,d=t.arcs.length;d>h;++h)l.push(h);return{type:"MultiLineString",arcs:e(t,l)}}function i(t,r){function i(e){e.forEach(function(t){t.forEach(function(t){(a[t=0>t?~t:t]||(a[t]=[])).push(e)})}),l.push(e)}function o(e){return h(s(t,{type:"Polygon",arcs:[e]}).coordinates[0])>0}var a={},l=[],u=[];return r.forEach(function(e){"Polygon"===e.type?i(e.arcs):"MultiPolygon"===e.type&&e.arcs.forEach(i)}),l.forEach(function(e){if(!e._){var t=[],r=[e];for(e._=1,u.push(t);e=r.pop();)t.push(e),e.forEach(function(e){e.forEach(function(e){a[0>e?~e:e].forEach(function(e){e._||(e._=1,r.push(e))})})})}}),l.forEach(function(e){delete e._}),{type:"MultiPolygon",arcs:u.map(function(r){var i=[];if(r.forEach(function(e){e.forEach(function(e){e.forEach(function(e){a[0>e?~e:e].length<2&&i.push(e)})})}),i=e(t,i),(n=i.length)>1)for(var s,l=o(r[0][0]),u=0;n>u;++u)if(l===o(i[u])){s=i[0],i[0]=i[u],i[u]=s;break}return i})}}function o(e,t){return"GeometryCollection"===t.type?{type:"FeatureCollection",features:t.geometries.map(function(t){return a(e,t)})}:a(e,t)}function a(e,t){var r={type:"Feature",id:t.id,properties:t.properties||{},geometry:s(e,t)};return null==t.id&&delete r.id,r}function s(e,t){function r(e,t){t.length&&t.pop();for(var r,n=c[0>e?~e:e],i=0,o=n.length;o>i;++i)t.push(r=n[i].slice()),u(r,i);0>e&&l(t,o)}function n(e){return e=e.slice(),u(e,0),e}function i(e){for(var t=[],n=0,i=e.length;i>n;++n)r(e[n],t);return t.length<2&&t.push(t[0].slice()),t}function o(e){for(var t=i(e);t.length<4;)t.push(t[0].slice());return t}function a(e){return e.map(o)}function s(e){var t=e.type;return"GeometryCollection"===t?{type:t,geometries:e.geometries.map(s)}:t in f?{type:t,coordinates:f[t](e)}:null}var u=g(e.transform),c=e.arcs,f={Point:function(e){return n(e.coordinates)},MultiPoint:function(e){return e.coordinates.map(n)},LineString:function(e){return i(e.arcs)},MultiLineString:function(e){return e.arcs.map(i)},Polygon:function(e){return a(e.arcs)},MultiPolygon:function(e){return e.arcs.map(a)}};return s(t)}function l(e,t){for(var r,n=e.length,i=n-t;i<--n;)r=e[i],e[i++]=e[n],e[n]=r}function u(e,t){for(var r=0,n=e.length;n>r;){var i=r+n>>>1;e[i]e&&(e=~e);var r=i[e];r?r.push(t):i[e]=[t]})}function r(e,r){e.forEach(function(e){t(e,r)})}function n(e,t){"GeometryCollection"===e.type?e.geometries.forEach(function(e){n(e,t)}):e.type in a&&a[e.type](e.arcs,t)}var i={},o=e.map(function(){return[]}),a={LineString:t,MultiLineString:r,Polygon:r,MultiPolygon:function(e,t){e.forEach(function(e){r(e,t)})}};e.forEach(n);for(var s in i)for(var l=i[s],c=l.length,f=0;c>f;++f)for(var h=f+1;c>h;++h){var d,p=l[f],m=l[h];(d=o[p])[s=u(d,m)]!==m&&d.splice(s,0,m),(d=o[m])[s=u(d,p)]!==p&&d.splice(s,0,p)}return o}function f(e,t){function r(e){o.remove(e),e[1][2]=t(e),o.push(e)}var n=g(e.transform),i=v(e.transform),o=m();return t||(t=d),e.arcs.forEach(function(e){for(var a,s,l=[],u=0,c=0,f=e.length;f>c;++c)s=e[c],n(e[c]=[s[0],s[1],1/0],c);for(var c=1,f=e.length-1;f>c;++c)a=e.slice(c-1,c+2),a[1][2]=t(a),l.push(a),o.push(a);for(var c=0,f=l.length;f>c;++c)a=l[c],a.previous=l[c-1],a.next=l[c+1];for(;a=o.pop();){var h=a.previous,d=a.next;a[1][2]0;){var r=(t+1>>1)-1,i=n[r];if(p(e,i)>=0)break;n[i._=t]=i,n[e._=t=r]=e}}function t(e,t){for(;;){var r=t+1<<1,o=r-1,a=t,s=n[a];if(i>o&&p(n[o],s)<0&&(s=n[a=o]),i>r&&p(n[r],s)<0&&(s=n[a=r]),a===t)break;n[s._=t]=s,n[e._=t=a]=e}}var r={},n=[],i=0;return r.push=function(t){return e(n[t._=i]=t,i++),i},r.pop=function(){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],(p(o,r)<0?e:t)(n[o._=a]=o,a)),a},r}function g(e){if(!e)return _;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 v(e){if(!e)return _;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 l=(e[0]-o)/n|0,u=(e[1]-a)/i|0;e[0]=l-t,e[1]=u-r,t=l,r=u}}function _(){}var y={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(y):"object"==typeof t&&t.exports?t.exports=y:this.topojson=y}()},{}],191:[function(e,t,r){(function(t,n){"use strict";function i(e){if(e){var t=e.length||e.byteLength,r=_.log2(t);w[r].push(e)}}function o(e){i(e.buffer)}function a(e){var e=_.nextPow2(e),t=_.log2(e),r=w[t];return r.length>0?r.pop():new ArrayBuffer(e)}function s(e){return new Uint8Array(a(e),0,e)}function l(e){return new Uint16Array(a(2*e),0,e)}function u(e){return new Uint32Array(a(4*e),0,e)}function c(e){return new Int8Array(a(e),0,e)}function f(e){return new Int16Array(a(2*e),0,e)}function h(e){return new Int32Array(a(4*e),0,e)}function d(e){return new Float32Array(a(4*e),0,e)}function p(e){return new Float64Array(a(8*e),0,e)}function m(e){return b?new Uint8ClampedArray(a(e),0,e):s(e)}function g(e){return new DataView(a(e),0,e)}function v(e){e=_.nextPow2(e);var t=_.log2(e),r=A[t];return r.length>0?r.pop():new n(e)}var _=e("bit-twiddle"),y=e("dup");t.__TYPEDARRAY_POOL||(t.__TYPEDARRAY_POOL={UINT8:y([32,0]),UINT16:y([32,0]),UINT32:y([32,0]),INT8:y([32,0]),INT16:y([32,0]),INT32:y([32,0]),FLOAT:y([32,0]),DOUBLE:y([32,0]),DATA:y([32,0]),UINT8C:y([32,0]),BUFFER:y([32,0])});var b="undefined"!=typeof Uint8ClampedArray,x=t.__TYPEDARRAY_POOL;x.UINT8C||(x.UINT8C=y([32,0])),x.BUFFER||(x.BUFFER=y([32,0]));var w=x.DATA,A=x.BUFFER;r.free=function(e){if(n.isBuffer(e))A[_.log2(e.length)].push(e);else{if("[object ArrayBuffer]"!==Object.prototype.toString.call(e)&&(e=e.buffer),!e)return;var t=e.length||e.byteLength,r=0|_.log2(t);w[r].push(e)}},r.freeUint8=r.freeUint16=r.freeUint32=r.freeInt8=r.freeInt16=r.freeInt32=r.freeFloat32=r.freeFloat=r.freeFloat64=r.freeDouble=r.freeUint8Clamped=r.freeDataView=o,r.freeArrayBuffer=i,r.freeBuffer=function(e){A[_.log2(e.length)].push(e)},r.malloc=function(e,t){if(void 0===t||"arraybuffer"===t)return a(e);switch(t){case"uint8":return s(e);case"uint16":return l(e);case"uint32":return u(e);case"int8":return c(e);case"int16":return f(e);case"int32":return h(e);case"float":case"float32":return d(e);case"double":case"float64":return p(e);case"uint8_clamped":return m(e);case"buffer":return v(e);case"data":case"dataview":return g(e);default:return null}return null},r.mallocArrayBuffer=a,r.mallocUint8=s,r.mallocUint16=l,r.mallocUint32=u,r.mallocInt8=c,r.mallocInt16=f,r.mallocInt32=h,r.mallocFloat32=r.mallocFloat=d,r.mallocFloat64=r.mallocDouble=p,r.mallocUint8Clamped=m,r.mallocDataView=g,r.mallocBuffer=v,r.clearCache=function(){for(var e=0;32>e;++e)x.UINT8[e].length=0,x.UINT16[e].length=0,x.UINT32[e].length=0,x.INT8[e].length=0,x.INT16[e].length=0,x.INT32[e].length=0,x.FLOAT[e].length=0,x.DOUBLE[e].length=0,x.UINT8C[e].length=0,w[e].length=0,A[e].length=0}}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer)},{"bit-twiddle":29,buffer:38,dup:134}],192:[function(e,t){t.exports.VectorTile=e("./lib/vectortile.js"),t.exports.VectorTileFeature=e("./lib/vectortilefeature.js"),t.exports.VectorTileLayer=e("./lib/vectortilelayer.js")},{"./lib/vectortile.js":193,"./lib/vectortilefeature.js":194,"./lib/vectortilelayer.js":195}],193:[function(e,t){"use strict";function r(e,t){this.layers=e.readFields(n,{},t)}function n(e,t,r){if(3===e){var n=new i(r,r.readVarint()+r.pos);n.length&&(t[n.name]=n)}}var i=e("./vectortilelayer");t.exports=r},{"./vectortilelayer":195}],194:[function(e,t){"use strict";function r(e,t,r,i,o){this.properties={},this.extent=r,this.type=0,this._pbf=e,this._geometry=-1,this._keys=i,this._values=o,e.readFields(n,this,t)}function n(e,t,r){1==e?t._id=r.readVarint():2==e?i(r,t):3==e?t.type=r.readVarint():4==e&&(t._geometry=r.pos)}function i(e,t){for(var r=e.readVarint()+e.pos;e.pos>3}if(i--,1===n||2===n)a+=e.readSVarint(),s+=e.readSVarint(),1===n&&(t&&l.push(t),t=[]),t.push(new o(a,s));else{if(7!==n)throw new Error("unknown command "+n);t.push(t[0].clone())}}return t&&l.push(t),l},r.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,l=1/0,u=-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),l>o&&(l=o),o>u&&(u=o);else if(7!==r)throw new Error("unknown command "+r)}return[a,l,s,u]},r.prototype.toGeoJSON=function(e,t,n){for(var i=this.extent*Math.pow(2,n),o=this.extent*e,a=this.extent*t,s=this.loadGeometry(),l=r.types[this.type],u=0;u>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 o=e("./vectortilefeature.js");t.exports=r,r.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 o(this._pbf,t,this.extent,this._keys,this._values)}},{"./vectortilefeature.js":194}],196:[function(e,t,r){"use strict";function n(e,t,r){var n=s[0],i=s[1];return e[0]<=n.x+r&&t[0]<=n.x+r||e[0]>=i.x-r&&t[0]>=i.x-r||e[1]>=n.y-r&&t[1]>=n.y-r||e[1]<=i.y+r&&t[1]<=i.y+r?!0:!1 -}var i=e("babel-runtime/helpers/interop-require-default")["default"];Object.defineProperty(r,"__esModule",{value:!0}),r.outsideTile=n;var o=e("../geo"),a=i(o),s=[{x:0,y:0},{x:a["default"].tile_scale,y:-a["default"].tile_scale}];r.tile_bounds=s;var l=[0,0,1,1];r.default_uvs=l},{"../geo":201,"babel-runtime/helpers/interop-require-default":23}],197:[function(e,t,r){"use strict";function n(e,t,r,n,a){var s=n.texcoord_index,l=n.position_index,u=n.shape_index,c=n.offset_index,f=a.quad,h=a.quad_scale,d=a.offset,p=a.angle,m=a.texcoord_scale,g=a.texcoord_normalize,v=f[0]/2,_=f[1]/2,y=[[-v,-_],[v,-_],[v,_],[-v,-_],[v,_],[-v,_]],b=void 0;if(s){g=g||1;var x=m||o.default_uvs,w=i(x,4),A=w[0],T=w[1],k=w[2],E=w[3];b=[[A,T],[k,T],[k,E],[A,T],[k,E],[A,E]]}for(var S=e.length,R=0;S>R;R++)for(var M=e[R],j=0;6>j;j++)s&&(r[s+0]=b[j][0]*g,r[s+1]=b[j][1]*g),r[l+0]=M[0],r[l+1]=M[1],r[u+0]=y[j][0],r[u+1]=y[j][1],r[u+2]=p,r[u+3]=h,r[c+0]=d[0],r[c+1]=d[1],t.addVertex(r)}var i=e("babel-runtime/helpers/sliced-to-array")["default"];Object.defineProperty(r,"__esModule",{value:!0}),r.buildQuadsForPoints=n;var o=e("./common")},{"./common":196,"babel-runtime/helpers/sliced-to-array":24}],198:[function(e,t,r){"use strict";function n(e,t,r,n){var i=n.texcoord_index,s=n.texcoord_scale,l=n.texcoord_normalize;if(i){l=l||1;var c=s||h.default_uvs,f=a(c,4),d=f[0],p=f[1],m=f[2],g=f[3]}for(var v=e.length,_=0;v>_;_++){var y=e[_];if(i)var b=u["default"].findBoundingBox(y),x=a(b,4),w=x[0],A=x[1],T=x[2],k=x[3],E=T-w,S=k-A,R=(m-d)/E,M=(g-p)/S;for(var j=o(y),P=j.length,z=0;P>z;z++){var N=j[z];r[0]=N[0],r[1]=N[1],i&&(r[i+0]=((N[0]-w)*R+d)*l,r[i+1]=((N[1]-A)*M+p)*l),t.addVertex(r)}}}function i(e,t,r,i,o,s,l,u,c){var d=c.remove_tile_edges,p=c.tile_edge_tolerance,g=c.texcoord_index,v=c.texcoord_scale,_=c.texcoord_normalize,y=c.winding,b=t+(i||0),x=t+r;if(s[2]=x,n(e,o,s,{texcoord_index:g,texcoord_scale:v,texcoord_normalize:_}),g){_=_||1;var w=v||h.default_uvs,A=a(w,4),T=A[0],k=A[1],E=A[2],S=A[3],R=[[T,S],[T,k],[E,k],[E,k],[E,S],[T,S]]}for(var M=e.length,j=0;M>j;j++)for(var P=e[j],z=0;z$)){var C=[0,0],G=[0,0],B=[0,0],q=[0,0],V=[0,0],W=[0,0],H=!1,X=!0;d(U);for(var Z=0;$>Z;Z++){if(X=$>Z+1,H)C=G,q=v["default"].normalize(v["default"].perp(C,D[Z]));else if(0===Z&&s===!0){var Y=!0;l&&b.outsideTile(D[Z],D[$-2],u)&&(Y=!1),Y&&(C=D[$-2],q=v["default"].normalize(v["default"].perp(C,D[Z])),H=!0)}if(G=D[Z],X?B=D[Z+1]:s===!0&&(B=D[1],X=!0),X&&(W=v["default"].normalize(v["default"].perp(G,B)),l&&b.outsideTile(G,B,u)))V=v["default"].normalize(v["default"].perp(C,G)),H&&(a(G,V,U.texcoords&&v["default"].length(v["default"].sub(G,C)),U),U.num_pairs++,d(U)),H=!1;else{if(H)if(X){V=v["default"].normalize(v["default"].add(q,W));var J=2/(1+Math.abs(v["default"].dot(q,V)));V=v["default"].mult(V,J*J)}else V=v["default"].normalize(v["default"].perp(C,G));else{if(!X)continue;W=v["default"].normalize(v["default"].perp(G,B)),V=W}(H||X)&&(0!==Z||H||s||f(G,V,R,!0,U),0===M&&v["default"].lengthSq(V)>j&&(M=A.bevel),0!==M&&H&&X?c([C,G,B],[q,V,W],M,U):a(G,V,U.texcoords&&v["default"].length(v["default"].sub(G,C)),U),X&&U.num_pairs++,H=!0)}}d(U),s||f(G,V,R,!1,U)}}}}function i(e,t){var r=void 0,n=void 0;for(r=0;ru)){d(c);var f=v["default"].set(t),p=[0,0],m=v["default"].angleBetween(t,n),g=m/u;if(l||(g*=-1),c.texcoords)var _=v["default"].set(i),y=v["default"].div(v["default"].sub(s,i),u);o(e,r,a,c),o(e,f,i,c);for(var b=0;u>b;b++)p=v["default"].normalize(f),f=v["default"].rot(v["default"].normalize(f),g),c.texcoords&&(_=v["default"].add(_,y)),o(e,f,_,c);for(var x=0;u>x;x++)l?(h(x+2,c),h(0,c),h(x+1,c)):(h(x+1,c),h(0,c),h(x+2,c));c.vertices=[],c.scalingVecs&&(c.scalingVecs=[]),c.texcoords&&(c.texcoords=[])}}function l(e,t,r,n,i,a,s,l,u){d(u),o(e,r,a,u),o(e,t,i,u),o(e,n,s,u),l?(h(2,u),h(0,u),h(1,u)):(h(1,u),h(0,u),h(2,u)),u.vertices=[],u.scalingVecs&&(u.scalingVecs=[]),u.texcoords&&(u.texcoords=[])}function u(e,t,r,n,i,a,s,l){d(l);var u=v["default"].set(t),c=[0,0];if(l.texcoords)var f=v["default"].set(n),p=v["default"].div(v["default"].sub(a,n),4);var m=.78539816339;s||(m*=-1),o(e,x,i,l),o(e,u,n,l);for(var g=0;4>g;g++){if(c=v["default"].normalize(u),u=v["default"].rot(v["default"].normalize(u),m),0===g||2===g){var _=2/(1+Math.abs(v["default"].dot(c,u)));u=v["default"].mult(u,_*_)}l.texcoords&&(f=v["default"].add(f,p)),1!==g&&o(e,u,f,l)}for(var y=0;3>y;y++)s?(h(y+2,l),h(0,l),h(y+1,l)):(h(y+1,l),h(0,l),h(y+2,l));l.vertices=[],l.scalingVecs&&(l.scalingVecs=[]),l.texcoords&&(l.texcoords=[])}function c(e,t,r,n){var i,a,u,c=v["default"].signed_area(e[0],e[1],e[2])>0,f=t[0],h=v["default"].neg(t[1]),d=t[2];n.texcoords&&(n.total_dist+=v["default"].length(v["default"].sub(e[1],e[0]))*n.v_scale,i=[n.max_u,n.total_dist],u=[n.min_u,n.total_dist],a=i),c?(o(e[1],f,i,n),o(e[1],h,u,n)):(f=v["default"].neg(t[0]),h=t[1],d=v["default"].neg(t[2]),n.texcoords&&(i=[n.min_u,n.total_dist],u=[n.max_u,n.total_dist],a=i),o(e[1],h,u,n),o(e[1],f,i,n)),1===r?l(e[1],f,h,d,i,u,a,c,n):r>1&&s(e[1],f,h,d,i,u,a,c,r,n),c?(o(e[1],d,a,n),o(e[1],h,u,n)):(o(e[1],h,u,n),o(e[1],d,a,n))}function f(e,t,r,n,i){if(!(1>r)){var o,a,l;i.texcoords&&(l=[i.min_u+(i.max_u-i.min_u)/2,i.total_dist],o=[i.min_u,i.total_dist],a=[i.max_u,i.total_dist]),2===r?u(e,v["default"].neg(t),t,o,l,a,n,i):s(e,v["default"].neg(t),x,t,o,l,a,n,2*r,i)}}function h(e,t){var r=t.vertex_data,n=t.vertex_template,i=t.half_width,o=t.vertices,a=t.scaling_index,s=t.scaling_normalize,l=t.scalingVecs,u=t.texcoord_index,c=t.texcoords,f=t.texcoord_normalize;e>=o.length||(n[0]=o[e][0],n[1]=o[e][1],u&&(n[u+0]=c[e][0]*f,n[u+1]=c[e][1]*f),a&&(n[a+0]=l[e][0]*s,n[a+1]=l[e][1]*s,n[a+2]=i),r.addVertex(n))}function d(e){for(var t=0;t180||-180>e)&&(e=((e+180)%360+360)%360-180),e},o.transformGeometry=function(e,t){null!=e&&("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)})}))},o.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]},o.geometryType=function(e){return"Polygon"===e||"MultiPolygon"===e?"polygon":"LineString"===e||"MultiLineString"===e?"line":"Point"===e||"MultiPoint"===e?"point":void 0},o.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]},o.polygonArea=function(e){return Math.abs(o.signedPolygonAreaSum(e))/2},o.multiPolygonArea=function(e){for(var t=0,r=0;r0?"CW":0>t?"CCW":void 0},o.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 n=0;n=2&&l.length<=4?r.push({type:"vec"+l.length,method:l.length+"fv",name:o,value:l,key:s,uniforms:e}):l.length>4&&r.push({type:"float[]",method:"1fv",name:o+"[0]",value:l,key:s,uniforms:e});else if("string"==typeof l[0])for(a=0;a=2&&l[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=arguments.length<=2||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=arguments.length<=1||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=arguments.length<=1||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},t.exports=r["default"]},{"babel-runtime/helpers/to-consumable-array":25}],206:[function(e,t,r){"use strict";var n=e("babel-runtime/helpers/create-class")["default"],i=e("babel-runtime/helpers/class-call-check")["default"];Object.defineProperty(r,"__esModule",{value:!0});var o=function(){function e(t,r){i(this,e),r(t),this.value=t,this.setup=r}return n(e,[{key:"set",value:function(e){JSON.stringify(this.value)!==JSON.stringify(e)&&(this.setup(e),this.value=e)}}],[{key:"initialize",value:function(t){e.defaults={},e.defaults.culling=!0,e.defaults.culling_face=t.BACK,e.defaults.blending=!1,e.defaults.blending_src=t.ONE_MINUS_SRC_ALPHA,e.defaults.blending_dst=t.ONE_MINUS_SRC_ALPHA,e.defaults.blending_src_alpha=t.ONE,e.defaults.blending_dst_alpha=t.ONE_MINUS_SRC_ALPHA,e.defaults.depth_write=!0,e.defaults.depth_test=!0,e.defaults.depth_func=t.LESS,e.culling=new e({cull:e.defaults.culling,face:e.defaults.culling_face},function(e){e.cull?(t.enable(t.CULL_FACE),t.cullFace(e.face)):t.disable(t.CULL_FACE)}),e.blending=new e({blend:e.defaults.blending,src:e.defaults.blending_src,dst:e.defaults.blending_dst,src_alpha:e.defaults.blending_src_alpha,dst_alpha:e.defaults.blending_dst_alpha},function(e){e.blend?(t.enable(t.BLEND),e.src_alpha&&e.dst_alpha?t.blendFuncSeparate(e.src,e.dst,e.src_alpha,e.dst_alpha):t.blendFunc(e.src,e.dst)):t.disable(t.BLEND)}),e.depth_write=new e({depth_write:e.defaults.depth_write},function(e){t.depthMask(e.depth_write)}),e.depth_test=new e({depth_test:e.defaults.depth_test,depth_func:e.defaults.depth_func},function(e){e.depth_test?(t.enable(t.DEPTH_TEST),t.depthFunc(e.depth_func)):t.disable(t.DEPTH_TEST)})}}]),e}();r["default"]=o,t.exports=r["default"]},{"babel-runtime/helpers/class-call-check":18,"babel-runtime/helpers/create-class":19}],207:[function(e,t,r){"use strict";var n=e("babel-runtime/helpers/create-class")["default"],i=e("babel-runtime/helpers/class-call-check")["default"],o=e("babel-runtime/helpers/to-consumable-array")["default"],a=e("babel-runtime/core-js/object/assign")["default"],s=e("babel-runtime/core-js/get-iterator")["default"],l=e("babel-runtime/helpers/interop-require-default")["default"];Object.defineProperty(r,"__esModule",{value:!0});var u=e("./glsl"),c=l(u),f=e("./texture"),h=l(f),d=e("./extensions"),p=l(d),m=e("loglevel"),g=l(m),v=e("strip-comments"),_=l(v),y=e("gl-shader-errors"),b=l(y),x=function(){function e(t,r,n,o){i(this,e),o=o||{},this.gl=t,this.program=null,this.compiled=!1,this.compiling=!1,this.error=null,this.defines=a({},o.defines||{}),this.blocks=a({},o.blocks||{}),this.block_scopes=a({},o.block_scopes||{}),this.extensions=o.extensions||[],this.dependent_uniforms=o.uniforms,this.uniforms={},this.attribs={},this.vertex_source=r,this.fragment_source=n,this.id=e.id++,e.programs[this.id]=this,this.name=o.name}return n(e,[{key:"destroy",value:function(){this.gl.useProgram(null),this.gl.deleteProgram(this.program),this.program=null,this.uniforms={},this.attribs={},delete e.programs[this.id],this.compiled=!1}},{key:"use",value:function(){this.compiled&&(e.current!==this&&this.gl.useProgram(this.program),e.current=this)}},{key:"compile",value:function(){if(this.compiling)throw new Error("ShaderProgram.compile(): skipping for "+this.id+" ("+this.name+") because already compiling");this.compiling=!0,this.compiled=!1,this.error=null,this.computed_vertex_source=this.vertex_source,this.computed_fragment_source=this.fragment_source;var t,r=this.checkExtensions(),n=this.buildDefineList(),i=this.buildShaderBlockList();for(var o in i){var a=i[o];if(a&&(!Array.isArray(a)||0!==a.length)){t=new RegExp("^\\s*#pragma\\s+tangram:\\s+"+o+"\\s*$","m");var l=this.computed_vertex_source.match(t),u=this.computed_fragment_source.match(t);if(null!=l||null!=u){var c="";a.forEach(function(e){var t=e.scope+", "+e.key+", "+e.num;c+="\n// tangram-block-start: "+t+"\n",c+=e.source,c+="\n// tangram-block-end: "+t+"\n"}),null!=l&&(this.computed_vertex_source=this.computed_vertex_source.replace(t,c)),null!=u&&(this.computed_fragment_source=this.computed_fragment_source.replace(t,c)),n["TANGRAM_BLOCK_"+o.replace(/[\s-]+/g,"_").toUpperCase()]=!0}}}t=new RegExp("^\\s*#pragma.*$","gm"),this.computed_vertex_source=this.computed_vertex_source.replace(t,""),this.computed_fragment_source=this.computed_fragment_source.replace(t,""),this.ensureUniforms(this.dependent_uniforms);var f=this.name?this.name+" / id "+this.id:"id "+this.id,h="// Program: "+f+"\n",d="",p=this.gl.getShaderPrecisionFormat(this.gl.FRAGMENT_SHADER,this.gl.HIGH_FLOAT);d=p&&p.precision>0?"precision highp float;\n":"precision mediump float;\n",n.TANGRAM_VERTEX_SHADER=!0,n.TANGRAM_FRAGMENT_SHADER=!1,this.computed_vertex_source=h+d+e.buildDefineString(n)+this.computed_vertex_source,n.TANGRAM_VERTEX_SHADER=!1,n.TANGRAM_FRAGMENT_SHADER=!0,this.computed_fragment_source=e.buildExtensionString(r)+h+d+e.buildDefineString(n)+this.computed_fragment_source;try{this.program=e.updateProgram(this.gl,this.program,this.computed_vertex_source,this.computed_fragment_source),this.compiled=!0,this.compiling=!1}catch(m){if(this.program=null,this.compiled=!1,this.compiling=!1,this.error=m,"vertex"===m.type||"fragment"===m.type){this.shader_errors=m.errors;var g=!0,v=!1,_=void 0;try{for(var y,b=s(this.shader_errors);!(g=(y=b.next()).done);g=!0){var x=y.value;x.type=m.type,x.block=this.block(m.type,x.line)}}catch(w){v=!0,_=w}finally{try{!g&&b["return"]&&b["return"]()}finally{if(v)throw _}}}throw new Error("ShaderProgram.compile(): program "+this.id+" ("+this.name+") error:",m)}this.use(),this.refreshUniforms(),this.refreshAttributes()}},{key:"buildDefineList",value:function(){var t,r={};for(t in e.defines)r[t]=e.defines[t];for(t in this.defines)r[t]=this.defines[t];return r}},{key:"buildShaderBlockList",value:function(){var t=void 0,r={};for(t in e.blocks)if(r[t]=[],Array.isArray(e.blocks[t])){var n;(n=r[t]).push.apply(n,o(e.blocks[t].map(function(e,r){return{key:t,source:e,num:r,scope:"ShaderProgram"}})))}else r[t]=[{key:t,source:e.blocks[t],num:0,scope:"ShaderProgram"}];for(t in this.blocks)if(r[t]=r[t]||[],Array.isArray(this.blocks[t]))for(var i=this.block_scopes&&this.block_scopes[t]||[],a=null,s=0,l=0;l0&&(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)}}},{key:"setUniforms",value:function(e){var t=arguments.length<=1||void 0===arguments[1]?!0:arguments[1];if(this.compiled){t&&(this.texture_unit=0);var r=c["default"].parseUniforms(e),n=!0,i=!1,o=void 0;try{for(var a,l=s(r);!(n=(a=l.next()).done);n=!0){var u=a.value;"sampler2D"===u.type?this.setTextureUniform(u.name,u.value):this.uniform(u.method,u.name,u.value)}}catch(f){i=!0,o=f}finally{try{!n&&l["return"]&&l["return"]()}finally{if(i)throw o}}}}},{key:"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}},{key:"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}},{key:"setTextureUniform",value:function(e,t){var r=h["default"].textures[t]; -return null==r?void g["default"].warn("Can't find texture '"+t+"'"):(r.bind(this.texture_unit),this.uniform("1i",e,this.texture_unit),void this.texture_unit++)}},{key:"uniform",value:function t(e,r){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;for(var n=arguments.length,i=Array(n>2?n-2:0),o=2;n>o;o++)i[o-2]=arguments[o];t.value=i,this.updateUniform(r)}}},{key:"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)))}}},{key:"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)}},{key:"refreshAttributes",value:function(){this.attribs={}}},{key:"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)}}},{key:"source",value:function(e){return"vertex"===e?this.computed_vertex_source:"fragment"===e?this.computed_fragment_source:void 0}},{key:"lines",value:function(e){var t=this.source(e);return t?t.split("\n"):[]}},{key:"line",value:function(e,t){var r=this.lines(e);return r?r[t]:void 0}},{key:"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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\d+)/),a&&a.length>1&&(r=null)),r&&(r.line=null==r.line?-1:r.line+1,r.source=o)}return r}},{key:"checkExtensions",value:function(){var e=[],t=!0,r=!1,n=void 0;try{for(var i,o=s(this.extensions);!(t=(i=o.next()).done);t=!0){var a=i.value,l=p["default"](this.gl,a),u="TANGRAM_EXTENSION_"+a;this.defines[u]=null!=l,l?e.push(a):g["default"].debug("Could not enable extension '"+a+"'")}}catch(c){r=!0,n=c}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}return e}}]),e}();r["default"]=x,x.id=0,x.programs={},x.current=null,x.defines={},x.blocks={},x.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},x.buildExtensionString=function(e){e=e||[];var t="",r=!0,n=!1,i=void 0;try{for(var o,a=s(e);!(r=(o=a.next()).done);r=!0){var l=o.value;t+="#ifdef GL_"+l+"\n#extension GL_"+l+" : enable\n#endif\n"}}catch(u){n=!0,i=u}finally{try{!r&&a["return"]&&a["return"]()}finally{if(n)throw i}}return t},x.addBlock=function(e){var t;x.blocks[e]=x.blocks[e]||[];for(var r=arguments.length,n=Array(r>1?r-1:0),i=1;r>i;i++)n[i-1]=arguments[i];(t=x.blocks[e]).push.apply(t,n)},x.removeBlock=function(e){x.blocks[e]=[]},x.replaceBlock=function(e){x.removeBlock(e);for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];x.addBlock.apply(x,[e].concat(r))},x.updateProgram=function(e,t,r,n){try{var i=x.createShader(e,r,e.VERTEX_SHADER),o=x.createShader(e,n,e.FRAGMENT_SHADER)}catch(a){throw g["default"].error(a.message),a}if(e.useProgram(null),null!=t)for(var s=e.getAttachedShaders(t),l=0;lR;R++)for(var M=e[R],j=0;6>j;j++)s&&(r[s+0]=b[j][0]*g,r[s+1]=b[j][1]*g),r[l+0]=M[0],r[l+1]=M[1],r[u+0]=y[j][0],r[u+1]=y[j][1],r[u+2]=p,r[u+3]=h,r[c+0]=d[0],r[c+1]=d[1],t.addVertex(r)}var i=e("babel-runtime/helpers/sliced-to-array")["default"];Object.defineProperty(r,"__esModule",{value:!0}),r.buildQuadsForPoints=n;var o=e("./common")},{"./common":196,"babel-runtime/helpers/sliced-to-array":24}],198:[function(e,t,r){"use strict";function n(e,t,r,n){var i=n.texcoord_index,s=n.texcoord_scale,l=n.texcoord_normalize;if(i){l=l||1;var c=s||h.default_uvs,f=a(c,4),d=f[0],p=f[1],m=f[2],g=f[3]}for(var v=e.length,_=0;v>_;_++){var y=e[_];if(i)var b=u["default"].findBoundingBox(y),x=a(b,4),w=x[0],A=x[1],T=x[2],k=x[3],E=T-w,S=k-A,R=(m-d)/E,M=(g-p)/S;for(var j=o(y),P=j.length,z=0;P>z;z++){var N=j[z];r[0]=N[0],r[1]=N[1],i&&(r[i+0]=((N[0]-w)*R+d)*l,r[i+1]=((N[1]-A)*M+p)*l),t.addVertex(r)}}}function i(e,t,r,i,o,s,l,u,c){var d=c.remove_tile_edges,p=c.tile_edge_tolerance,g=c.texcoord_index,v=c.texcoord_scale,_=c.texcoord_normalize,y=c.winding,b=t+(i||0),x=t+r;if(s[2]=x,n(e,o,s,{texcoord_index:g,texcoord_scale:v,texcoord_normalize:_}),g){_=_||1;var w=v||h.default_uvs,A=a(w,4),T=A[0],k=A[1],E=A[2],S=A[3],R=[[T,S],[T,k],[E,k],[E,k],[E,S],[T,S]]}for(var M=e.length,j=0;M>j;j++)for(var P=e[j],z=0;z$)){var C=[0,0],G=[0,0],B=[0,0],q=[0,0],V=[0,0],W=[0,0],H=!1,X=!0;d(U);for(var Z=0;$>Z;Z++){if(X=$>Z+1,H)C=G,q=v["default"].normalize(v["default"].perp(C,D[Z]));else if(0===Z&&s===!0){var Y=!0;l&&b.outsideTile(D[Z],D[$-2],u)&&(Y=!1),Y&&(C=D[$-2],q=v["default"].normalize(v["default"].perp(C,D[Z])),H=!0)}if(G=D[Z],X?B=D[Z+1]:s===!0&&(B=D[1],X=!0),X&&(W=v["default"].normalize(v["default"].perp(G,B)),l&&b.outsideTile(G,B,u)))V=v["default"].normalize(v["default"].perp(C,G)),H&&(a(G,V,U.texcoords&&v["default"].length(v["default"].sub(G,C)),U),U.num_pairs++,d(U)),H=!1;else{if(H)if(X){V=v["default"].normalize(v["default"].add(q,W));var J=2/(1+Math.abs(v["default"].dot(q,V)));V=v["default"].mult(V,J*J)}else V=v["default"].normalize(v["default"].perp(C,G));else{if(!X)continue;W=v["default"].normalize(v["default"].perp(G,B)),V=W}(H||X)&&(0!==Z||H||s||f(G,V,R,!0,U),0===M&&v["default"].lengthSq(V)>j&&(M=A.bevel),0!==M&&H&&X?c([C,G,B],[q,V,W],M,U):a(G,V,U.texcoords&&v["default"].length(v["default"].sub(G,C)),U),X&&U.num_pairs++,H=!0)}}d(U),s||f(G,V,R,!1,U)}}}}function i(e,t){var r=void 0,n=void 0;for(r=0;ru)){d(c);var f=v["default"].set(t),p=[0,0],m=v["default"].angleBetween(t,n),g=m/u;if(l||(g*=-1),c.texcoords)var _=v["default"].set(i),y=v["default"].div(v["default"].sub(s,i),u);o(e,r,a,c),o(e,f,i,c);for(var b=0;u>b;b++)p=v["default"].normalize(f),f=v["default"].rot(v["default"].normalize(f),g),c.texcoords&&(_=v["default"].add(_,y)),o(e,f,_,c);for(var x=0;u>x;x++)l?(h(x+2,c),h(0,c),h(x+1,c)):(h(x+1,c),h(0,c),h(x+2,c));c.vertices=[],c.scalingVecs&&(c.scalingVecs=[]),c.texcoords&&(c.texcoords=[])}}function l(e,t,r,n,i,a,s,l,u){d(u),o(e,r,a,u),o(e,t,i,u),o(e,n,s,u),l?(h(2,u),h(0,u),h(1,u)):(h(1,u),h(0,u),h(2,u)),u.vertices=[],u.scalingVecs&&(u.scalingVecs=[]),u.texcoords&&(u.texcoords=[])}function u(e,t,r,n,i,a,s,l){d(l);var u=v["default"].set(t),c=[0,0];if(l.texcoords)var f=v["default"].set(n),p=v["default"].div(v["default"].sub(a,n),4);var m=.78539816339;s||(m*=-1),o(e,x,i,l),o(e,u,n,l);for(var g=0;4>g;g++){if(c=v["default"].normalize(u),u=v["default"].rot(v["default"].normalize(u),m),0===g||2===g){var _=2/(1+Math.abs(v["default"].dot(c,u)));u=v["default"].mult(u,_*_)}l.texcoords&&(f=v["default"].add(f,p)),1!==g&&o(e,u,f,l)}for(var y=0;3>y;y++)s?(h(y+2,l),h(0,l),h(y+1,l)):(h(y+1,l),h(0,l),h(y+2,l));l.vertices=[],l.scalingVecs&&(l.scalingVecs=[]),l.texcoords&&(l.texcoords=[])}function c(e,t,r,n){var i,a,u,c=v["default"].signed_area(e[0],e[1],e[2])>0,f=t[0],h=v["default"].neg(t[1]),d=t[2];n.texcoords&&(n.total_dist+=v["default"].length(v["default"].sub(e[1],e[0]))*n.v_scale,i=[n.max_u,n.total_dist],u=[n.min_u,n.total_dist],a=i),c?(o(e[1],f,i,n),o(e[1],h,u,n)):(f=v["default"].neg(t[0]),h=t[1],d=v["default"].neg(t[2]),n.texcoords&&(i=[n.min_u,n.total_dist],u=[n.max_u,n.total_dist],a=i),o(e[1],h,u,n),o(e[1],f,i,n)),1===r?l(e[1],f,h,d,i,u,a,c,n):r>1&&s(e[1],f,h,d,i,u,a,c,r,n),c?(o(e[1],d,a,n),o(e[1],h,u,n)):(o(e[1],h,u,n),o(e[1],d,a,n))}function f(e,t,r,n,i){if(!(1>r)){var o,a,l;i.texcoords&&(l=[i.min_u+(i.max_u-i.min_u)/2,i.total_dist],o=[i.min_u,i.total_dist],a=[i.max_u,i.total_dist]),2===r?u(e,v["default"].neg(t),t,o,l,a,n,i):s(e,v["default"].neg(t),x,t,o,l,a,n,2*r,i)}}function h(e,t){var r=t.vertex_data,n=t.vertex_template,i=t.half_width,o=t.vertices,a=t.scaling_index,s=t.scaling_normalize,l=t.scalingVecs,u=t.texcoord_index,c=t.texcoords,f=t.texcoord_normalize;e>=o.length||(n[0]=o[e][0],n[1]=o[e][1],u&&(n[u+0]=c[e][0]*f,n[u+1]=c[e][1]*f),a&&(n[a+0]=l[e][0]*s,n[a+1]=l[e][1]*s,n[a+2]=i),r.addVertex(n))}function d(e){for(var t=0;t180||-180>e)&&(e=((e+180)%360+360)%360-180),e},o.transformGeometry=function(e,t){null!=e&&("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)})}))},o.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]},o.geometryType=function(e){return"Polygon"===e||"MultiPolygon"===e?"polygon":"LineString"===e||"MultiLineString"===e?"line":"Point"===e||"MultiPoint"===e?"point":void 0},o.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]},o.polygonArea=function(e){return Math.abs(o.signedPolygonAreaSum(e))/2},o.multiPolygonArea=function(e){for(var t=0,r=0;r0?"CW":0>t?"CCW":void 0},o.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 n=0;n=2&&l.length<=4?r.push({type:"vec"+l.length,method:l.length+"fv",name:o,value:l,key:s,uniforms:e}):l.length>4&&r.push({type:"float[]",method:"1fv",name:o+"[0]",value:l,key:s,uniforms:e});else if("string"==typeof l[0])for(a=0;a=2&&l[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=arguments.length<=2||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=arguments.length<=1||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=arguments.length<=1||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},t.exports=r["default"]},{"babel-runtime/helpers/to-consumable-array":25}],206:[function(e,t,r){"use strict";var n=e("babel-runtime/helpers/create-class")["default"],i=e("babel-runtime/helpers/class-call-check")["default"];Object.defineProperty(r,"__esModule",{value:!0});var o=function(){function e(t,r){i(this,e),r(t),this.value=t,this.setup=r}return n(e,[{key:"set",value:function(e){JSON.stringify(this.value)!==JSON.stringify(e)&&(this.setup(e),this.value=e)}}],[{key:"initialize",value:function(t){e.defaults={},e.defaults.culling=!0,e.defaults.culling_face=t.BACK,e.defaults.blending=!1,e.defaults.blending_src=t.ONE_MINUS_SRC_ALPHA,e.defaults.blending_dst=t.ONE_MINUS_SRC_ALPHA,e.defaults.blending_src_alpha=t.ONE,e.defaults.blending_dst_alpha=t.ONE_MINUS_SRC_ALPHA,e.defaults.depth_write=!0,e.defaults.depth_test=!0,t.depthFunc(t.LESS),e.culling=new e({cull:e.defaults.culling,face:e.defaults.culling_face},function(e){e.cull?(t.enable(t.CULL_FACE),t.cullFace(e.face)):t.disable(t.CULL_FACE)}),e.blending=new e({blend:e.defaults.blending,src:e.defaults.blending_src,dst:e.defaults.blending_dst,src_alpha:e.defaults.blending_src_alpha,dst_alpha:e.defaults.blending_dst_alpha},function(e){e.blend?(t.enable(t.BLEND),e.src_alpha&&e.dst_alpha?t.blendFuncSeparate(e.src,e.dst,e.src_alpha,e.dst_alpha):t.blendFunc(e.src,e.dst)):t.disable(t.BLEND)}),e.depth_write=new e({depth_write:e.defaults.depth_write},function(e){t.depthMask(e.depth_write)}),e.depth_test=new e({depth_test:e.defaults.depth_test},function(e){e.depth_test?t.enable(t.DEPTH_TEST):t.disable(t.DEPTH_TEST)})}}]),e}();r["default"]=o,t.exports=r["default"]},{"babel-runtime/helpers/class-call-check":18,"babel-runtime/helpers/create-class":19}],207:[function(e,t,r){"use strict";var n=e("babel-runtime/helpers/create-class")["default"],i=e("babel-runtime/helpers/class-call-check")["default"],o=e("babel-runtime/helpers/to-consumable-array")["default"],a=e("babel-runtime/core-js/object/assign")["default"],s=e("babel-runtime/core-js/get-iterator")["default"],l=e("babel-runtime/helpers/interop-require-default")["default"];Object.defineProperty(r,"__esModule",{value:!0});var u=e("./glsl"),c=l(u),f=e("./texture"),h=l(f),d=e("./extensions"),p=l(d),m=e("loglevel"),g=l(m),v=e("strip-comments"),_=l(v),y=e("gl-shader-errors"),b=l(y),x=function(){function e(t,r,n,o){i(this,e),o=o||{},this.gl=t,this.program=null,this.compiled=!1,this.compiling=!1,this.error=null,this.defines=a({},o.defines||{}),this.blocks=a({},o.blocks||{}),this.block_scopes=a({},o.block_scopes||{}),this.extensions=o.extensions||[],this.dependent_uniforms=o.uniforms,this.uniforms={},this.attribs={},this.vertex_source=r,this.fragment_source=n,this.id=e.id++,e.programs[this.id]=this,this.name=o.name}return n(e,[{key:"destroy",value:function(){this.gl.useProgram(null),this.gl.deleteProgram(this.program),this.program=null,this.uniforms={},this.attribs={},delete e.programs[this.id],this.compiled=!1}},{key:"use",value:function(){this.compiled&&(e.current!==this&&this.gl.useProgram(this.program),e.current=this)}},{key:"compile",value:function(){if(this.compiling)throw new Error("ShaderProgram.compile(): skipping for "+this.id+" ("+this.name+") because already compiling");this.compiling=!0,this.compiled=!1,this.error=null,this.computed_vertex_source=this.vertex_source,this.computed_fragment_source=this.fragment_source;var t,r=this.checkExtensions(),n=this.buildDefineList(),i=this.buildShaderBlockList();for(var o in i){var a=i[o];if(a&&(!Array.isArray(a)||0!==a.length)){t=new RegExp("^\\s*#pragma\\s+tangram:\\s+"+o+"\\s*$","m");var l=this.computed_vertex_source.match(t),u=this.computed_fragment_source.match(t);if(null!=l||null!=u){var c="";a.forEach(function(e){var t=e.scope+", "+e.key+", "+e.num;c+="\n// tangram-block-start: "+t+"\n",c+=e.source,c+="\n// tangram-block-end: "+t+"\n"}),null!=l&&(this.computed_vertex_source=this.computed_vertex_source.replace(t,c)),null!=u&&(this.computed_fragment_source=this.computed_fragment_source.replace(t,c)),n["TANGRAM_BLOCK_"+o.replace(/[\s-]+/g,"_").toUpperCase()]=!0}}}t=new RegExp("^\\s*#pragma.*$","gm"),this.computed_vertex_source=this.computed_vertex_source.replace(t,""),this.computed_fragment_source=this.computed_fragment_source.replace(t,""),this.ensureUniforms(this.dependent_uniforms);var f=this.name?this.name+" / id "+this.id:"id "+this.id,h="// Program: "+f+"\n",d="",p=this.gl.getShaderPrecisionFormat(this.gl.FRAGMENT_SHADER,this.gl.HIGH_FLOAT);d=p&&p.precision>0?"precision highp float;\n":"precision mediump float;\n",n.TANGRAM_VERTEX_SHADER=!0,n.TANGRAM_FRAGMENT_SHADER=!1,this.computed_vertex_source=h+d+e.buildDefineString(n)+this.computed_vertex_source,n.TANGRAM_VERTEX_SHADER=!1,n.TANGRAM_FRAGMENT_SHADER=!0,this.computed_fragment_source=e.buildExtensionString(r)+h+d+e.buildDefineString(n)+this.computed_fragment_source;try{this.program=e.updateProgram(this.gl,this.program,this.computed_vertex_source,this.computed_fragment_source),this.compiled=!0,this.compiling=!1}catch(m){if(this.program=null,this.compiled=!1,this.compiling=!1,this.error=m,"vertex"===m.type||"fragment"===m.type){this.shader_errors=m.errors;var g=!0,v=!1,_=void 0;try{for(var y,b=s(this.shader_errors);!(g=(y=b.next()).done);g=!0){var x=y.value;x.type=m.type,x.block=this.block(m.type,x.line)}}catch(w){v=!0,_=w}finally{try{!g&&b["return"]&&b["return"]()}finally{if(v)throw _}}}throw new Error("ShaderProgram.compile(): program "+this.id+" ("+this.name+") error:",m)}this.use(),this.refreshUniforms(),this.refreshAttributes()}},{key:"buildDefineList",value:function(){var t,r={};for(t in e.defines)r[t]=e.defines[t];for(t in this.defines)r[t]=this.defines[t];return r}},{key:"buildShaderBlockList",value:function(){var t=void 0,r={};for(t in e.blocks)if(r[t]=[],Array.isArray(e.blocks[t])){var n;(n=r[t]).push.apply(n,o(e.blocks[t].map(function(e,r){return{key:t,source:e,num:r,scope:"ShaderProgram"}})))}else r[t]=[{key:t,source:e.blocks[t],num:0,scope:"ShaderProgram"}];for(t in this.blocks)if(r[t]=r[t]||[],Array.isArray(this.blocks[t]))for(var i=this.block_scopes&&this.block_scopes[t]||[],a=null,s=0,l=0;l0&&(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)}}},{key:"setUniforms",value:function(e){var t=arguments.length<=1||void 0===arguments[1]?!0:arguments[1];if(this.compiled){t&&(this.texture_unit=0);var r=c["default"].parseUniforms(e),n=!0,i=!1,o=void 0;try{for(var a,l=s(r);!(n=(a=l.next()).done);n=!0){var u=a.value;"sampler2D"===u.type?this.setTextureUniform(u.name,u.value):this.uniform(u.method,u.name,u.value)}}catch(f){i=!0,o=f}finally{try{!n&&l["return"]&&l["return"]()}finally{if(i)throw o}}}}},{key:"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}},{key:"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}},{key:"setTextureUniform",value:function(e,t){var r=h["default"].textures[t];return null==r?void g["default"].warn("Can't find texture '"+t+"'"):(r.bind(this.texture_unit),this.uniform("1i",e,this.texture_unit),void this.texture_unit++) +}},{key:"uniform",value:function t(e,r){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;for(var n=arguments.length,i=Array(n>2?n-2:0),o=2;n>o;o++)i[o-2]=arguments[o];t.value=i,this.updateUniform(r)}}},{key:"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)))}}},{key:"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)}},{key:"refreshAttributes",value:function(){this.attribs={}}},{key:"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)}}},{key:"source",value:function(e){return"vertex"===e?this.computed_vertex_source:"fragment"===e?this.computed_fragment_source:void 0}},{key:"lines",value:function(e){var t=this.source(e);return t?t.split("\n"):[]}},{key:"line",value:function(e,t){var r=this.lines(e);return r?r[t]:void 0}},{key:"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: ([A-Za-z0-9_-]+), ([A-Za-z0-9_-]+), (\d+)/),a&&a.length>1&&(r=null)),r&&(r.line=null==r.line?-1:r.line+1,r.source=o)}return r}},{key:"checkExtensions",value:function(){var e=[],t=!0,r=!1,n=void 0;try{for(var i,o=s(this.extensions);!(t=(i=o.next()).done);t=!0){var a=i.value,l=p["default"](this.gl,a),u="TANGRAM_EXTENSION_"+a;this.defines[u]=null!=l,l?e.push(a):g["default"].debug("Could not enable extension '"+a+"'")}}catch(c){r=!0,n=c}finally{try{!t&&o["return"]&&o["return"]()}finally{if(r)throw n}}return e}}]),e}();r["default"]=x,x.id=0,x.programs={},x.current=null,x.defines={},x.blocks={},x.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},x.buildExtensionString=function(e){e=e||[];var t="",r=!0,n=!1,i=void 0;try{for(var o,a=s(e);!(r=(o=a.next()).done);r=!0){var l=o.value;t+="#ifdef GL_"+l+"\n#extension GL_"+l+" : enable\n#endif\n"}}catch(u){n=!0,i=u}finally{try{!r&&a["return"]&&a["return"]()}finally{if(n)throw i}}return t},x.addBlock=function(e){var t;x.blocks[e]=x.blocks[e]||[];for(var r=arguments.length,n=Array(r>1?r-1:0),i=1;r>i;i++)n[i-1]=arguments[i];(t=x.blocks[e]).push.apply(t,n)},x.removeBlock=function(e){x.blocks[e]=[]},x.replaceBlock=function(e){x.removeBlock(e);for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;t>n;n++)r[n-1]=arguments[n];x.addBlock.apply(x,[e].concat(r))},x.updateProgram=function(e,t,r,n){try{var i=x.createShader(e,r,e.VERTEX_SHADER),o=x.createShader(e,n,e.FRAGMENT_SHADER)}catch(a){throw g["default"].error(a.message),a}if(e.useProgram(null),null!=t)for(var s=e.getAttachedShaders(t),l=0;l0?void v["default"].error("Texture '"+this.name+"': destroying texture with retain count of '"+this.retain_count+"'"):void(this.valid&&(this.gl.deleteTexture(this.texture),this.texture=null,delete this.data,this.data=null,delete e.textures[this.name],this.valid=!1,v["default"].trace("destroying Texture "+this.name)))}},{key:"retain",value:function(){this.retain_count++}},{key:"release",value:function(){this.retain_count<=0&&v["default"].error("Texture '"+this.name+"': releasing texture with retain count of '"+this.retain_count+"'"),this.retain_count--,this.retain_count<=0&&this.destroy()}},{key:"bind",value:function(t){this.valid&&("number"==typeof t&&e.activeUnit!==t&&(this.gl.activeTexture(this.gl.TEXTURE0+t),e.activeUnit=t),e.activeTexture!==this.texture&&(this.gl.bindTexture(this.gl.TEXTURE_2D,this.texture),e.activeTexture=this.texture))}},{key:"load",value:function(e){var t=this;return e?(this.loading=null,"string"==typeof e.url?(this.config_type="url",this.setUrl(e.url,e)):e.element?(this.config_type="element",this.setElement(e.element,e)):e.data&&e.width&&e.height&&(this.config_type="data",this.setData(e.width,e.height,e.data,e)),this.loading=this.loading&&this.loading.then(function(){return t.calculateSprites(),t})||a.resolve(this),this.loading):this.loading||a.resolve(this)}},{key:"setUrl",value:function(t){var r=this,n=arguments.length<=1||void 0===arguments[1]?{}:arguments[1];return this.valid?(e.base_url&&(t=f["default"].addBaseURL(t,e.base_url)),this.url=f["default"].cacheBusterForUrl(t),this.source=this.url,this.source_type="url",this.loading=new a(function(t){var i=new Image;i.onload=function(){try{r.setElement(i,n)}catch(o){r.loaded=!1,v["default"].warn("Texture '"+r.name+"': failed to load url: '"+r.source+"'",o,n),e.trigger("warning",{message:"Failed to load texture from "+r.source,error:o,texture:n})}r.loaded=!0,t(r)},i.onerror=function(i){r.loaded=!1,v["default"].warn("Texture '"+r.name+"': failed to load url: '"+r.source+"'",i,n),e.trigger("warning",{message:"Failed to load texture from "+r.source,error:i,texture:n}),t(r)},i.crossOrigin="anonymous",i.src=r.source}),this.loading):void 0}},{key:"setData",value:function(e,t,r){var n=arguments.length<=3||void 0===arguments[3]?{}:arguments[3];return this.width=e,this.height=t,this.source=r,this.source_type="data",this.update(n),this.setFiltering(n),this.loaded=!0,this.loading=a.resolve(this),this.loading}},{key:"setElement",value:function(t,r){var n=t;if("string"==typeof t&&(t=document.querySelector(t)),t instanceof HTMLCanvasElement||t instanceof HTMLImageElement||t instanceof HTMLVideoElement)this.source=t,this.source_type="element",this.update(r),this.setFiltering(r);else{this.loaded=!1;var i="the 'element' parameter (`element: "+JSON.stringify(n)+"`) must be a CSS ";i+="selector string, or a , or