Newer
Older
www-root / coverage / lib / Leaflet.MapboxVectorTile.js
@root root on 25 Aug 2018 293 KB 2018-08-25
  1. (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})({1:[function(require,module,exports){
  2. (function (Buffer){
  3. 'use strict';
  4.  
  5. var ieee754 = require('ieee754');
  6.  
  7. module.exports = Protobuf;
  8. function Protobuf(buf) {
  9. this.buf = buf;
  10. this.pos = 0;
  11. }
  12.  
  13. Protobuf.prototype = {
  14. get length() { return this.buf.length; }
  15. };
  16.  
  17. Protobuf.Varint = 0;
  18. Protobuf.Int64 = 1;
  19. Protobuf.Message = 2;
  20. Protobuf.String = 2;
  21. Protobuf.Packed = 2;
  22. Protobuf.Int32 = 5;
  23.  
  24. Protobuf.prototype.destroy = function() {
  25. this.buf = null;
  26. };
  27.  
  28. // === READING =================================================================
  29.  
  30. Protobuf.prototype.readUInt32 = function() {
  31. var val = this.buf.readUInt32LE(this.pos);
  32. this.pos += 4;
  33. return val;
  34. };
  35.  
  36. Protobuf.prototype.readUInt64 = function() {
  37. var val = this.buf.readUInt64LE(this.pos);
  38. this.pos += 8;
  39. return val;
  40. };
  41.  
  42. Protobuf.prototype.readDouble = function() {
  43. var val = ieee754.read(this.buf, this.pos, true, 52, 8);
  44. this.pos += 8;
  45. return val;
  46. };
  47.  
  48. Protobuf.prototype.readVarint = function() {
  49. // TODO: bounds checking
  50. var pos = this.pos;
  51. if (this.buf[pos] <= 0x7f) {
  52. this.pos++;
  53. return this.buf[pos];
  54. } else if (this.buf[pos + 1] <= 0x7f) {
  55. this.pos += 2;
  56. return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] << 7);
  57. } else if (this.buf[pos + 2] <= 0x7f) {
  58. this.pos += 3;
  59. return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2]) << 14;
  60. } else if (this.buf[pos + 3] <= 0x7f) {
  61. this.pos += 4;
  62. return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2] & 0x7f) << 14 | (this.buf[pos + 3]) << 21;
  63. } else if (this.buf[pos + 4] <= 0x7f) {
  64. this.pos += 5;
  65. return ((this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2] & 0x7f) << 14 | (this.buf[pos + 3]) << 21) + (this.buf[pos + 4] * 268435456);
  66. } else {
  67. this.skip(Protobuf.Varint);
  68. return 0;
  69. // throw new Error("TODO: Handle 6+ byte varints");
  70. }
  71. };
  72.  
  73. Protobuf.prototype.readSVarint = function() {
  74. var num = this.readVarint();
  75. if (num > 2147483647) throw new Error('TODO: Handle numbers >= 2^30');
  76. // zigzag encoding
  77. return ((num >> 1) ^ -(num & 1));
  78. };
  79.  
  80. Protobuf.prototype.readString = function() {
  81. var bytes = this.readVarint();
  82. // TODO: bounds checking
  83. var chr = String.fromCharCode;
  84. var b = this.buf;
  85. var p = this.pos;
  86. var end = this.pos + bytes;
  87. var str = '';
  88. while (p < end) {
  89. if (b[p] <= 0x7F) str += chr(b[p++]);
  90. else if (b[p] <= 0xBF) throw new Error('Invalid UTF-8 codepoint: ' + b[p]);
  91. else if (b[p] <= 0xDF) str += chr((b[p++] & 0x1F) << 6 | (b[p++] & 0x3F));
  92. else if (b[p] <= 0xEF) str += chr((b[p++] & 0x1F) << 12 | (b[p++] & 0x3F) << 6 | (b[p++] & 0x3F));
  93. else if (b[p] <= 0xF7) p += 4; // We can't handle these codepoints in JS, so skip.
  94. else if (b[p] <= 0xFB) p += 5;
  95. else if (b[p] <= 0xFD) p += 6;
  96. else throw new Error('Invalid UTF-8 codepoint: ' + b[p]);
  97. }
  98. this.pos += bytes;
  99. return str;
  100. };
  101.  
  102. Protobuf.prototype.readBuffer = function() {
  103. var bytes = this.readVarint();
  104. var buffer = this.buf.subarray(this.pos, this.pos + bytes);
  105. this.pos += bytes;
  106. return buffer;
  107. };
  108.  
  109. Protobuf.prototype.readPacked = function(type) {
  110. // TODO: bounds checking
  111. var bytes = this.readVarint();
  112. var end = this.pos + bytes;
  113. var array = [];
  114. while (this.pos < end) {
  115. array.push(this['read' + type]());
  116. }
  117. return array;
  118. };
  119.  
  120. Protobuf.prototype.skip = function(val) {
  121. // TODO: bounds checking
  122. var type = val & 0x7;
  123. switch (type) {
  124. /* varint */ case Protobuf.Varint: while (this.buf[this.pos++] > 0x7f); break;
  125. /* 64 bit */ case Protobuf.Int64: this.pos += 8; break;
  126. /* length */ case Protobuf.Message: var bytes = this.readVarint(); this.pos += bytes; break;
  127. /* 32 bit */ case Protobuf.Int32: this.pos += 4; break;
  128. default: throw new Error('Unimplemented type: ' + type);
  129. }
  130. };
  131.  
  132. // === WRITING =================================================================
  133.  
  134. Protobuf.prototype.writeTag = function(tag, type) {
  135. this.writeVarint((tag << 3) | type);
  136. };
  137.  
  138. Protobuf.prototype.realloc = function(min) {
  139. var length = this.buf.length;
  140. while (length < this.pos + min) length *= 2;
  141. if (length != this.buf.length) {
  142. var buf = new Buffer(length);
  143. this.buf.copy(buf);
  144. this.buf = buf;
  145. }
  146. };
  147.  
  148. Protobuf.prototype.finish = function() {
  149. return this.buf.slice(0, this.pos);
  150. };
  151.  
  152. Protobuf.prototype.writePacked = function(type, tag, items) {
  153. if (!items.length) return;
  154.  
  155. var message = new Protobuf();
  156. for (var i = 0; i < items.length; i++) {
  157. message['write' + type](items[i]);
  158. }
  159. var data = message.finish();
  160.  
  161. this.writeTag(tag, Protobuf.Packed);
  162. this.writeBuffer(data);
  163. };
  164.  
  165. Protobuf.prototype.writeUInt32 = function(val) {
  166. this.realloc(4);
  167. this.buf.writeUInt32LE(val, this.pos);
  168. this.pos += 4;
  169. };
  170.  
  171. Protobuf.prototype.writeTaggedUInt32 = function(tag, val) {
  172. this.writeTag(tag, Protobuf.Int32);
  173. this.writeUInt32(val);
  174. };
  175.  
  176. Protobuf.prototype.writeVarint = function(val) {
  177. val = Number(val);
  178. if (isNaN(val)) {
  179. val = 0;
  180. }
  181.  
  182. if (val <= 0x7f) {
  183. this.realloc(1);
  184. this.buf[this.pos++] = val;
  185. } else if (val <= 0x3fff) {
  186. this.realloc(2);
  187. this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);
  188. this.buf[this.pos++] = 0x00 | ((val >>> 7) & 0x7f);
  189. } else if (val <= 0x1ffffff) {
  190. this.realloc(3);
  191. this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);
  192. this.buf[this.pos++] = 0x80 | ((val >>> 7) & 0x7f);
  193. this.buf[this.pos++] = 0x00 | ((val >>> 14) & 0x7f);
  194. } else if (val <= 0xfffffff) {
  195. this.realloc(4);
  196. this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);
  197. this.buf[this.pos++] = 0x80 | ((val >>> 7) & 0x7f);
  198. this.buf[this.pos++] = 0x80 | ((val >>> 14) & 0x7f);
  199. this.buf[this.pos++] = 0x00 | ((val >>> 21) & 0x7f);
  200. } else {
  201. while (val > 0) {
  202. var b = val & 0x7f;
  203. val = Math.floor(val / 128);
  204. if (val > 0) b |= 0x80
  205. this.realloc(1);
  206. this.buf[this.pos++] = b;
  207. }
  208. }
  209. };
  210.  
  211. Protobuf.prototype.writeTaggedVarint = function(tag, val) {
  212. this.writeTag(tag, Protobuf.Varint);
  213. this.writeVarint(val);
  214. };
  215.  
  216. Protobuf.prototype.writeSVarint = function(val) {
  217. if (val >= 0) {
  218. this.writeVarint(val * 2);
  219. } else {
  220. this.writeVarint(val * -2 - 1);
  221. }
  222. };
  223.  
  224. Protobuf.prototype.writeTaggedSVarint = function(tag, val) {
  225. this.writeTag(tag, Protobuf.Varint);
  226. this.writeSVarint(val);
  227. };
  228.  
  229. Protobuf.prototype.writeBoolean = function(val) {
  230. this.writeVarint(Boolean(val));
  231. };
  232.  
  233. Protobuf.prototype.writeTaggedBoolean = function(tag, val) {
  234. this.writeTaggedVarint(tag, Boolean(val));
  235. };
  236.  
  237. Protobuf.prototype.writeString = function(str) {
  238. str = String(str);
  239. var bytes = Buffer.byteLength(str);
  240. this.writeVarint(bytes);
  241. this.realloc(bytes);
  242. this.buf.write(str, this.pos);
  243. this.pos += bytes;
  244. };
  245.  
  246. Protobuf.prototype.writeTaggedString = function(tag, str) {
  247. this.writeTag(tag, Protobuf.String);
  248. this.writeString(str);
  249. };
  250.  
  251. Protobuf.prototype.writeFloat = function(val) {
  252. this.realloc(4);
  253. this.buf.writeFloatLE(val, this.pos);
  254. this.pos += 4;
  255. };
  256.  
  257. Protobuf.prototype.writeTaggedFloat = function(tag, val) {
  258. this.writeTag(tag, Protobuf.Int32);
  259. this.writeFloat(val);
  260. };
  261.  
  262. Protobuf.prototype.writeDouble = function(val) {
  263. this.realloc(8);
  264. this.buf.writeDoubleLE(val, this.pos);
  265. this.pos += 8;
  266. };
  267.  
  268. Protobuf.prototype.writeTaggedDouble = function(tag, val) {
  269. this.writeTag(tag, Protobuf.Int64);
  270. this.writeDouble(val);
  271. };
  272.  
  273. Protobuf.prototype.writeBuffer = function(buffer) {
  274. var bytes = buffer.length;
  275. this.writeVarint(bytes);
  276. this.realloc(bytes);
  277. buffer.copy(this.buf, this.pos);
  278. this.pos += bytes;
  279. };
  280.  
  281. Protobuf.prototype.writeTaggedBuffer = function(tag, buffer) {
  282. this.writeTag(tag, Protobuf.String);
  283. this.writeBuffer(buffer);
  284. };
  285.  
  286. Protobuf.prototype.writeMessage = function(tag, protobuf) {
  287. var buffer = protobuf.finish();
  288. this.writeTag(tag, Protobuf.Message);
  289. this.writeBuffer(buffer);
  290. };
  291.  
  292. }).call(this,require("buffer").Buffer)
  293.  
  294. },{"buffer":14,"ieee754":2}],2:[function(require,module,exports){
  295. exports.read = function (buffer, offset, isLE, mLen, nBytes) {
  296. var e, m
  297. var eLen = nBytes * 8 - mLen - 1
  298. var eMax = (1 << eLen) - 1
  299. var eBias = eMax >> 1
  300. var nBits = -7
  301. var i = isLE ? (nBytes - 1) : 0
  302. var d = isLE ? -1 : 1
  303. var s = buffer[offset + i]
  304.  
  305. i += d
  306.  
  307. e = s & ((1 << (-nBits)) - 1)
  308. s >>= (-nBits)
  309. nBits += eLen
  310. for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}
  311.  
  312. m = e & ((1 << (-nBits)) - 1)
  313. e >>= (-nBits)
  314. nBits += mLen
  315. for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}
  316.  
  317. if (e === 0) {
  318. e = 1 - eBias
  319. } else if (e === eMax) {
  320. return m ? NaN : ((s ? -1 : 1) * Infinity)
  321. } else {
  322. m = m + Math.pow(2, mLen)
  323. e = e - eBias
  324. }
  325. return (s ? -1 : 1) * m * Math.pow(2, e - mLen)
  326. }
  327.  
  328. exports.write = function (buffer, value, offset, isLE, mLen, nBytes) {
  329. var e, m, c
  330. var eLen = nBytes * 8 - mLen - 1
  331. var eMax = (1 << eLen) - 1
  332. var eBias = eMax >> 1
  333. var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)
  334. var i = isLE ? 0 : (nBytes - 1)
  335. var d = isLE ? 1 : -1
  336. var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0
  337.  
  338. value = Math.abs(value)
  339.  
  340. if (isNaN(value) || value === Infinity) {
  341. m = isNaN(value) ? 1 : 0
  342. e = eMax
  343. } else {
  344. e = Math.floor(Math.log(value) / Math.LN2)
  345. if (value * (c = Math.pow(2, -e)) < 1) {
  346. e--
  347. c *= 2
  348. }
  349. if (e + eBias >= 1) {
  350. value += rt / c
  351. } else {
  352. value += rt * Math.pow(2, 1 - eBias)
  353. }
  354. if (value * c >= 2) {
  355. e++
  356. c /= 2
  357. }
  358.  
  359. if (e + eBias >= eMax) {
  360. m = 0
  361. e = eMax
  362. } else if (e + eBias >= 1) {
  363. m = (value * c - 1) * Math.pow(2, mLen)
  364. e = e + eBias
  365. } else {
  366. m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)
  367. e = 0
  368. }
  369. }
  370.  
  371. for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}
  372.  
  373. e = (e << mLen) | m
  374. eLen += mLen
  375. for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}
  376.  
  377. buffer[offset + i - d] |= s * 128
  378. }
  379.  
  380. },{}],3:[function(require,module,exports){
  381. 'use strict';
  382.  
  383. module.exports = Point;
  384.  
  385. function Point(x, y) {
  386. this.x = x;
  387. this.y = y;
  388. }
  389.  
  390. Point.prototype = {
  391. clone: function() { return new Point(this.x, this.y); },
  392.  
  393. add: function(p) { return this.clone()._add(p); },
  394. sub: function(p) { return this.clone()._sub(p); },
  395. mult: function(k) { return this.clone()._mult(k); },
  396. div: function(k) { return this.clone()._div(k); },
  397. rotate: function(a) { return this.clone()._rotate(a); },
  398. matMult: function(m) { return this.clone()._matMult(m); },
  399. unit: function() { return this.clone()._unit(); },
  400. perp: function() { return this.clone()._perp(); },
  401. round: function() { return this.clone()._round(); },
  402.  
  403. mag: function() {
  404. return Math.sqrt(this.x * this.x + this.y * this.y);
  405. },
  406.  
  407. equals: function(p) {
  408. return this.x === p.x &&
  409. this.y === p.y;
  410. },
  411.  
  412. dist: function(p) {
  413. return Math.sqrt(this.distSqr(p));
  414. },
  415.  
  416. distSqr: function(p) {
  417. var dx = p.x - this.x,
  418. dy = p.y - this.y;
  419. return dx * dx + dy * dy;
  420. },
  421.  
  422. angle: function() {
  423. return Math.atan2(this.y, this.x);
  424. },
  425.  
  426. angleTo: function(b) {
  427. return Math.atan2(this.y - b.y, this.x - b.x);
  428. },
  429.  
  430. angleWith: function(b) {
  431. return this.angleWithSep(b.x, b.y);
  432. },
  433.  
  434. // Find the angle of the two vectors, solving the formula for the cross product a x b = |a||b|sin(θ) for θ.
  435. angleWithSep: function(x, y) {
  436. return Math.atan2(
  437. this.x * y - this.y * x,
  438. this.x * x + this.y * y);
  439. },
  440.  
  441. _matMult: function(m) {
  442. var x = m[0] * this.x + m[1] * this.y,
  443. y = m[2] * this.x + m[3] * this.y;
  444. this.x = x;
  445. this.y = y;
  446. return this;
  447. },
  448.  
  449. _add: function(p) {
  450. this.x += p.x;
  451. this.y += p.y;
  452. return this;
  453. },
  454.  
  455. _sub: function(p) {
  456. this.x -= p.x;
  457. this.y -= p.y;
  458. return this;
  459. },
  460.  
  461. _mult: function(k) {
  462. this.x *= k;
  463. this.y *= k;
  464. return this;
  465. },
  466.  
  467. _div: function(k) {
  468. this.x /= k;
  469. this.y /= k;
  470. return this;
  471. },
  472.  
  473. _unit: function() {
  474. this._div(this.mag());
  475. return this;
  476. },
  477.  
  478. _perp: function() {
  479. var y = this.y;
  480. this.y = this.x;
  481. this.x = -y;
  482. return this;
  483. },
  484.  
  485. _rotate: function(angle) {
  486. var cos = Math.cos(angle),
  487. sin = Math.sin(angle),
  488. x = cos * this.x - sin * this.y,
  489. y = sin * this.x + cos * this.y;
  490. this.x = x;
  491. this.y = y;
  492. return this;
  493. },
  494.  
  495. _round: function() {
  496. this.x = Math.round(this.x);
  497. this.y = Math.round(this.y);
  498. return this;
  499. }
  500. };
  501.  
  502. // constructs Point from an array if necessary
  503. Point.convert = function (a) {
  504. if (a instanceof Point) {
  505. return a;
  506. }
  507. if (Array.isArray(a)) {
  508. return new Point(a[0], a[1]);
  509. }
  510. return a;
  511. };
  512.  
  513. },{}],4:[function(require,module,exports){
  514. module.exports.VectorTile = require('./lib/vectortile.js');
  515. module.exports.VectorTileFeature = require('./lib/vectortilefeature.js');
  516. module.exports.VectorTileLayer = require('./lib/vectortilelayer.js');
  517.  
  518. },{"./lib/vectortile.js":5,"./lib/vectortilefeature.js":6,"./lib/vectortilelayer.js":7}],5:[function(require,module,exports){
  519. 'use strict';
  520.  
  521. var VectorTileLayer = require('./vectortilelayer');
  522.  
  523. module.exports = VectorTile;
  524.  
  525. function VectorTile(buffer, end) {
  526.  
  527. this.layers = {};
  528. this._buffer = buffer;
  529.  
  530. end = end || buffer.length;
  531.  
  532. while (buffer.pos < end) {
  533. var val = buffer.readVarint(),
  534. tag = val >> 3;
  535.  
  536. if (tag == 3) {
  537. var layer = this.readLayer();
  538. if (layer.length) this.layers[layer.name] = layer;
  539. } else {
  540. buffer.skip(val);
  541. }
  542. }
  543. }
  544.  
  545. VectorTile.prototype.readLayer = function() {
  546. var buffer = this._buffer,
  547. bytes = buffer.readVarint(),
  548. end = buffer.pos + bytes,
  549. layer = new VectorTileLayer(buffer, end);
  550.  
  551. buffer.pos = end;
  552.  
  553. return layer;
  554. };
  555.  
  556. },{"./vectortilelayer":7}],6:[function(require,module,exports){
  557. 'use strict';
  558.  
  559. var Point = require('point-geometry');
  560.  
  561. module.exports = VectorTileFeature;
  562.  
  563. function VectorTileFeature(buffer, end, extent, keys, values) {
  564.  
  565. this.properties = {};
  566.  
  567. // Public
  568. this.extent = extent;
  569. this.type = 0;
  570.  
  571. // Private
  572. this._buffer = buffer;
  573. this._geometry = -1;
  574.  
  575. end = end || buffer.length;
  576.  
  577. while (buffer.pos < end) {
  578. var val = buffer.readVarint(),
  579. tag = val >> 3;
  580.  
  581. if (tag == 1) {
  582. this._id = buffer.readVarint();
  583.  
  584. } else if (tag == 2) {
  585. var tagLen = buffer.readVarint(),
  586. tagEnd = buffer.pos + tagLen;
  587.  
  588. while (buffer.pos < tagEnd) {
  589. var key = keys[buffer.readVarint()];
  590. var value = values[buffer.readVarint()];
  591. this.properties[key] = value;
  592. }
  593.  
  594. } else if (tag == 3) {
  595. this.type = buffer.readVarint();
  596.  
  597. } else if (tag == 4) {
  598. this._geometry = buffer.pos;
  599. buffer.skip(val);
  600.  
  601. } else {
  602. buffer.skip(val);
  603. }
  604. }
  605. }
  606.  
  607. VectorTileFeature.types = ['Unknown', 'Point', 'LineString', 'Polygon'];
  608.  
  609. VectorTileFeature.prototype.loadGeometry = function() {
  610. var buffer = this._buffer;
  611. buffer.pos = this._geometry;
  612.  
  613. var bytes = buffer.readVarint(),
  614. end = buffer.pos + bytes,
  615. cmd = 1,
  616. length = 0,
  617. x = 0,
  618. y = 0,
  619. lines = [],
  620. line;
  621.  
  622. while (buffer.pos < end) {
  623. if (!length) {
  624. var cmd_length = buffer.readVarint();
  625. cmd = cmd_length & 0x7;
  626. length = cmd_length >> 3;
  627. }
  628.  
  629. length--;
  630.  
  631. if (cmd === 1 || cmd === 2) {
  632. x += buffer.readSVarint();
  633. y += buffer.readSVarint();
  634.  
  635. if (cmd === 1) {
  636. // moveTo
  637. if (line) {
  638. lines.push(line);
  639. }
  640. line = [];
  641. }
  642.  
  643. line.push(new Point(x, y));
  644. } else if (cmd === 7) {
  645. // closePolygon
  646. line.push(line[0].clone());
  647. } else {
  648. throw new Error('unknown command ' + cmd);
  649. }
  650. }
  651.  
  652. if (line) lines.push(line);
  653.  
  654. return lines;
  655. };
  656.  
  657. VectorTileFeature.prototype.bbox = function() {
  658. var buffer = this._buffer;
  659. buffer.pos = this._geometry;
  660.  
  661. var bytes = buffer.readVarint(),
  662. end = buffer.pos + bytes,
  663.  
  664. cmd = 1,
  665. length = 0,
  666. x = 0,
  667. y = 0,
  668. x1 = Infinity,
  669. x2 = -Infinity,
  670. y1 = Infinity,
  671. y2 = -Infinity;
  672.  
  673. while (buffer.pos < end) {
  674. if (!length) {
  675. var cmd_length = buffer.readVarint();
  676. cmd = cmd_length & 0x7;
  677. length = cmd_length >> 3;
  678. }
  679.  
  680. length--;
  681.  
  682. if (cmd === 1 || cmd === 2) {
  683. x += buffer.readSVarint();
  684. y += buffer.readSVarint();
  685. if (x < x1) x1 = x;
  686. if (x > x2) x2 = x;
  687. if (y < y1) y1 = y;
  688. if (y > y2) y2 = y;
  689.  
  690. } else if (cmd !== 7) {
  691. throw new Error('unknown command ' + cmd);
  692. }
  693. }
  694.  
  695. return [x1, y1, x2, y2];
  696. };
  697.  
  698. },{"point-geometry":3}],7:[function(require,module,exports){
  699. 'use strict';
  700.  
  701. var VectorTileFeature = require('./vectortilefeature.js');
  702.  
  703. module.exports = VectorTileLayer;
  704. function VectorTileLayer(buffer, end) {
  705. // Public
  706. this.version = 1;
  707. this.name = null;
  708. this.extent = 4096;
  709. this.length = 0;
  710.  
  711. // Private
  712. this._buffer = buffer;
  713. this._keys = [];
  714. this._values = [];
  715. this._features = [];
  716.  
  717. var val, tag;
  718.  
  719. end = end || buffer.length;
  720.  
  721. while (buffer.pos < end) {
  722. val = buffer.readVarint();
  723. tag = val >> 3;
  724.  
  725. if (tag === 15) {
  726. this.version = buffer.readVarint();
  727. } else if (tag === 1) {
  728. this.name = buffer.readString();
  729. } else if (tag === 5) {
  730. this.extent = buffer.readVarint();
  731. } else if (tag === 2) {
  732. this.length++;
  733. this._features.push(buffer.pos);
  734. buffer.skip(val);
  735.  
  736. } else if (tag === 3) {
  737. this._keys.push(buffer.readString());
  738. } else if (tag === 4) {
  739. this._values.push(this.readFeatureValue());
  740. } else {
  741. buffer.skip(val);
  742. }
  743. }
  744. }
  745.  
  746. VectorTileLayer.prototype.readFeatureValue = function() {
  747. var buffer = this._buffer,
  748. value = null,
  749. bytes = buffer.readVarint(),
  750. end = buffer.pos + bytes,
  751. val, tag;
  752.  
  753. while (buffer.pos < end) {
  754. val = buffer.readVarint();
  755. tag = val >> 3;
  756.  
  757. if (tag == 1) {
  758. value = buffer.readString();
  759. } else if (tag == 2) {
  760. throw new Error('read float');
  761. } else if (tag == 3) {
  762. value = buffer.readDouble();
  763. } else if (tag == 4) {
  764. value = buffer.readVarint();
  765. } else if (tag == 5) {
  766. throw new Error('read uint');
  767. } else if (tag == 6) {
  768. value = buffer.readSVarint();
  769. } else if (tag == 7) {
  770. value = Boolean(buffer.readVarint());
  771. } else {
  772. buffer.skip(val);
  773. }
  774. }
  775.  
  776. return value;
  777. };
  778.  
  779. // return feature `i` from this layer as a `VectorTileFeature`
  780. VectorTileLayer.prototype.feature = function(i) {
  781. if (i < 0 || i >= this._features.length) throw new Error('feature index out of bounds');
  782.  
  783. this._buffer.pos = this._features[i];
  784. var end = this._buffer.readVarint() + this._buffer.pos;
  785.  
  786. return new VectorTileFeature(this._buffer, end, this.extent, this._keys, this._values);
  787. };
  788.  
  789. },{"./vectortilefeature.js":6}],8:[function(require,module,exports){
  790. /**
  791. * Created by Ryan Whitley, Daniel Duarte, and Nicholas Hallahan
  792. * on 6/03/14.
  793. */
  794. var Util = require('./MVTUtil');
  795. var StaticLabel = require('./StaticLabel/StaticLabel.js');
  796.  
  797. module.exports = MVTFeature;
  798.  
  799. function MVTFeature(mvtLayer, vtf, ctx, id, style) {
  800. if (!vtf) return null;
  801.  
  802. // Apply all of the properties of vtf to this object.
  803. for (var key in vtf) {
  804. this[key] = vtf[key];
  805. }
  806.  
  807. this.mvtLayer = mvtLayer;
  808. this.mvtSource = mvtLayer.mvtSource;
  809. this.map = mvtLayer.mvtSource.map;
  810.  
  811. this.id = id;
  812.  
  813. this.layerLink = this.mvtSource.layerLink;
  814. this.toggleEnabled = true;
  815. this.selected = false;
  816.  
  817. // how much we divide the coordinate from the vector tile
  818. this.divisor = vtf.extent / ctx.tileSize;
  819. this.extent = vtf.extent;
  820. this.tileSize = ctx.tileSize;
  821.  
  822. //An object to store the paths and contexts for this feature
  823. this.tiles = {};
  824.  
  825. this.style = style;
  826.  
  827. //Add to the collection
  828. this.addTileFeature(vtf, ctx);
  829.  
  830. var self = this;
  831. this.map.on('zoomend', function() {
  832. self.staticLabel = null;
  833. });
  834.  
  835. if (style && style.dynamicLabel && typeof style.dynamicLabel === 'function') {
  836. this.dynamicLabel = this.mvtSource.dynamicLabel.createFeature(this);
  837. }
  838.  
  839. ajax(self);
  840. }
  841.  
  842.  
  843. function ajax(self) {
  844. var style = self.style;
  845. if (style && style.ajaxSource && typeof style.ajaxSource === 'function') {
  846. var ajaxEndpoint = style.ajaxSource(self);
  847. if (ajaxEndpoint) {
  848. Util.getJSON(ajaxEndpoint, function(error, response, body) {
  849. if (error) {
  850. throw ['ajaxSource AJAX Error', error];
  851. } else {
  852. ajaxCallback(self, response);
  853. return true;
  854. }
  855. });
  856. }
  857. }
  858. return false;
  859. }
  860.  
  861. function ajaxCallback(self, response) {
  862. self.ajaxData = response;
  863.  
  864. /**
  865. * You can attach a callback function to a feature in your app
  866. * that will get called whenever new ajaxData comes in. This
  867. * can be used to update UI that looks at data from within a feature.
  868. *
  869. * setStyle may possibly have a style with a different ajaxData source,
  870. * and you would potentially get new contextual data for your feature.
  871. *
  872. * TODO: This needs to be documented.
  873. */
  874. if (typeof self.ajaxDataReceived === 'function') {
  875. self.ajaxDataReceived(self, response);
  876. }
  877.  
  878. self._setStyle(self.mvtLayer.style);
  879. redrawTiles(self);
  880. }
  881.  
  882. MVTFeature.prototype._setStyle = function(styleFn) {
  883. this.style = styleFn(this, this.ajaxData);
  884.  
  885. // The label gets removed, and the (re)draw,
  886. // that is initiated by the MVTLayer creates a new label.
  887. this.removeLabel();
  888. };
  889.  
  890. MVTFeature.prototype.setStyle = function(styleFn) {
  891. this.ajaxData = null;
  892. this.style = styleFn(this, null);
  893. var hasAjaxSource = ajax(this);
  894. if (!hasAjaxSource) {
  895. // The label gets removed, and the (re)draw,
  896. // that is initiated by the MVTLayer creates a new label.
  897. this.removeLabel();
  898. }
  899. };
  900.  
  901. MVTFeature.prototype.draw = function(canvasID) {
  902. //Get the info from the tiles list
  903. var tileInfo = this.tiles[canvasID];
  904.  
  905. var vtf = tileInfo.vtf;
  906. var ctx = tileInfo.ctx;
  907.  
  908. //Get the actual canvas from the parent layer's _tiles object.
  909. var xy = canvasID.split(":").slice(1, 3).join(":");
  910. ctx.canvas = this.mvtLayer._tiles[xy];
  911.  
  912. // This could be used to directly compute the style function from the layer on every draw.
  913. // This is much less efficient...
  914. // this.style = this.mvtLayer.style(this);
  915.  
  916. if (this.selected) {
  917. var style = this.style.selected || this.style;
  918. } else {
  919. var style = this.style;
  920. }
  921.  
  922. switch (vtf.type) {
  923. case 1: //Point
  924. this._drawPoint(ctx, vtf.coordinates, style);
  925. if (!this.staticLabel && typeof this.style.staticLabel === 'function') {
  926. if (this.style.ajaxSource && !this.ajaxData) {
  927. break;
  928. }
  929. this._drawStaticLabel(ctx, vtf.coordinates, style);
  930. }
  931. break;
  932.  
  933. case 2: //LineString
  934. this._drawLineString(ctx, vtf.coordinates, style);
  935. break;
  936.  
  937. case 3: //Polygon
  938. this._drawPolygon(ctx, vtf.coordinates, style);
  939. break;
  940.  
  941. default:
  942. throw new Error('Unmanaged type: ' + vtf.type);
  943. }
  944.  
  945. };
  946.  
  947. MVTFeature.prototype.getPathsForTile = function(canvasID) {
  948. //Get the info from the parts list
  949. return this.tiles[canvasID].paths;
  950. };
  951.  
  952. MVTFeature.prototype.addTileFeature = function(vtf, ctx) {
  953. //Store the important items in the tiles list
  954.  
  955. //We only want to store info for tiles for the current map zoom. If it is tile info for another zoom level, ignore it
  956. //Also, if there are existing tiles in the list for other zoom levels, expunge them.
  957. var zoom = this.map.getZoom();
  958.  
  959. if(ctx.zoom != zoom) return;
  960.  
  961. this.clearTileFeatures(zoom); //TODO: This iterates thru all tiles every time a new tile is added. Figure out a better way to do this.
  962.  
  963. this.tiles[ctx.id] = {
  964. ctx: ctx,
  965. vtf: vtf,
  966. paths: []
  967. };
  968.  
  969. };
  970.  
  971.  
  972. /**
  973. * Clear the inner list of tile features if they don't match the given zoom.
  974. *
  975. * @param zoom
  976. */
  977. MVTFeature.prototype.clearTileFeatures = function(zoom) {
  978. //If stored tiles exist for other zoom levels, expunge them from the list.
  979. for (var key in this.tiles) {
  980. if(key.split(":")[0] != zoom) delete this.tiles[key];
  981. }
  982. };
  983.  
  984. /**
  985. * Redraws all of the tiles associated with a feature. Useful for
  986. * style change and toggling.
  987. *
  988. * @param self
  989. */
  990. function redrawTiles(self) {
  991. //Redraw the whole tile, not just this vtf
  992. var tiles = self.tiles;
  993. var mvtLayer = self.mvtLayer;
  994.  
  995. for (var id in tiles) {
  996. var tileZoom = parseInt(id.split(':')[0]);
  997. var mapZoom = self.map.getZoom();
  998. if (tileZoom === mapZoom) {
  999. //Redraw the tile
  1000. mvtLayer.redrawTile(id);
  1001. }
  1002. }
  1003. }
  1004.  
  1005. MVTFeature.prototype.toggle = function() {
  1006. if (this.selected) {
  1007. this.deselect();
  1008. } else {
  1009. this.select();
  1010. }
  1011. };
  1012.  
  1013. MVTFeature.prototype.select = function() {
  1014. this.selected = true;
  1015. this.mvtSource.featureSelected(this);
  1016. redrawTiles(this);
  1017. var linkedFeature = this.linkedFeature();
  1018. if (linkedFeature && linkedFeature.staticLabel && !linkedFeature.staticLabel.selected) {
  1019. linkedFeature.staticLabel.select();
  1020. }
  1021. };
  1022.  
  1023. MVTFeature.prototype.deselect = function() {
  1024. this.selected = false;
  1025. this.mvtSource.featureDeselected(this);
  1026. redrawTiles(this);
  1027. var linkedFeature = this.linkedFeature();
  1028. if (linkedFeature && linkedFeature.staticLabel && linkedFeature.staticLabel.selected) {
  1029. linkedFeature.staticLabel.deselect();
  1030. }
  1031. };
  1032.  
  1033. MVTFeature.prototype.on = function(eventType, callback) {
  1034. this._eventHandlers[eventType] = callback;
  1035. };
  1036.  
  1037. MVTFeature.prototype._drawPoint = function(ctx, coordsArray, style) {
  1038. if (!style) return;
  1039. if (!ctx || !ctx.canvas) return;
  1040.  
  1041. var tile = this.tiles[ctx.id];
  1042.  
  1043. //Get radius
  1044. var radius = 1;
  1045. if (typeof style.radius === 'function') {
  1046. radius = style.radius(ctx.zoom); //Allows for scale dependent rednering
  1047. }
  1048. else{
  1049. radius = style.radius;
  1050. }
  1051.  
  1052. var p = this._tilePoint(coordsArray[0][0]);
  1053. var c = ctx.canvas;
  1054. var ctx2d;
  1055. try{
  1056. ctx2d = c.getContext('2d');
  1057. }
  1058. catch(e){
  1059. console.log("_drawPoint error: " + e);
  1060. return;
  1061. }
  1062.  
  1063. ctx2d.beginPath();
  1064. ctx2d.fillStyle = style.color;
  1065. ctx2d.arc(p.x, p.y, radius, 0, Math.PI * 2);
  1066. ctx2d.closePath();
  1067. ctx2d.fill();
  1068.  
  1069. if(style.lineWidth && style.strokeStyle){
  1070. ctx2d.lineWidth = style.lineWidth;
  1071. ctx2d.strokeStyle = style.strokeStyle;
  1072. ctx2d.stroke();
  1073. }
  1074.  
  1075. ctx2d.restore();
  1076. tile.paths.push([p]);
  1077. };
  1078.  
  1079. MVTFeature.prototype._drawLineString = function(ctx, coordsArray, style) {
  1080. if (!style) return;
  1081. if (!ctx || !ctx.canvas) return;
  1082.  
  1083. var ctx2d = ctx.canvas.getContext('2d');
  1084. ctx2d.strokeStyle = style.color;
  1085. ctx2d.lineWidth = style.size;
  1086. ctx2d.beginPath();
  1087.  
  1088. var projCoords = [];
  1089. var tile = this.tiles[ctx.id];
  1090.  
  1091. for (var gidx in coordsArray) {
  1092. var coords = coordsArray[gidx];
  1093.  
  1094. for (i = 0; i < coords.length; i++) {
  1095. var method = (i === 0 ? 'move' : 'line') + 'To';
  1096. var proj = this._tilePoint(coords[i]);
  1097. projCoords.push(proj);
  1098. ctx2d[method](proj.x, proj.y);
  1099. }
  1100. }
  1101.  
  1102. ctx2d.stroke();
  1103. ctx2d.restore();
  1104.  
  1105. tile.paths.push(projCoords);
  1106. };
  1107.  
  1108. MVTFeature.prototype._drawPolygon = function(ctx, coordsArray, style) {
  1109. if (!style) return;
  1110. if (!ctx || !ctx.canvas) return;
  1111.  
  1112. var ctx2d = ctx.canvas.getContext('2d');
  1113. var outline = style.outline;
  1114.  
  1115. // color may be defined via function to make choropleth work right
  1116. if (typeof style.color === 'function') {
  1117. ctx2d.fillStyle = style.color(ctx2d);
  1118. } else {
  1119. ctx2d.fillStyle = style.color;
  1120. }
  1121.  
  1122. if (outline) {
  1123. ctx2d.strokeStyle = outline.color;
  1124. ctx2d.lineWidth = outline.size;
  1125. }
  1126. ctx2d.beginPath();
  1127.  
  1128. var projCoords = [];
  1129. var tile = this.tiles[ctx.id];
  1130.  
  1131. var featureLabel = this.dynamicLabel;
  1132. if (featureLabel) {
  1133. featureLabel.addTilePolys(ctx, coordsArray);
  1134. }
  1135.  
  1136. for (var gidx = 0, len = coordsArray.length; gidx < len; gidx++) {
  1137. var coords = coordsArray[gidx];
  1138.  
  1139. for (var i = 0; i < coords.length; i++) {
  1140. var coord = coords[i];
  1141. var method = (i === 0 ? 'move' : 'line') + 'To';
  1142. var proj = this._tilePoint(coords[i]);
  1143. projCoords.push(proj);
  1144. ctx2d[method](proj.x, proj.y);
  1145. }
  1146. }
  1147.  
  1148. ctx2d.closePath();
  1149. ctx2d.fill();
  1150. if (outline) {
  1151. ctx2d.stroke();
  1152. }
  1153.  
  1154. tile.paths.push(projCoords);
  1155.  
  1156. };
  1157.  
  1158. MVTFeature.prototype._drawStaticLabel = function(ctx, coordsArray, style) {
  1159. if (!style) return;
  1160. if (!ctx) return;
  1161.  
  1162. // If the corresponding layer is not on the map,
  1163. // we dont want to put on a label.
  1164. if (!this.mvtLayer._map) return;
  1165.  
  1166. var vecPt = this._tilePoint(coordsArray[0][0]);
  1167.  
  1168. // We're making a standard Leaflet Marker for this label.
  1169. var p = this._project(vecPt, ctx.tile.x, ctx.tile.y, this.extent, this.tileSize); //vectile pt to merc pt
  1170. var mercPt = L.point(p.x, p.y); // make into leaflet obj
  1171. var latLng = this.map.unproject(mercPt); // merc pt to latlng
  1172.  
  1173. this.staticLabel = new StaticLabel(this, ctx, latLng, style);
  1174. this.mvtLayer.featureWithLabelAdded(this);
  1175. };
  1176.  
  1177. MVTFeature.prototype.removeLabel = function() {
  1178. if (!this.staticLabel) return;
  1179. this.staticLabel.remove();
  1180. this.staticLabel = null;
  1181. };
  1182.  
  1183. /**
  1184. * Projects a vector tile point to the Spherical Mercator pixel space for a given zoom level.
  1185. *
  1186. * @param vecPt
  1187. * @param tileX
  1188. * @param tileY
  1189. * @param extent
  1190. * @param tileSize
  1191. */
  1192. MVTFeature.prototype._project = function(vecPt, tileX, tileY, extent, tileSize) {
  1193. var xOffset = tileX * tileSize;
  1194. var yOffset = tileY * tileSize;
  1195. return {
  1196. x: Math.floor(vecPt.x + xOffset),
  1197. y: Math.floor(vecPt.y + yOffset)
  1198. };
  1199. };
  1200.  
  1201. /**
  1202. * Takes a coordinate from a vector tile and turns it into a Leaflet Point.
  1203. *
  1204. * @param ctx
  1205. * @param coords
  1206. * @returns {eGeomType.Point}
  1207. * @private
  1208. */
  1209. MVTFeature.prototype._tilePoint = function(coords) {
  1210. return new L.Point(coords.x / this.divisor, coords.y / this.divisor);
  1211. };
  1212.  
  1213. MVTFeature.prototype.linkedFeature = function() {
  1214. var linkedLayer = this.mvtLayer.linkedLayer();
  1215. if(linkedLayer){
  1216. var linkedFeature = linkedLayer.features[this.id];
  1217. return linkedFeature;
  1218. }else{
  1219. return null;
  1220. }
  1221. };
  1222.  
  1223.  
  1224. },{"./MVTUtil":11,"./StaticLabel/StaticLabel.js":12}],9:[function(require,module,exports){
  1225. /**
  1226. * Created by Ryan Whitley on 5/17/14.
  1227. */
  1228. /** Forked from https://gist.github.com/DGuidi/1716010 **/
  1229. var MVTFeature = require('./MVTFeature');
  1230. var Util = require('./MVTUtil');
  1231.  
  1232. module.exports = L.TileLayer.Canvas.extend({
  1233.  
  1234. options: {
  1235. debug: false,
  1236. isHiddenLayer: false,
  1237. getIDForLayerFeature: function() {},
  1238. tileSize: 256,
  1239. lineClickTolerance: 2
  1240. },
  1241.  
  1242. _featureIsClicked: {},
  1243.  
  1244. _isPointInPoly: function(pt, poly) {
  1245. if(poly && poly.length) {
  1246. for (var c = false, i = -1, l = poly.length, j = l - 1; ++i < l; j = i)
  1247. ((poly[i].y <= pt.y && pt.y < poly[j].y) || (poly[j].y <= pt.y && pt.y < poly[i].y))
  1248. && (pt.x < (poly[j].x - poly[i].x) * (pt.y - poly[i].y) / (poly[j].y - poly[i].y) + poly[i].x)
  1249. && (c = !c);
  1250. return c;
  1251. }
  1252. },
  1253.  
  1254. _getDistanceFromLine: function(pt, pts) {
  1255. var min = Number.POSITIVE_INFINITY;
  1256. if (pts && pts.length > 1) {
  1257. pt = L.point(pt.x, pt.y);
  1258. for (var i = 0, l = pts.length - 1; i < l; i++) {
  1259. var test = this._projectPointOnLineSegment(pt, pts[i], pts[i + 1]);
  1260. if (test.distance <= min) {
  1261. min = test.distance;
  1262. }
  1263. }
  1264. }
  1265. return min;
  1266. },
  1267.  
  1268. _projectPointOnLineSegment: function(p, r0, r1) {
  1269. var lineLength = r0.distanceTo(r1);
  1270. if (lineLength < 1) {
  1271. return {distance: p.distanceTo(r0), coordinate: r0};
  1272. }
  1273. var u = ((p.x - r0.x) * (r1.x - r0.x) + (p.y - r0.y) * (r1.y - r0.y)) / Math.pow(lineLength, 2);
  1274. if (u < 0.0000001) {
  1275. return {distance: p.distanceTo(r0), coordinate: r0};
  1276. }
  1277. if (u > 0.9999999) {
  1278. return {distance: p.distanceTo(r1), coordinate: r1};
  1279. }
  1280. var a = L.point(r0.x + u * (r1.x - r0.x), r0.y + u * (r1.y - r0.y));
  1281. return {distance: p.distanceTo(a), point: a};
  1282. },
  1283.  
  1284. initialize: function(mvtSource, options) {
  1285. var self = this;
  1286. self.mvtSource = mvtSource;
  1287. L.Util.setOptions(this, options);
  1288.  
  1289. this.style = options.style;
  1290. this.name = options.name;
  1291. this._canvasIDToFeatures = {};
  1292. this.features = {};
  1293. this.featuresWithLabels = [];
  1294. this._highestCount = 0;
  1295. },
  1296.  
  1297. onAdd: function(map) {
  1298. var self = this;
  1299. self.map = map;
  1300. L.TileLayer.Canvas.prototype.onAdd.call(this, map);
  1301. map.on('layerremove', function(e) {
  1302. // we only want to do stuff when the layerremove event is on this layer
  1303. if (e.layer._leaflet_id === self._leaflet_id) {
  1304. removeLabels(self);
  1305. }
  1306. });
  1307. },
  1308.  
  1309. drawTile: function(canvas, tilePoint, zoom) {
  1310.  
  1311. var ctx = {
  1312. canvas: canvas,
  1313. tile: tilePoint,
  1314. zoom: zoom,
  1315. tileSize: this.options.tileSize
  1316. };
  1317.  
  1318. ctx.id = Util.getContextID(ctx);
  1319.  
  1320. if (!this._canvasIDToFeatures[ctx.id]) {
  1321. this._initializeFeaturesHash(ctx);
  1322. }
  1323. if (!this.features) {
  1324. this.features = {};
  1325. }
  1326.  
  1327. },
  1328.  
  1329. _initializeFeaturesHash: function(ctx){
  1330. this._canvasIDToFeatures[ctx.id] = {};
  1331. this._canvasIDToFeatures[ctx.id].features = [];
  1332. this._canvasIDToFeatures[ctx.id].canvas = ctx.canvas;
  1333. },
  1334.  
  1335. _draw: function(ctx) {
  1336. //Draw is handled by the parent MVTSource object
  1337. },
  1338. getCanvas: function(parentCtx){
  1339. //This gets called if a vector tile feature has already been parsed.
  1340. //We've already got the geom, just get on with the drawing.
  1341. //Need a way to pluck a canvas element from this layer given the parent layer's id.
  1342. //Wait for it to get loaded before proceeding.
  1343. var tilePoint = parentCtx.tile;
  1344. var ctx = this._tiles[tilePoint.x + ":" + tilePoint.y];
  1345.  
  1346. if(ctx){
  1347. parentCtx.canvas = ctx;
  1348. this.redrawTile(parentCtx.id);
  1349. return;
  1350. }
  1351.  
  1352. var self = this;
  1353.  
  1354. //This is a timer that will wait for a criterion to return true.
  1355. //If not true within the timeout duration, it will move on.
  1356. waitFor(function () {
  1357. ctx = self._tiles[tilePoint.x + ":" + tilePoint.y];
  1358. if(ctx) {
  1359. return true;
  1360. }
  1361. },
  1362. function(){
  1363. //When it finishes, do this.
  1364. ctx = self._tiles[tilePoint.x + ":" + tilePoint.y];
  1365. parentCtx.canvas = ctx;
  1366. self.redrawTile(parentCtx.id);
  1367.  
  1368. }, //when done, go to next flow
  1369. 2000); //The Timeout milliseconds. After this, give up and move on
  1370.  
  1371. },
  1372.  
  1373. parseVectorTileLayer: function(vtl, ctx) {
  1374. var self = this;
  1375. var tilePoint = ctx.tile;
  1376. var layerCtx = { canvas: null, id: ctx.id, tile: ctx.tile, zoom: ctx.zoom, tileSize: ctx.tileSize};
  1377.  
  1378. //See if we can pluck the child tile from this PBF tile layer based on the master layer's tile id.
  1379. layerCtx.canvas = self._tiles[tilePoint.x + ":" + tilePoint.y];
  1380.  
  1381.  
  1382.  
  1383. //Initialize this tile's feature storage hash, if it hasn't already been created. Used for when filters are updated, and features are cleared to prepare for a fresh redraw.
  1384. if (!this._canvasIDToFeatures[layerCtx.id]) {
  1385. this._initializeFeaturesHash(layerCtx);
  1386. }else{
  1387. //Clear this tile's previously saved features.
  1388. this.clearTileFeatureHash(layerCtx.id);
  1389. }
  1390.  
  1391. var features = vtl.parsedFeatures;
  1392. for (var i = 0, len = features.length; i < len; i++) {
  1393. var vtf = features[i]; //vector tile feature
  1394. vtf.layer = vtl;
  1395.  
  1396. /**
  1397. * Apply filter on feature if there is one. Defined in the options object
  1398. * of TileLayer.MVTSource.js
  1399. */
  1400. var filter = self.options.filter;
  1401. if (typeof filter === 'function') {
  1402. if ( filter(vtf, layerCtx) === false ) continue;
  1403. }
  1404.  
  1405. var getIDForLayerFeature;
  1406. if (typeof self.options.getIDForLayerFeature === 'function') {
  1407. getIDForLayerFeature = self.options.getIDForLayerFeature;
  1408. } else {
  1409. getIDForLayerFeature = Util.getIDForLayerFeature;
  1410. }
  1411. var uniqueID = self.options.getIDForLayerFeature(vtf) || i;
  1412. var mvtFeature = self.features[uniqueID];
  1413.  
  1414. /**
  1415. * Use layerOrdering function to apply a zIndex property to each vtf. This is defined in
  1416. * TileLayer.MVTSource.js. Used below to sort features.npm
  1417. */
  1418. var layerOrdering = self.options.layerOrdering;
  1419. if (typeof layerOrdering === 'function') {
  1420. layerOrdering(vtf, layerCtx); //Applies a custom property to the feature, which is used after we're thru iterating to sort
  1421. }
  1422.  
  1423. //Create a new MVTFeature if one doesn't already exist for this feature.
  1424. if (!mvtFeature) {
  1425. //Get a style for the feature - set it just once for each new MVTFeature
  1426. var style = self.style(vtf);
  1427.  
  1428. //create a new feature
  1429. self.features[uniqueID] = mvtFeature = new MVTFeature(self, vtf, layerCtx, uniqueID, style);
  1430. if (style && style.dynamicLabel && typeof style.dynamicLabel === 'function') {
  1431. self.featuresWithLabels.push(mvtFeature);
  1432. }
  1433. } else {
  1434. //Add the new part to the existing feature
  1435. mvtFeature.addTileFeature(vtf, layerCtx);
  1436. }
  1437.  
  1438. //Associate & Save this feature with this tile for later
  1439. if(layerCtx && layerCtx.id) self._canvasIDToFeatures[layerCtx.id]['features'].push(mvtFeature);
  1440.  
  1441. }
  1442.  
  1443. /**
  1444. * Apply sorting (zIndex) on feature if there is a function defined in the options object
  1445. * of TileLayer.MVTSource.js
  1446. */
  1447. var layerOrdering = self.options.layerOrdering;
  1448. if (layerOrdering) {
  1449. //We've assigned the custom zIndex property when iterating above. Now just sort.
  1450. self._canvasIDToFeatures[layerCtx.id].features = self._canvasIDToFeatures[layerCtx.id].features.sort(function(a, b) {
  1451. return -(b.properties.zIndex - a.properties.zIndex)
  1452. });
  1453. }
  1454.  
  1455. self.redrawTile(layerCtx.id);
  1456. },
  1457.  
  1458. setStyle: function(styleFn) {
  1459. // refresh the number for the highest count value
  1460. // this is used only for choropleth
  1461. this._highestCount = 0;
  1462.  
  1463. // lowest count should not be 0, since we want to figure out the lowest
  1464. this._lowestCount = null;
  1465.  
  1466. this.style = styleFn;
  1467. for (var key in this.features) {
  1468. var feat = this.features[key];
  1469. feat.setStyle(styleFn);
  1470. }
  1471. var z = this.map.getZoom();
  1472. for (var key in this._tiles) {
  1473. var id = z + ':' + key;
  1474. this.redrawTile(id);
  1475. }
  1476. },
  1477.  
  1478. /**
  1479. * As counts for choropleths come in with the ajax data,
  1480. * we want to keep track of which value is the highest
  1481. * to create the color ramp for the fills of polygons.
  1482. * @param count
  1483. */
  1484. setHighestCount: function(count) {
  1485. if (count > this._highestCount) {
  1486. this._highestCount = count;
  1487. }
  1488. },
  1489.  
  1490. /**
  1491. * Returns the highest number of all of the counts that have come in
  1492. * from setHighestCount. This is assumed to be set via ajax callbacks.
  1493. * @returns {number}
  1494. */
  1495. getHighestCount: function() {
  1496. return this._highestCount;
  1497. },
  1498.  
  1499. setLowestCount: function(count) {
  1500. if (!this._lowestCount || count < this._lowestCount) {
  1501. this._lowestCount = count;
  1502. }
  1503. },
  1504.  
  1505. getLowestCount: function() {
  1506. return this._lowestCount;
  1507. },
  1508.  
  1509. setCountRange: function(count) {
  1510. this.setHighestCount(count);
  1511. this.setLowestCount(count);
  1512. },
  1513.  
  1514. //This is the old way. It works, but is slow for mouseover events. Fine for click events.
  1515. handleClickEvent: function(evt, cb) {
  1516. //Click happened on the GroupLayer (Manager) and passed it here
  1517. var tileID = evt.tileID.split(":").slice(1, 3).join(":");
  1518. var zoom = evt.tileID.split(":")[0];
  1519. var canvas = this._tiles[tileID];
  1520. if(!canvas) (cb(evt)); //break out
  1521. var x = evt.layerPoint.x - canvas._leaflet_pos.x;
  1522. var y = evt.layerPoint.y - canvas._leaflet_pos.y;
  1523.  
  1524. var tilePoint = {x: x, y: y};
  1525. var features = this._canvasIDToFeatures[evt.tileID].features;
  1526.  
  1527. var minDistance = Number.POSITIVE_INFINITY;
  1528. var nearest = null;
  1529. var j, paths, distance;
  1530.  
  1531. for (var i = 0; i < features.length; i++) {
  1532. var feature = features[i];
  1533. switch (feature.type) {
  1534.  
  1535. case 1: //Point - currently rendered as circular paths. Intersect with that.
  1536.  
  1537. //Find the radius of the point.
  1538. var radius = 3;
  1539. if (typeof feature.style.radius === 'function') {
  1540. radius = feature.style.radius(zoom); //Allows for scale dependent rednering
  1541. }
  1542. else{
  1543. radius = feature.style.radius;
  1544. }
  1545.  
  1546. paths = feature.getPathsForTile(evt.tileID);
  1547. for (j = 0; j < paths.length; j++) {
  1548. //Builds a circle of radius feature.style.radius (assuming circular point symbology).
  1549. if(in_circle(paths[j][0].x, paths[j][0].y, radius, x, y)){
  1550. nearest = feature;
  1551. minDistance = 0;
  1552. }
  1553. }
  1554. break;
  1555.  
  1556. case 2: //LineString
  1557. paths = feature.getPathsForTile(evt.tileID);
  1558. for (j = 0; j < paths.length; j++) {
  1559. if (feature.style) {
  1560. var distance = this._getDistanceFromLine(tilePoint, paths[j]);
  1561. var thickness = (feature.selected && feature.style.selected ? feature.style.selected.size : feature.style.size);
  1562. if (distance < thickness / 2 + this.options.lineClickTolerance && distance < minDistance) {
  1563. nearest = feature;
  1564. minDistance = distance;
  1565. }
  1566. }
  1567. }
  1568. break;
  1569.  
  1570. case 3: //Polygon
  1571. paths = feature.getPathsForTile(evt.tileID);
  1572. for (j = 0; j < paths.length; j++) {
  1573. if (this._isPointInPoly(tilePoint, paths[j])) {
  1574. nearest = feature;
  1575. minDistance = 0; // point is inside the polygon, so distance is zero
  1576. }
  1577. }
  1578. break;
  1579. }
  1580. if (minDistance == 0) break;
  1581. }
  1582.  
  1583. if (nearest && nearest.toggleEnabled) {
  1584. nearest.toggle();
  1585. }
  1586. evt.feature = nearest;
  1587. cb(evt);
  1588. },
  1589.  
  1590. clearTile: function(id) {
  1591. //id is the entire zoom:x:y. we just want x:y.
  1592. var ca = id.split(":");
  1593. var canvasId = ca[1] + ":" + ca[2];
  1594. if (typeof this._tiles[canvasId] === 'undefined') {
  1595. console.error("typeof this._tiles[canvasId] === 'undefined'");
  1596. return;
  1597. }
  1598. var canvas = this._tiles[canvasId];
  1599.  
  1600. var context = canvas.getContext('2d');
  1601. context.clearRect(0, 0, canvas.width, canvas.height);
  1602. },
  1603.  
  1604. clearTileFeatureHash: function(canvasID){
  1605. this._canvasIDToFeatures[canvasID] = { features: []}; //Get rid of all saved features
  1606. },
  1607.  
  1608. clearLayerFeatureHash: function(){
  1609. this.features = {};
  1610. },
  1611.  
  1612. redrawTile: function(canvasID) {
  1613. //First, clear the canvas
  1614. this.clearTile(canvasID);
  1615.  
  1616. // If the features are not in the tile, then there is nothing to redraw.
  1617. // This may happen if you call redraw before features have loaded and initially
  1618. // drawn the tile.
  1619. var featfeats = this._canvasIDToFeatures[canvasID];
  1620. if (!featfeats) {
  1621. return;
  1622. }
  1623.  
  1624. //Get the features for this tile, and redraw them.
  1625. var features = featfeats.features;
  1626.  
  1627. // we want to skip drawing the selected features and draw them last
  1628. var selectedFeatures = [];
  1629.  
  1630. // drawing all of the non-selected features
  1631. for (var i = 0; i < features.length; i++) {
  1632. var feature = features[i];
  1633. if (feature.selected) {
  1634. selectedFeatures.push(feature);
  1635. } else {
  1636. feature.draw(canvasID);
  1637. }
  1638. }
  1639.  
  1640. // drawing the selected features last
  1641. for (var j = 0, len2 = selectedFeatures.length; j < len2; j++) {
  1642. var selFeat = selectedFeatures[j];
  1643. selFeat.draw(canvasID);
  1644. }
  1645. },
  1646.  
  1647. _resetCanvasIDToFeatures: function(canvasID, canvas) {
  1648.  
  1649. this._canvasIDToFeatures[canvasID] = {};
  1650. this._canvasIDToFeatures[canvasID].features = [];
  1651. this._canvasIDToFeatures[canvasID].canvas = canvas;
  1652.  
  1653. },
  1654.  
  1655. linkedLayer: function() {
  1656. if(this.mvtSource.layerLink) {
  1657. var linkName = this.mvtSource.layerLink(this.name);
  1658. return this.mvtSource.layers[linkName];
  1659. }
  1660. else{
  1661. return null;
  1662. }
  1663. },
  1664.  
  1665. featureWithLabelAdded: function(feature) {
  1666. this.featuresWithLabels.push(feature);
  1667. }
  1668.  
  1669. });
  1670.  
  1671.  
  1672. function removeLabels(self) {
  1673. var features = self.featuresWithLabels;
  1674. for (var i = 0, len = features.length; i < len; i++) {
  1675. var feat = features[i];
  1676. feat.removeLabel();
  1677. }
  1678. self.featuresWithLabels = [];
  1679. }
  1680.  
  1681. function in_circle(center_x, center_y, radius, x, y) {
  1682. var square_dist = Math.pow((center_x - x), 2) + Math.pow((center_y - y), 2);
  1683. return square_dist <= Math.pow(radius, 2);
  1684. }
  1685. /**
  1686. * See https://github.com/ariya/phantomjs/blob/master/examples/waitfor.js
  1687. *
  1688. * Wait until the test condition is true or a timeout occurs. Useful for waiting
  1689. * on a server response or for a ui change (fadeIn, etc.) to occur.
  1690. *
  1691. * @param testFx javascript condition that evaluates to a boolean,
  1692. * it can be passed in as a string (e.g.: "1 == 1" or "$('#bar').is(':visible')" or
  1693. * as a callback function.
  1694. * @param onReady what to do when testFx condition is fulfilled,
  1695. * it can be passed in as a string (e.g.: "1 == 1" or "$('#bar').is(':visible')" or
  1696. * as a callback function.
  1697. * @param timeOutMillis the max amount of time to wait. If not specified, 3 sec is used.
  1698. */
  1699. function waitFor(testFx, onReady, timeOutMillis) {
  1700. var maxtimeOutMillis = timeOutMillis ? timeOutMillis : 3000, //< Default Max Timout is 3s
  1701. start = new Date().getTime(),
  1702. condition = (typeof (testFx) === "string" ? eval(testFx) : testFx()), //< defensive code
  1703. interval = setInterval(function () {
  1704. if ((new Date().getTime() - start < maxtimeOutMillis) && !condition) {
  1705. // If not time-out yet and condition not yet fulfilled
  1706. condition = (typeof (testFx) === "string" ? eval(testFx) : testFx()); //< defensive code
  1707. } else {
  1708. if (!condition) {
  1709. // If condition still not fulfilled (timeout but condition is 'false')
  1710. console.log("'waitFor()' timeout");
  1711. clearInterval(interval); //< Stop this interval
  1712. typeof (onReady) === "string" ? eval(onReady) : onReady('timeout'); //< Do what it's supposed to do once the condition is fulfilled
  1713. } else {
  1714. // Condition fulfilled (timeout and/or condition is 'true')
  1715. console.log("'waitFor()' finished in " + (new Date().getTime() - start) + "ms.");
  1716. clearInterval(interval); //< Stop this interval
  1717. typeof (onReady) === "string" ? eval(onReady) : onReady('success'); //< Do what it's supposed to do once the condition is fulfilled
  1718. }
  1719. }
  1720. }, 50); //< repeat check every 50ms
  1721. };
  1722. },{"./MVTFeature":8,"./MVTUtil":11}],10:[function(require,module,exports){
  1723. var VectorTile = require('vector-tile').VectorTile;
  1724. var Protobuf = require('pbf');
  1725. var Point = require('point-geometry');
  1726. var Util = require('./MVTUtil');
  1727. var MVTLayer = require('./MVTLayer');
  1728.  
  1729.  
  1730. module.exports = L.TileLayer.MVTSource = L.TileLayer.Canvas.extend({
  1731.  
  1732. options: {
  1733. debug: false,
  1734. url: "", //URL TO Vector Tile Source,
  1735. getIDForLayerFeature: function() {},
  1736. tileSize: 256,
  1737. visibleLayers: [],
  1738. xhrHeaders: {}
  1739. },
  1740. layers: {}, //Keep a list of the layers contained in the PBFs
  1741. processedTiles: {}, //Keep a list of tiles that have been processed already
  1742. _eventHandlers: {},
  1743. _triggerOnTilesLoadedEvent: true, //whether or not to fire the onTilesLoaded event when all of the tiles finish loading.
  1744. _url: "", //internal URL property
  1745.  
  1746. style: function(feature) {
  1747. var style = {};
  1748.  
  1749. var type = feature.type;
  1750. switch (type) {
  1751. case 1: //'Point'
  1752. style.color = 'rgba(49,79,79,1)';
  1753. style.radius = 5;
  1754. style.selected = {
  1755. color: 'rgba(255,255,0,0.5)',
  1756. radius: 6
  1757. };
  1758. break;
  1759. case 2: //'LineString'
  1760. style.color = 'rgba(161,217,155,0.8)';
  1761. style.size = 3;
  1762. style.selected = {
  1763. color: 'rgba(255,25,0,0.5)',
  1764. size: 4
  1765. };
  1766. break;
  1767. case 3: //'Polygon'
  1768. style.color = 'rgba(49,79,79,1)';
  1769. style.outline = {
  1770. color: 'rgba(161,217,155,0.8)',
  1771. size: 1
  1772. };
  1773. style.selected = {
  1774. color: 'rgba(255,140,0,0.3)',
  1775. outline: {
  1776. color: 'rgba(255,140,0,1)',
  1777. size: 2
  1778. }
  1779. };
  1780. break;
  1781. }
  1782. return style;
  1783. },
  1784.  
  1785.  
  1786. initialize: function(options) {
  1787. L.Util.setOptions(this, options);
  1788.  
  1789. //a list of the layers contained in the PBFs
  1790. this.layers = {};
  1791.  
  1792. // tiles currently in the viewport
  1793. this.activeTiles = {};
  1794.  
  1795. // thats that have been loaded and drawn
  1796. this.loadedTiles = {};
  1797.  
  1798. this._url = this.options.url;
  1799.  
  1800. /**
  1801. * For some reason, Leaflet has some code that resets the
  1802. * z index in the options object. I'm having trouble tracking
  1803. * down exactly what does this and why, so for now, we should
  1804. * just copy the value to this.zIndex so we can have the right
  1805. * number when we make the subsequent MVTLayers.
  1806. */
  1807. this.zIndex = options.zIndex;
  1808.  
  1809. if (typeof options.style === 'function') {
  1810. this.style = options.style;
  1811. }
  1812.  
  1813. if (typeof options.ajaxSource === 'function') {
  1814. this.ajaxSource = options.ajaxSource;
  1815. }
  1816.  
  1817. this.layerLink = options.layerLink;
  1818.  
  1819. this._eventHandlers = {};
  1820.  
  1821. this._tilesToProcess = 0; //store the max number of tiles to be loaded. Later, we can use this count to count down PBF loading.
  1822. },
  1823.  
  1824. redraw: function(triggerOnTilesLoadedEvent){
  1825. //Only set to false if it actually is passed in as 'false'
  1826. if (triggerOnTilesLoadedEvent === false) {
  1827. this._triggerOnTilesLoadedEvent = false;
  1828. }
  1829.  
  1830. L.TileLayer.Canvas.prototype.redraw.call(this);
  1831. },
  1832.  
  1833. onAdd: function(map) {
  1834. var self = this;
  1835. self.map = map;
  1836. L.TileLayer.Canvas.prototype.onAdd.call(this, map);
  1837.  
  1838. var mapOnClickCallback = function(e) {
  1839. self._onClick(e);
  1840. };
  1841.  
  1842. map.on('click', mapOnClickCallback);
  1843.  
  1844. map.on("layerremove", function(e) {
  1845. // check to see if the layer removed is this one
  1846. // call a method to remove the child layers (the ones that actually have something drawn on them).
  1847. if (e.layer._leaflet_id === self._leaflet_id && e.layer.removeChildLayers) {
  1848. e.layer.removeChildLayers(map);
  1849. map.off('click', mapOnClickCallback);
  1850. }
  1851. });
  1852.  
  1853. self.addChildLayers(map);
  1854.  
  1855. if (typeof DynamicLabel === 'function' ) {
  1856. this.dynamicLabel = new DynamicLabel(map, this, {});
  1857. }
  1858.  
  1859. },
  1860.  
  1861. drawTile: function(canvas, tilePoint, zoom) {
  1862. var ctx = {
  1863. id: [zoom, tilePoint.x, tilePoint.y].join(":"),
  1864. canvas: canvas,
  1865. tile: tilePoint,
  1866. zoom: zoom,
  1867. tileSize: this.options.tileSize
  1868. };
  1869.  
  1870. //Capture the max number of the tiles to load here. this._tilesToProcess is an internal number we use to know when we've finished requesting PBFs.
  1871. if(this._tilesToProcess < this._tilesToLoad) this._tilesToProcess = this._tilesToLoad;
  1872.  
  1873. var id = ctx.id = Util.getContextID(ctx);
  1874. this.activeTiles[id] = ctx;
  1875.  
  1876. if(!this.processedTiles[ctx.zoom]) this.processedTiles[ctx.zoom] = {};
  1877.  
  1878. if (this.options.debug) {
  1879. this._drawDebugInfo(ctx);
  1880. }
  1881. this._draw(ctx);
  1882. },
  1883.  
  1884. setOpacity:function(opacity) {
  1885. this._setVisibleLayersStyle('opacity',opacity);
  1886. },
  1887.  
  1888. setZIndex:function(zIndex) {
  1889. this._setVisibleLayersStyle('zIndex',zIndex);
  1890. },
  1891.  
  1892. _setVisibleLayersStyle:function(style, value) {
  1893. for(var key in this.layers) {
  1894. this.layers[key]._tileContainer.style[style] = value;
  1895. }
  1896. },
  1897.  
  1898. _drawDebugInfo: function(ctx) {
  1899. var max = this.options.tileSize;
  1900. var g = ctx.canvas.getContext('2d');
  1901. g.strokeStyle = '#000000';
  1902. g.fillStyle = '#FFFF00';
  1903. g.strokeRect(0, 0, max, max);
  1904. g.font = "12px Arial";
  1905. g.fillRect(0, 0, 5, 5);
  1906. g.fillRect(0, max - 5, 5, 5);
  1907. g.fillRect(max - 5, 0, 5, 5);
  1908. g.fillRect(max - 5, max - 5, 5, 5);
  1909. g.fillRect(max / 2 - 5, max / 2 - 5, 10, 10);
  1910. g.strokeText(ctx.zoom + ' ' + ctx.tile.x + ' ' + ctx.tile.y, max / 2 - 30, max / 2 - 10);
  1911. },
  1912.  
  1913. _draw: function(ctx) {
  1914. var self = this;
  1915.  
  1916. // //This works to skip fetching and processing tiles if they've already been processed.
  1917. // var vectorTile = this.processedTiles[ctx.zoom][ctx.id];
  1918. // //if we've already parsed it, don't get it again.
  1919. // if(vectorTile){
  1920. // console.log("Skipping fetching " + ctx.id);
  1921. // self.checkVectorTileLayers(parseVT(vectorTile), ctx, true);
  1922. // self.reduceTilesToProcessCount();
  1923. // return;
  1924. // }
  1925.  
  1926. if (!this._url) return;
  1927. var src = this.getTileUrl({ x: ctx.tile.x, y: ctx.tile.y, z: ctx.zoom });
  1928.  
  1929. var xhr = new XMLHttpRequest();
  1930. xhr.onload = function() {
  1931. if (xhr.status == "200") {
  1932.  
  1933. if(!xhr.response) return;
  1934.  
  1935. var arrayBuffer = new Uint8Array(xhr.response);
  1936. var buf = new Protobuf(arrayBuffer);
  1937. var vt = new VectorTile(buf);
  1938. //Check the current map layer zoom. If fast zooming is occurring, then short circuit tiles that are for a different zoom level than we're currently on.
  1939. if(self.map && self.map.getZoom() != ctx.zoom) {
  1940. console.log("Fetched tile for zoom level " + ctx.zoom + ". Map is at zoom level " + self._map.getZoom());
  1941. return;
  1942. }
  1943. self.checkVectorTileLayers(parseVT(vt), ctx);
  1944. tileLoaded(self, ctx);
  1945. }
  1946.  
  1947. //either way, reduce the count of tilesToProcess tiles here
  1948. self.reduceTilesToProcessCount();
  1949. };
  1950.  
  1951. xhr.onerror = function() {
  1952. console.log("xhr error: " + xhr.status)
  1953. };
  1954.  
  1955. xhr.open('GET', src, true); //async is true
  1956. var headers = self.options.xhrHeaders;
  1957. for (var header in headers) {
  1958. xhr.setRequestHeader(header, headers[header])
  1959. }
  1960. xhr.responseType = 'arraybuffer';
  1961. xhr.send();
  1962. },
  1963.  
  1964. reduceTilesToProcessCount: function(){
  1965. this._tilesToProcess--;
  1966. if(!this._tilesToProcess){
  1967. //Trigger event letting us know that all PBFs have been loaded and processed (or 404'd).
  1968. if(this._eventHandlers["PBFLoad"]) this._eventHandlers["PBFLoad"]();
  1969. this._pbfLoaded();
  1970. }
  1971. },
  1972.  
  1973. checkVectorTileLayers: function(vt, ctx, parsed) {
  1974. var self = this;
  1975.  
  1976. //Check if there are specified visible layers
  1977. if(self.options.visibleLayers && self.options.visibleLayers.length > 0){
  1978. //only let thru the layers listed in the visibleLayers array
  1979. for(var i=0; i < self.options.visibleLayers.length; i++){
  1980. var layerName = self.options.visibleLayers[i];
  1981. if(vt.layers[layerName]){
  1982. //Proceed with parsing
  1983. self.prepareMVTLayers(vt.layers[layerName], layerName, ctx, parsed);
  1984. }
  1985. }
  1986. }else{
  1987. //Parse all vt.layers
  1988. for (var key in vt.layers) {
  1989. self.prepareMVTLayers(vt.layers[key], key, ctx, parsed);
  1990. }
  1991. }
  1992. },
  1993.  
  1994. prepareMVTLayers: function(lyr ,key, ctx, parsed) {
  1995. var self = this;
  1996.  
  1997. if (!self.layers[key]) {
  1998. //Create MVTLayer or MVTPointLayer for user
  1999. self.layers[key] = self.createMVTLayer(key, lyr.parsedFeatures[0].type || null);
  2000. }
  2001.  
  2002. if (parsed) {
  2003. //We've already parsed it. Go get canvas and draw.
  2004. self.layers[key].getCanvas(ctx, lyr);
  2005. } else {
  2006. self.layers[key].parseVectorTileLayer(lyr, ctx);
  2007. }
  2008.  
  2009. },
  2010.  
  2011. createMVTLayer: function(key, type) {
  2012. var self = this;
  2013.  
  2014. var getIDForLayerFeature;
  2015. if (typeof self.options.getIDForLayerFeature === 'function') {
  2016. getIDForLayerFeature = self.options.getIDForLayerFeature;
  2017. } else {
  2018. getIDForLayerFeature = Util.getIDForLayerFeature;
  2019. }
  2020.  
  2021. var options = {
  2022. getIDForLayerFeature: getIDForLayerFeature,
  2023. filter: self.options.filter,
  2024. layerOrdering: self.options.layerOrdering,
  2025. style: self.style,
  2026. name: key,
  2027. asynch: true
  2028. };
  2029.  
  2030. if (self.options.zIndex) {
  2031. options.zIndex = self.zIndex;
  2032. }
  2033.  
  2034. //Take the layer and create a new MVTLayer or MVTPointLayer if one doesn't exist.
  2035. var layer = new MVTLayer(self, options).addTo(self.map);
  2036.  
  2037. return layer;
  2038. },
  2039.  
  2040. getLayers: function() {
  2041. return this.layers;
  2042. },
  2043.  
  2044. hideLayer: function(id) {
  2045. if (this.layers[id]) {
  2046. this._map.removeLayer(this.layers[id]);
  2047. if(this.options.visibleLayers.indexOf("id") > -1){
  2048. this.visibleLayers.splice(this.options.visibleLayers.indexOf("id"), 1);
  2049. }
  2050. }
  2051. },
  2052.  
  2053. showLayer: function(id) {
  2054. if (this.layers[id]) {
  2055. this._map.addLayer(this.layers[id]);
  2056. if(this.options.visibleLayers.indexOf("id") == -1){
  2057. this.visibleLayers.push(id);
  2058. }
  2059. }
  2060. //Make sure manager layer is always in front
  2061. this.bringToFront();
  2062. },
  2063.  
  2064. removeChildLayers: function(map){
  2065. //Remove child layers of this group layer
  2066. for (var key in this.layers) {
  2067. var layer = this.layers[key];
  2068. map.removeLayer(layer);
  2069. }
  2070. },
  2071.  
  2072. addChildLayers: function(map) {
  2073. var self = this;
  2074. if(self.options.visibleLayers.length > 0){
  2075. //only let thru the layers listed in the visibleLayers array
  2076. for(var i=0; i < self.options.visibleLayers.length; i++){
  2077. var layerName = self.options.visibleLayers[i];
  2078. var layer = this.layers[layerName];
  2079. if(layer){
  2080. //Proceed with parsing
  2081. map.addLayer(layer);
  2082. }
  2083. }
  2084. }else{
  2085. //Add all layers
  2086. for (var key in this.layers) {
  2087. var layer = this.layers[key];
  2088. // layer is set to visible and is not already on map
  2089. if (!layer._map) {
  2090. map.addLayer(layer);
  2091. }
  2092. }
  2093. }
  2094. },
  2095.  
  2096. bind: function(eventType, callback) {
  2097. this._eventHandlers[eventType] = callback;
  2098. },
  2099.  
  2100. _onClick: function(evt) {
  2101. //Here, pass the event on to the child MVTLayer and have it do the hit test and handle the result.
  2102. var self = this;
  2103. var onClick = self.options.onClick;
  2104. var clickableLayers = self.options.clickableLayers;
  2105. var layers = self.layers;
  2106.  
  2107. evt.tileID = getTileURL(evt.latlng.lat, evt.latlng.lng, this.map.getZoom());
  2108.  
  2109. // We must have an array of clickable layers, otherwise, we just pass
  2110. // the event to the public onClick callback in options.
  2111.  
  2112. if(!clickableLayers){
  2113. clickableLayers = Object.keys(self.layers);
  2114. }
  2115.  
  2116. if (clickableLayers && clickableLayers.length > 0) {
  2117. for (var i = 0, len = clickableLayers.length; i < len; i++) {
  2118. var key = clickableLayers[i];
  2119. var layer = layers[key];
  2120. if (layer) {
  2121. layer.handleClickEvent(evt, function(evt) {
  2122. if (typeof onClick === 'function') {
  2123. onClick(evt);
  2124. }
  2125. });
  2126. }
  2127. }
  2128. } else {
  2129. if (typeof onClick === 'function') {
  2130. onClick(evt);
  2131. }
  2132. }
  2133.  
  2134. },
  2135.  
  2136. setFilter: function(filterFunction, layerName) {
  2137. //take in a new filter function.
  2138. //Propagate to child layers.
  2139.  
  2140. //Add filter to all child layers if no layer is specified.
  2141. for (var key in this.layers) {
  2142. var layer = this.layers[key];
  2143.  
  2144. if (layerName){
  2145. if(key.toLowerCase() == layerName.toLowerCase()){
  2146. layer.options.filter = filterFunction; //Assign filter to child layer, only if name matches
  2147. //After filter is set, the old feature hashes are invalid. Clear them for next draw.
  2148. layer.clearLayerFeatureHash();
  2149. //layer.clearTileFeatureHash();
  2150. }
  2151. }
  2152. else{
  2153. layer.options.filter = filterFunction; //Assign filter to child layer
  2154. //After filter is set, the old feature hashes are invalid. Clear them for next draw.
  2155. layer.clearLayerFeatureHash();
  2156. //layer.clearTileFeatureHash();
  2157. }
  2158. }
  2159. },
  2160.  
  2161. /**
  2162. * Take in a new style function and propogate to child layers.
  2163. * If you do not set a layer name, it resets the style for all of the layers.
  2164. * @param styleFunction
  2165. * @param layerName
  2166. */
  2167. setStyle: function(styleFn, layerName) {
  2168. for (var key in this.layers) {
  2169. var layer = this.layers[key];
  2170. if (layerName) {
  2171. if(key.toLowerCase() == layerName.toLowerCase()) {
  2172. layer.setStyle(styleFn);
  2173. }
  2174. } else {
  2175. layer.setStyle(styleFn);
  2176. }
  2177. }
  2178. },
  2179.  
  2180. featureSelected: function(mvtFeature) {
  2181. if (this.options.mutexToggle) {
  2182. if (this._selectedFeature) {
  2183. this._selectedFeature.deselect();
  2184. }
  2185. this._selectedFeature = mvtFeature;
  2186. }
  2187. if (this.options.onSelect) {
  2188. this.options.onSelect(mvtFeature);
  2189. }
  2190. },
  2191.  
  2192. featureDeselected: function(mvtFeature) {
  2193. if (this.options.mutexToggle && this._selectedFeature) {
  2194. this._selectedFeature = null;
  2195. }
  2196. if (this.options.onDeselect) {
  2197. this.options.onDeselect(mvtFeature);
  2198. }
  2199. },
  2200.  
  2201. _pbfLoaded: function() {
  2202. //Fires when all tiles from this layer have been loaded and drawn (or 404'd).
  2203.  
  2204. //Make sure manager layer is always in front
  2205. this.bringToFront();
  2206.  
  2207. //See if there is an event to execute
  2208. var self = this;
  2209. var onTilesLoaded = self.options.onTilesLoaded;
  2210.  
  2211. if (onTilesLoaded && typeof onTilesLoaded === 'function' && this._triggerOnTilesLoadedEvent === true) {
  2212. onTilesLoaded(this);
  2213. }
  2214. self._triggerOnTilesLoadedEvent = true; //reset - if redraw() is called with the optinal 'false' parameter to temporarily disable the onTilesLoaded event from firing. This resets it back to true after a single time of firing as 'false'.
  2215. }
  2216.  
  2217. });
  2218.  
  2219.  
  2220. if (typeof(Number.prototype.toRad) === "undefined") {
  2221. Number.prototype.toRad = function() {
  2222. return this * Math.PI / 180;
  2223. }
  2224. }
  2225.  
  2226. function getTileURL(lat, lon, zoom) {
  2227. var xtile = parseInt(Math.floor( (lon + 180) / 360 * (1<<zoom) ));
  2228. var ytile = parseInt(Math.floor( (1 - Math.log(Math.tan(lat.toRad()) + 1 / Math.cos(lat.toRad())) / Math.PI) / 2 * (1<<zoom) ));
  2229. return "" + zoom + ":" + xtile + ":" + ytile;
  2230. }
  2231.  
  2232. function tileLoaded(pbfSource, ctx) {
  2233. pbfSource.loadedTiles[ctx.id] = ctx;
  2234. }
  2235.  
  2236. function parseVT(vt){
  2237. for (var key in vt.layers) {
  2238. var lyr = vt.layers[key];
  2239. parseVTFeatures(lyr);
  2240. }
  2241. return vt;
  2242. }
  2243.  
  2244. function parseVTFeatures(vtl){
  2245. vtl.parsedFeatures = [];
  2246. var features = vtl._features;
  2247. for (var i = 0, len = features.length; i < len; i++) {
  2248. var vtf = vtl.feature(i);
  2249. vtf.coordinates = vtf.loadGeometry();
  2250. vtl.parsedFeatures.push(vtf);
  2251. }
  2252. return vtl;
  2253. }
  2254.  
  2255. },{"./MVTLayer":9,"./MVTUtil":11,"pbf":1,"point-geometry":3,"vector-tile":4}],11:[function(require,module,exports){
  2256. /**
  2257. * Created by Nicholas Hallahan <nhallahan@spatialdev.com>
  2258. * on 8/15/14.
  2259. */
  2260. var Util = module.exports = {};
  2261.  
  2262. Util.getContextID = function(ctx) {
  2263. return [ctx.zoom, ctx.tile.x, ctx.tile.y].join(":");
  2264. };
  2265.  
  2266. /**
  2267. * Default function that gets the id for a layer feature.
  2268. * Sometimes this needs to be done in a different way and
  2269. * can be specified by the user in the options for L.TileLayer.MVTSource.
  2270. *
  2271. * @param feature
  2272. * @returns {ctx.id|*|id|string|jsts.index.chain.MonotoneChain.id|number}
  2273. */
  2274. Util.getIDForLayerFeature = function(feature) {
  2275. return feature.properties.id;
  2276. };
  2277.  
  2278. Util.getJSON = function(url, callback) {
  2279. var xmlhttp = typeof XMLHttpRequest !== 'undefined' ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP');
  2280. xmlhttp.onreadystatechange = function() {
  2281. var status = xmlhttp.status;
  2282. if (xmlhttp.readyState === 4 && status >= 200 && status < 300) {
  2283. var json = JSON.parse(xmlhttp.responseText);
  2284. callback(null, json);
  2285. } else {
  2286. callback( { error: true, status: status } );
  2287. }
  2288. };
  2289. xmlhttp.open("GET", url, true);
  2290. xmlhttp.send();
  2291. };
  2292.  
  2293. },{}],12:[function(require,module,exports){
  2294. /**
  2295. * Created by Nicholas Hallahan <nhallahan@spatialdev.com>
  2296. * on 7/31/14.
  2297. */
  2298. var Util = require('../MVTUtil');
  2299. module.exports = StaticLabel;
  2300.  
  2301. function StaticLabel(mvtFeature, ctx, latLng, style) {
  2302. var self = this;
  2303. this.mvtFeature = mvtFeature;
  2304. this.map = mvtFeature.map;
  2305. this.zoom = ctx.zoom;
  2306. this.latLng = latLng;
  2307. this.selected = false;
  2308.  
  2309. if (mvtFeature.linkedFeature) {
  2310. var linkedFeature = mvtFeature.linkedFeature();
  2311. if (linkedFeature && linkedFeature.selected) {
  2312. self.selected = true;
  2313. }
  2314. }
  2315.  
  2316. init(self, mvtFeature, ctx, latLng, style)
  2317. }
  2318.  
  2319. function init(self, mvtFeature, ctx, latLng, style) {
  2320. var ajaxData = mvtFeature.ajaxData;
  2321. var sty = self.style = style.staticLabel(mvtFeature, ajaxData);
  2322. var icon = self.icon = L.divIcon({
  2323. className: sty.cssClass || 'label-icon-text',
  2324. html: sty.html,
  2325. iconSize: sty.iconSize || [50,50]
  2326. });
  2327.  
  2328. self.marker = L.marker(latLng, {icon: icon}).addTo(self.map);
  2329.  
  2330. if (self.selected) {
  2331. self.marker._icon.classList.add(self.style.cssSelectedClass || 'label-icon-text-selected');
  2332. }
  2333.  
  2334. self.marker.on('click', function(e) {
  2335. self.toggle();
  2336. });
  2337.  
  2338. self.map.on('zoomend', function(e) {
  2339. var newZoom = e.target.getZoom();
  2340. if (self.zoom !== newZoom) {
  2341. self.map.removeLayer(self.marker);
  2342. }
  2343. });
  2344. }
  2345.  
  2346.  
  2347. StaticLabel.prototype.toggle = function() {
  2348. if (this.selected) {
  2349. this.deselect();
  2350. } else {
  2351. this.select();
  2352. }
  2353. };
  2354.  
  2355. StaticLabel.prototype.select = function() {
  2356. this.selected = true;
  2357. this.marker._icon.classList.add(this.style.cssSelectedClass || 'label-icon-text-selected');
  2358. var linkedFeature = this.mvtFeature.linkedFeature();
  2359. if (!linkedFeature.selected) linkedFeature.select();
  2360. };
  2361.  
  2362. StaticLabel.prototype.deselect = function() {
  2363. this.selected = false;
  2364. this.marker._icon.classList.remove(this.style.cssSelectedClass || 'label-icon-text-selected');
  2365. var linkedFeature = this.mvtFeature.linkedFeature();
  2366. if (linkedFeature.selected) linkedFeature.deselect();
  2367. };
  2368.  
  2369. StaticLabel.prototype.remove = function() {
  2370. if (!this.map || !this.marker) return;
  2371. this.map.removeLayer(this.marker);
  2372. };
  2373.  
  2374. },{"../MVTUtil":11}],13:[function(require,module,exports){
  2375. /**
  2376. * Copyright (c) 2014, Spatial Development International
  2377. * All rights reserved.
  2378. *
  2379. * Source code can be found at:
  2380. * https://github.com/SpatialServer/Leaflet.MapboxVectorTile
  2381. *
  2382. * @license ISC
  2383. */
  2384.  
  2385. module.exports = require('./MVTSource');
  2386.  
  2387. },{"./MVTSource":10}],14:[function(require,module,exports){
  2388. (function (global){
  2389. /*!
  2390. * The buffer module from node.js, for the browser.
  2391. *
  2392. * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
  2393. * @license MIT
  2394. */
  2395. /* eslint-disable no-proto */
  2396.  
  2397. var base64 = require('base64-js')
  2398. var ieee754 = require('ieee754')
  2399. var isArray = require('is-array')
  2400.  
  2401. exports.Buffer = Buffer
  2402. exports.SlowBuffer = SlowBuffer
  2403. exports.INSPECT_MAX_BYTES = 50
  2404. Buffer.poolSize = 8192 // not used by this implementation
  2405.  
  2406. var rootParent = {}
  2407.  
  2408. /**
  2409. * If `Buffer.TYPED_ARRAY_SUPPORT`:
  2410. * === true Use Uint8Array implementation (fastest)
  2411. * === false Use Object implementation (most compatible, even IE6)
  2412. *
  2413. * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,
  2414. * Opera 11.6+, iOS 4.2+.
  2415. *
  2416. * Due to various browser bugs, sometimes the Object implementation will be used even
  2417. * when the browser supports typed arrays.
  2418. *
  2419. * Note:
  2420. *
  2421. * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,
  2422. * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.
  2423. *
  2424. * - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property
  2425. * on objects.
  2426. *
  2427. * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.
  2428. *
  2429. * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of
  2430. * incorrect length in some situations.
  2431.  
  2432. * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they
  2433. * get the Object implementation, which is slower but behaves correctly.
  2434. */
  2435. Buffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined
  2436. ? global.TYPED_ARRAY_SUPPORT
  2437. : typedArraySupport()
  2438.  
  2439. function typedArraySupport () {
  2440. function Bar () {}
  2441. try {
  2442. var arr = new Uint8Array(1)
  2443. arr.foo = function () { return 42 }
  2444. arr.constructor = Bar
  2445. return arr.foo() === 42 && // typed array instances can be augmented
  2446. arr.constructor === Bar && // constructor can be set
  2447. typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`
  2448. arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`
  2449. } catch (e) {
  2450. return false
  2451. }
  2452. }
  2453.  
  2454. function kMaxLength () {
  2455. return Buffer.TYPED_ARRAY_SUPPORT
  2456. ? 0x7fffffff
  2457. : 0x3fffffff
  2458. }
  2459.  
  2460. /**
  2461. * Class: Buffer
  2462. * =============
  2463. *
  2464. * The Buffer constructor returns instances of `Uint8Array` that are augmented
  2465. * with function properties for all the node `Buffer` API functions. We use
  2466. * `Uint8Array` so that square bracket notation works as expected -- it returns
  2467. * a single octet.
  2468. *
  2469. * By augmenting the instances, we can avoid modifying the `Uint8Array`
  2470. * prototype.
  2471. */
  2472. function Buffer (arg) {
  2473. if (!(this instanceof Buffer)) {
  2474. // Avoid going through an ArgumentsAdaptorTrampoline in the common case.
  2475. if (arguments.length > 1) return new Buffer(arg, arguments[1])
  2476. return new Buffer(arg)
  2477. }
  2478.  
  2479. this.length = 0
  2480. this.parent = undefined
  2481.  
  2482. // Common case.
  2483. if (typeof arg === 'number') {
  2484. return fromNumber(this, arg)
  2485. }
  2486.  
  2487. // Slightly less common case.
  2488. if (typeof arg === 'string') {
  2489. return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8')
  2490. }
  2491.  
  2492. // Unusual.
  2493. return fromObject(this, arg)
  2494. }
  2495.  
  2496. function fromNumber (that, length) {
  2497. that = allocate(that, length < 0 ? 0 : checked(length) | 0)
  2498. if (!Buffer.TYPED_ARRAY_SUPPORT) {
  2499. for (var i = 0; i < length; i++) {
  2500. that[i] = 0
  2501. }
  2502. }
  2503. return that
  2504. }
  2505.  
  2506. function fromString (that, string, encoding) {
  2507. if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8'
  2508.  
  2509. // Assumption: byteLength() return value is always < kMaxLength.
  2510. var length = byteLength(string, encoding) | 0
  2511. that = allocate(that, length)
  2512.  
  2513. that.write(string, encoding)
  2514. return that
  2515. }
  2516.  
  2517. function fromObject (that, object) {
  2518. if (Buffer.isBuffer(object)) return fromBuffer(that, object)
  2519.  
  2520. if (isArray(object)) return fromArray(that, object)
  2521.  
  2522. if (object == null) {
  2523. throw new TypeError('must start with number, buffer, array or string')
  2524. }
  2525.  
  2526. if (typeof ArrayBuffer !== 'undefined') {
  2527. if (object.buffer instanceof ArrayBuffer) {
  2528. return fromTypedArray(that, object)
  2529. }
  2530. if (object instanceof ArrayBuffer) {
  2531. return fromArrayBuffer(that, object)
  2532. }
  2533. }
  2534.  
  2535. if (object.length) return fromArrayLike(that, object)
  2536.  
  2537. return fromJsonObject(that, object)
  2538. }
  2539.  
  2540. function fromBuffer (that, buffer) {
  2541. var length = checked(buffer.length) | 0
  2542. that = allocate(that, length)
  2543. buffer.copy(that, 0, 0, length)
  2544. return that
  2545. }
  2546.  
  2547. function fromArray (that, array) {
  2548. var length = checked(array.length) | 0
  2549. that = allocate(that, length)
  2550. for (var i = 0; i < length; i += 1) {
  2551. that[i] = array[i] & 255
  2552. }
  2553. return that
  2554. }
  2555.  
  2556. // Duplicate of fromArray() to keep fromArray() monomorphic.
  2557. function fromTypedArray (that, array) {
  2558. var length = checked(array.length) | 0
  2559. that = allocate(that, length)
  2560. // Truncating the elements is probably not what people expect from typed
  2561. // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior
  2562. // of the old Buffer constructor.
  2563. for (var i = 0; i < length; i += 1) {
  2564. that[i] = array[i] & 255
  2565. }
  2566. return that
  2567. }
  2568.  
  2569. function fromArrayBuffer (that, array) {
  2570. if (Buffer.TYPED_ARRAY_SUPPORT) {
  2571. // Return an augmented `Uint8Array` instance, for best performance
  2572. array.byteLength
  2573. that = Buffer._augment(new Uint8Array(array))
  2574. } else {
  2575. // Fallback: Return an object instance of the Buffer class
  2576. that = fromTypedArray(that, new Uint8Array(array))
  2577. }
  2578. return that
  2579. }
  2580.  
  2581. function fromArrayLike (that, array) {
  2582. var length = checked(array.length) | 0
  2583. that = allocate(that, length)
  2584. for (var i = 0; i < length; i += 1) {
  2585. that[i] = array[i] & 255
  2586. }
  2587. return that
  2588. }
  2589.  
  2590. // Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object.
  2591. // Returns a zero-length buffer for inputs that don't conform to the spec.
  2592. function fromJsonObject (that, object) {
  2593. var array
  2594. var length = 0
  2595.  
  2596. if (object.type === 'Buffer' && isArray(object.data)) {
  2597. array = object.data
  2598. length = checked(array.length) | 0
  2599. }
  2600. that = allocate(that, length)
  2601.  
  2602. for (var i = 0; i < length; i += 1) {
  2603. that[i] = array[i] & 255
  2604. }
  2605. return that
  2606. }
  2607.  
  2608. if (Buffer.TYPED_ARRAY_SUPPORT) {
  2609. Buffer.prototype.__proto__ = Uint8Array.prototype
  2610. Buffer.__proto__ = Uint8Array
  2611. }
  2612.  
  2613. function allocate (that, length) {
  2614. if (Buffer.TYPED_ARRAY_SUPPORT) {
  2615. // Return an augmented `Uint8Array` instance, for best performance
  2616. that = Buffer._augment(new Uint8Array(length))
  2617. that.__proto__ = Buffer.prototype
  2618. } else {
  2619. // Fallback: Return an object instance of the Buffer class
  2620. that.length = length
  2621. that._isBuffer = true
  2622. }
  2623.  
  2624. var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1
  2625. if (fromPool) that.parent = rootParent
  2626.  
  2627. return that
  2628. }
  2629.  
  2630. function checked (length) {
  2631. // Note: cannot use `length < kMaxLength` here because that fails when
  2632. // length is NaN (which is otherwise coerced to zero.)
  2633. if (length >= kMaxLength()) {
  2634. throw new RangeError('Attempt to allocate Buffer larger than maximum ' +
  2635. 'size: 0x' + kMaxLength().toString(16) + ' bytes')
  2636. }
  2637. return length | 0
  2638. }
  2639.  
  2640. function SlowBuffer (subject, encoding) {
  2641. if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding)
  2642.  
  2643. var buf = new Buffer(subject, encoding)
  2644. delete buf.parent
  2645. return buf
  2646. }
  2647.  
  2648. Buffer.isBuffer = function isBuffer (b) {
  2649. return !!(b != null && b._isBuffer)
  2650. }
  2651.  
  2652. Buffer.compare = function compare (a, b) {
  2653. if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {
  2654. throw new TypeError('Arguments must be Buffers')
  2655. }
  2656.  
  2657. if (a === b) return 0
  2658.  
  2659. var x = a.length
  2660. var y = b.length
  2661.  
  2662. var i = 0
  2663. var len = Math.min(x, y)
  2664. while (i < len) {
  2665. if (a[i] !== b[i]) break
  2666.  
  2667. ++i
  2668. }
  2669.  
  2670. if (i !== len) {
  2671. x = a[i]
  2672. y = b[i]
  2673. }
  2674.  
  2675. if (x < y) return -1
  2676. if (y < x) return 1
  2677. return 0
  2678. }
  2679.  
  2680. Buffer.isEncoding = function isEncoding (encoding) {
  2681. switch (String(encoding).toLowerCase()) {
  2682. case 'hex':
  2683. case 'utf8':
  2684. case 'utf-8':
  2685. case 'ascii':
  2686. case 'binary':
  2687. case 'base64':
  2688. case 'raw':
  2689. case 'ucs2':
  2690. case 'ucs-2':
  2691. case 'utf16le':
  2692. case 'utf-16le':
  2693. return true
  2694. default:
  2695. return false
  2696. }
  2697. }
  2698.  
  2699. Buffer.concat = function concat (list, length) {
  2700. if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.')
  2701.  
  2702. if (list.length === 0) {
  2703. return new Buffer(0)
  2704. }
  2705.  
  2706. var i
  2707. if (length === undefined) {
  2708. length = 0
  2709. for (i = 0; i < list.length; i++) {
  2710. length += list[i].length
  2711. }
  2712. }
  2713.  
  2714. var buf = new Buffer(length)
  2715. var pos = 0
  2716. for (i = 0; i < list.length; i++) {
  2717. var item = list[i]
  2718. item.copy(buf, pos)
  2719. pos += item.length
  2720. }
  2721. return buf
  2722. }
  2723.  
  2724. function byteLength (string, encoding) {
  2725. if (typeof string !== 'string') string = '' + string
  2726.  
  2727. var len = string.length
  2728. if (len === 0) return 0
  2729.  
  2730. // Use a for loop to avoid recursion
  2731. var loweredCase = false
  2732. for (;;) {
  2733. switch (encoding) {
  2734. case 'ascii':
  2735. case 'binary':
  2736. // Deprecated
  2737. case 'raw':
  2738. case 'raws':
  2739. return len
  2740. case 'utf8':
  2741. case 'utf-8':
  2742. return utf8ToBytes(string).length
  2743. case 'ucs2':
  2744. case 'ucs-2':
  2745. case 'utf16le':
  2746. case 'utf-16le':
  2747. return len * 2
  2748. case 'hex':
  2749. return len >>> 1
  2750. case 'base64':
  2751. return base64ToBytes(string).length
  2752. default:
  2753. if (loweredCase) return utf8ToBytes(string).length // assume utf8
  2754. encoding = ('' + encoding).toLowerCase()
  2755. loweredCase = true
  2756. }
  2757. }
  2758. }
  2759. Buffer.byteLength = byteLength
  2760.  
  2761. // pre-set for values that may exist in the future
  2762. Buffer.prototype.length = undefined
  2763. Buffer.prototype.parent = undefined
  2764.  
  2765. function slowToString (encoding, start, end) {
  2766. var loweredCase = false
  2767.  
  2768. start = start | 0
  2769. end = end === undefined || end === Infinity ? this.length : end | 0
  2770.  
  2771. if (!encoding) encoding = 'utf8'
  2772. if (start < 0) start = 0
  2773. if (end > this.length) end = this.length
  2774. if (end <= start) return ''
  2775.  
  2776. while (true) {
  2777. switch (encoding) {
  2778. case 'hex':
  2779. return hexSlice(this, start, end)
  2780.  
  2781. case 'utf8':
  2782. case 'utf-8':
  2783. return utf8Slice(this, start, end)
  2784.  
  2785. case 'ascii':
  2786. return asciiSlice(this, start, end)
  2787.  
  2788. case 'binary':
  2789. return binarySlice(this, start, end)
  2790.  
  2791. case 'base64':
  2792. return base64Slice(this, start, end)
  2793.  
  2794. case 'ucs2':
  2795. case 'ucs-2':
  2796. case 'utf16le':
  2797. case 'utf-16le':
  2798. return utf16leSlice(this, start, end)
  2799.  
  2800. default:
  2801. if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)
  2802. encoding = (encoding + '').toLowerCase()
  2803. loweredCase = true
  2804. }
  2805. }
  2806. }
  2807.  
  2808. Buffer.prototype.toString = function toString () {
  2809. var length = this.length | 0
  2810. if (length === 0) return ''
  2811. if (arguments.length === 0) return utf8Slice(this, 0, length)
  2812. return slowToString.apply(this, arguments)
  2813. }
  2814.  
  2815. Buffer.prototype.equals = function equals (b) {
  2816. if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')
  2817. if (this === b) return true
  2818. return Buffer.compare(this, b) === 0
  2819. }
  2820.  
  2821. Buffer.prototype.inspect = function inspect () {
  2822. var str = ''
  2823. var max = exports.INSPECT_MAX_BYTES
  2824. if (this.length > 0) {
  2825. str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')
  2826. if (this.length > max) str += ' ... '
  2827. }
  2828. return '<Buffer ' + str + '>'
  2829. }
  2830.  
  2831. Buffer.prototype.compare = function compare (b) {
  2832. if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')
  2833. if (this === b) return 0
  2834. return Buffer.compare(this, b)
  2835. }
  2836.  
  2837. Buffer.prototype.indexOf = function indexOf (val, byteOffset) {
  2838. if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff
  2839. else if (byteOffset < -0x80000000) byteOffset = -0x80000000
  2840. byteOffset >>= 0
  2841.  
  2842. if (this.length === 0) return -1
  2843. if (byteOffset >= this.length) return -1
  2844.  
  2845. // Negative offsets start from the end of the buffer
  2846. if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0)
  2847.  
  2848. if (typeof val === 'string') {
  2849. if (val.length === 0) return -1 // special case: looking for empty string always fails
  2850. return String.prototype.indexOf.call(this, val, byteOffset)
  2851. }
  2852. if (Buffer.isBuffer(val)) {
  2853. return arrayIndexOf(this, val, byteOffset)
  2854. }
  2855. if (typeof val === 'number') {
  2856. if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') {
  2857. return Uint8Array.prototype.indexOf.call(this, val, byteOffset)
  2858. }
  2859. return arrayIndexOf(this, [ val ], byteOffset)
  2860. }
  2861.  
  2862. function arrayIndexOf (arr, val, byteOffset) {
  2863. var foundIndex = -1
  2864. for (var i = 0; byteOffset + i < arr.length; i++) {
  2865. if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) {
  2866. if (foundIndex === -1) foundIndex = i
  2867. if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex
  2868. } else {
  2869. foundIndex = -1
  2870. }
  2871. }
  2872. return -1
  2873. }
  2874.  
  2875. throw new TypeError('val must be string, number or Buffer')
  2876. }
  2877.  
  2878. // `get` is deprecated
  2879. Buffer.prototype.get = function get (offset) {
  2880. console.log('.get() is deprecated. Access using array indexes instead.')
  2881. return this.readUInt8(offset)
  2882. }
  2883.  
  2884. // `set` is deprecated
  2885. Buffer.prototype.set = function set (v, offset) {
  2886. console.log('.set() is deprecated. Access using array indexes instead.')
  2887. return this.writeUInt8(v, offset)
  2888. }
  2889.  
  2890. function hexWrite (buf, string, offset, length) {
  2891. offset = Number(offset) || 0
  2892. var remaining = buf.length - offset
  2893. if (!length) {
  2894. length = remaining
  2895. } else {
  2896. length = Number(length)
  2897. if (length > remaining) {
  2898. length = remaining
  2899. }
  2900. }
  2901.  
  2902. // must be an even number of digits
  2903. var strLen = string.length
  2904. if (strLen % 2 !== 0) throw new Error('Invalid hex string')
  2905.  
  2906. if (length > strLen / 2) {
  2907. length = strLen / 2
  2908. }
  2909. for (var i = 0; i < length; i++) {
  2910. var parsed = parseInt(string.substr(i * 2, 2), 16)
  2911. if (isNaN(parsed)) throw new Error('Invalid hex string')
  2912. buf[offset + i] = parsed
  2913. }
  2914. return i
  2915. }
  2916.  
  2917. function utf8Write (buf, string, offset, length) {
  2918. return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)
  2919. }
  2920.  
  2921. function asciiWrite (buf, string, offset, length) {
  2922. return blitBuffer(asciiToBytes(string), buf, offset, length)
  2923. }
  2924.  
  2925. function binaryWrite (buf, string, offset, length) {
  2926. return asciiWrite(buf, string, offset, length)
  2927. }
  2928.  
  2929. function base64Write (buf, string, offset, length) {
  2930. return blitBuffer(base64ToBytes(string), buf, offset, length)
  2931. }
  2932.  
  2933. function ucs2Write (buf, string, offset, length) {
  2934. return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)
  2935. }
  2936.  
  2937. Buffer.prototype.write = function write (string, offset, length, encoding) {
  2938. // Buffer#write(string)
  2939. if (offset === undefined) {
  2940. encoding = 'utf8'
  2941. length = this.length
  2942. offset = 0
  2943. // Buffer#write(string, encoding)
  2944. } else if (length === undefined && typeof offset === 'string') {
  2945. encoding = offset
  2946. length = this.length
  2947. offset = 0
  2948. // Buffer#write(string, offset[, length][, encoding])
  2949. } else if (isFinite(offset)) {
  2950. offset = offset | 0
  2951. if (isFinite(length)) {
  2952. length = length | 0
  2953. if (encoding === undefined) encoding = 'utf8'
  2954. } else {
  2955. encoding = length
  2956. length = undefined
  2957. }
  2958. // legacy write(string, encoding, offset, length) - remove in v0.13
  2959. } else {
  2960. var swap = encoding
  2961. encoding = offset
  2962. offset = length | 0
  2963. length = swap
  2964. }
  2965.  
  2966. var remaining = this.length - offset
  2967. if (length === undefined || length > remaining) length = remaining
  2968.  
  2969. if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {
  2970. throw new RangeError('attempt to write outside buffer bounds')
  2971. }
  2972.  
  2973. if (!encoding) encoding = 'utf8'
  2974.  
  2975. var loweredCase = false
  2976. for (;;) {
  2977. switch (encoding) {
  2978. case 'hex':
  2979. return hexWrite(this, string, offset, length)
  2980.  
  2981. case 'utf8':
  2982. case 'utf-8':
  2983. return utf8Write(this, string, offset, length)
  2984.  
  2985. case 'ascii':
  2986. return asciiWrite(this, string, offset, length)
  2987.  
  2988. case 'binary':
  2989. return binaryWrite(this, string, offset, length)
  2990.  
  2991. case 'base64':
  2992. // Warning: maxLength not taken into account in base64Write
  2993. return base64Write(this, string, offset, length)
  2994.  
  2995. case 'ucs2':
  2996. case 'ucs-2':
  2997. case 'utf16le':
  2998. case 'utf-16le':
  2999. return ucs2Write(this, string, offset, length)
  3000.  
  3001. default:
  3002. if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)
  3003. encoding = ('' + encoding).toLowerCase()
  3004. loweredCase = true
  3005. }
  3006. }
  3007. }
  3008.  
  3009. Buffer.prototype.toJSON = function toJSON () {
  3010. return {
  3011. type: 'Buffer',
  3012. data: Array.prototype.slice.call(this._arr || this, 0)
  3013. }
  3014. }
  3015.  
  3016. function base64Slice (buf, start, end) {
  3017. if (start === 0 && end === buf.length) {
  3018. return base64.fromByteArray(buf)
  3019. } else {
  3020. return base64.fromByteArray(buf.slice(start, end))
  3021. }
  3022. }
  3023.  
  3024. function utf8Slice (buf, start, end) {
  3025. end = Math.min(buf.length, end)
  3026. var res = []
  3027.  
  3028. var i = start
  3029. while (i < end) {
  3030. var firstByte = buf[i]
  3031. var codePoint = null
  3032. var bytesPerSequence = (firstByte > 0xEF) ? 4
  3033. : (firstByte > 0xDF) ? 3
  3034. : (firstByte > 0xBF) ? 2
  3035. : 1
  3036.  
  3037. if (i + bytesPerSequence <= end) {
  3038. var secondByte, thirdByte, fourthByte, tempCodePoint
  3039.  
  3040. switch (bytesPerSequence) {
  3041. case 1:
  3042. if (firstByte < 0x80) {
  3043. codePoint = firstByte
  3044. }
  3045. break
  3046. case 2:
  3047. secondByte = buf[i + 1]
  3048. if ((secondByte & 0xC0) === 0x80) {
  3049. tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)
  3050. if (tempCodePoint > 0x7F) {
  3051. codePoint = tempCodePoint
  3052. }
  3053. }
  3054. break
  3055. case 3:
  3056. secondByte = buf[i + 1]
  3057. thirdByte = buf[i + 2]
  3058. if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {
  3059. tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)
  3060. if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {
  3061. codePoint = tempCodePoint
  3062. }
  3063. }
  3064. break
  3065. case 4:
  3066. secondByte = buf[i + 1]
  3067. thirdByte = buf[i + 2]
  3068. fourthByte = buf[i + 3]
  3069. if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {
  3070. tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)
  3071. if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {
  3072. codePoint = tempCodePoint
  3073. }
  3074. }
  3075. }
  3076. }
  3077.  
  3078. if (codePoint === null) {
  3079. // we did not generate a valid codePoint so insert a
  3080. // replacement char (U+FFFD) and advance only 1 byte
  3081. codePoint = 0xFFFD
  3082. bytesPerSequence = 1
  3083. } else if (codePoint > 0xFFFF) {
  3084. // encode to utf16 (surrogate pair dance)
  3085. codePoint -= 0x10000
  3086. res.push(codePoint >>> 10 & 0x3FF | 0xD800)
  3087. codePoint = 0xDC00 | codePoint & 0x3FF
  3088. }
  3089.  
  3090. res.push(codePoint)
  3091. i += bytesPerSequence
  3092. }
  3093.  
  3094. return decodeCodePointsArray(res)
  3095. }
  3096.  
  3097. // Based on http://stackoverflow.com/a/22747272/680742, the browser with
  3098. // the lowest limit is Chrome, with 0x10000 args.
  3099. // We go 1 magnitude less, for safety
  3100. var MAX_ARGUMENTS_LENGTH = 0x1000
  3101.  
  3102. function decodeCodePointsArray (codePoints) {
  3103. var len = codePoints.length
  3104. if (len <= MAX_ARGUMENTS_LENGTH) {
  3105. return String.fromCharCode.apply(String, codePoints) // avoid extra slice()
  3106. }
  3107.  
  3108. // Decode in chunks to avoid "call stack size exceeded".
  3109. var res = ''
  3110. var i = 0
  3111. while (i < len) {
  3112. res += String.fromCharCode.apply(
  3113. String,
  3114. codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)
  3115. )
  3116. }
  3117. return res
  3118. }
  3119.  
  3120. function asciiSlice (buf, start, end) {
  3121. var ret = ''
  3122. end = Math.min(buf.length, end)
  3123.  
  3124. for (var i = start; i < end; i++) {
  3125. ret += String.fromCharCode(buf[i] & 0x7F)
  3126. }
  3127. return ret
  3128. }
  3129.  
  3130. function binarySlice (buf, start, end) {
  3131. var ret = ''
  3132. end = Math.min(buf.length, end)
  3133.  
  3134. for (var i = start; i < end; i++) {
  3135. ret += String.fromCharCode(buf[i])
  3136. }
  3137. return ret
  3138. }
  3139.  
  3140. function hexSlice (buf, start, end) {
  3141. var len = buf.length
  3142.  
  3143. if (!start || start < 0) start = 0
  3144. if (!end || end < 0 || end > len) end = len
  3145.  
  3146. var out = ''
  3147. for (var i = start; i < end; i++) {
  3148. out += toHex(buf[i])
  3149. }
  3150. return out
  3151. }
  3152.  
  3153. function utf16leSlice (buf, start, end) {
  3154. var bytes = buf.slice(start, end)
  3155. var res = ''
  3156. for (var i = 0; i < bytes.length; i += 2) {
  3157. res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)
  3158. }
  3159. return res
  3160. }
  3161.  
  3162. Buffer.prototype.slice = function slice (start, end) {
  3163. var len = this.length
  3164. start = ~~start
  3165. end = end === undefined ? len : ~~end
  3166.  
  3167. if (start < 0) {
  3168. start += len
  3169. if (start < 0) start = 0
  3170. } else if (start > len) {
  3171. start = len
  3172. }
  3173.  
  3174. if (end < 0) {
  3175. end += len
  3176. if (end < 0) end = 0
  3177. } else if (end > len) {
  3178. end = len
  3179. }
  3180.  
  3181. if (end < start) end = start
  3182.  
  3183. var newBuf
  3184. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3185. newBuf = Buffer._augment(this.subarray(start, end))
  3186. } else {
  3187. var sliceLen = end - start
  3188. newBuf = new Buffer(sliceLen, undefined)
  3189. for (var i = 0; i < sliceLen; i++) {
  3190. newBuf[i] = this[i + start]
  3191. }
  3192. }
  3193.  
  3194. if (newBuf.length) newBuf.parent = this.parent || this
  3195.  
  3196. return newBuf
  3197. }
  3198.  
  3199. /*
  3200. * Need to make sure that buffer isn't trying to write out of bounds.
  3201. */
  3202. function checkOffset (offset, ext, length) {
  3203. if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')
  3204. if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')
  3205. }
  3206.  
  3207. Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {
  3208. offset = offset | 0
  3209. byteLength = byteLength | 0
  3210. if (!noAssert) checkOffset(offset, byteLength, this.length)
  3211.  
  3212. var val = this[offset]
  3213. var mul = 1
  3214. var i = 0
  3215. while (++i < byteLength && (mul *= 0x100)) {
  3216. val += this[offset + i] * mul
  3217. }
  3218.  
  3219. return val
  3220. }
  3221.  
  3222. Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {
  3223. offset = offset | 0
  3224. byteLength = byteLength | 0
  3225. if (!noAssert) {
  3226. checkOffset(offset, byteLength, this.length)
  3227. }
  3228.  
  3229. var val = this[offset + --byteLength]
  3230. var mul = 1
  3231. while (byteLength > 0 && (mul *= 0x100)) {
  3232. val += this[offset + --byteLength] * mul
  3233. }
  3234.  
  3235. return val
  3236. }
  3237.  
  3238. Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {
  3239. if (!noAssert) checkOffset(offset, 1, this.length)
  3240. return this[offset]
  3241. }
  3242.  
  3243. Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {
  3244. if (!noAssert) checkOffset(offset, 2, this.length)
  3245. return this[offset] | (this[offset + 1] << 8)
  3246. }
  3247.  
  3248. Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {
  3249. if (!noAssert) checkOffset(offset, 2, this.length)
  3250. return (this[offset] << 8) | this[offset + 1]
  3251. }
  3252.  
  3253. Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {
  3254. if (!noAssert) checkOffset(offset, 4, this.length)
  3255.  
  3256. return ((this[offset]) |
  3257. (this[offset + 1] << 8) |
  3258. (this[offset + 2] << 16)) +
  3259. (this[offset + 3] * 0x1000000)
  3260. }
  3261.  
  3262. Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {
  3263. if (!noAssert) checkOffset(offset, 4, this.length)
  3264.  
  3265. return (this[offset] * 0x1000000) +
  3266. ((this[offset + 1] << 16) |
  3267. (this[offset + 2] << 8) |
  3268. this[offset + 3])
  3269. }
  3270.  
  3271. Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {
  3272. offset = offset | 0
  3273. byteLength = byteLength | 0
  3274. if (!noAssert) checkOffset(offset, byteLength, this.length)
  3275.  
  3276. var val = this[offset]
  3277. var mul = 1
  3278. var i = 0
  3279. while (++i < byteLength && (mul *= 0x100)) {
  3280. val += this[offset + i] * mul
  3281. }
  3282. mul *= 0x80
  3283.  
  3284. if (val >= mul) val -= Math.pow(2, 8 * byteLength)
  3285.  
  3286. return val
  3287. }
  3288.  
  3289. Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {
  3290. offset = offset | 0
  3291. byteLength = byteLength | 0
  3292. if (!noAssert) checkOffset(offset, byteLength, this.length)
  3293.  
  3294. var i = byteLength
  3295. var mul = 1
  3296. var val = this[offset + --i]
  3297. while (i > 0 && (mul *= 0x100)) {
  3298. val += this[offset + --i] * mul
  3299. }
  3300. mul *= 0x80
  3301.  
  3302. if (val >= mul) val -= Math.pow(2, 8 * byteLength)
  3303.  
  3304. return val
  3305. }
  3306.  
  3307. Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) {
  3308. if (!noAssert) checkOffset(offset, 1, this.length)
  3309. if (!(this[offset] & 0x80)) return (this[offset])
  3310. return ((0xff - this[offset] + 1) * -1)
  3311. }
  3312.  
  3313. Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {
  3314. if (!noAssert) checkOffset(offset, 2, this.length)
  3315. var val = this[offset] | (this[offset + 1] << 8)
  3316. return (val & 0x8000) ? val | 0xFFFF0000 : val
  3317. }
  3318.  
  3319. Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {
  3320. if (!noAssert) checkOffset(offset, 2, this.length)
  3321. var val = this[offset + 1] | (this[offset] << 8)
  3322. return (val & 0x8000) ? val | 0xFFFF0000 : val
  3323. }
  3324.  
  3325. Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {
  3326. if (!noAssert) checkOffset(offset, 4, this.length)
  3327.  
  3328. return (this[offset]) |
  3329. (this[offset + 1] << 8) |
  3330. (this[offset + 2] << 16) |
  3331. (this[offset + 3] << 24)
  3332. }
  3333.  
  3334. Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {
  3335. if (!noAssert) checkOffset(offset, 4, this.length)
  3336.  
  3337. return (this[offset] << 24) |
  3338. (this[offset + 1] << 16) |
  3339. (this[offset + 2] << 8) |
  3340. (this[offset + 3])
  3341. }
  3342.  
  3343. Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {
  3344. if (!noAssert) checkOffset(offset, 4, this.length)
  3345. return ieee754.read(this, offset, true, 23, 4)
  3346. }
  3347.  
  3348. Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {
  3349. if (!noAssert) checkOffset(offset, 4, this.length)
  3350. return ieee754.read(this, offset, false, 23, 4)
  3351. }
  3352.  
  3353. Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {
  3354. if (!noAssert) checkOffset(offset, 8, this.length)
  3355. return ieee754.read(this, offset, true, 52, 8)
  3356. }
  3357.  
  3358. Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {
  3359. if (!noAssert) checkOffset(offset, 8, this.length)
  3360. return ieee754.read(this, offset, false, 52, 8)
  3361. }
  3362.  
  3363. function checkInt (buf, value, offset, ext, max, min) {
  3364. if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance')
  3365. if (value > max || value < min) throw new RangeError('value is out of bounds')
  3366. if (offset + ext > buf.length) throw new RangeError('index out of range')
  3367. }
  3368.  
  3369. Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {
  3370. value = +value
  3371. offset = offset | 0
  3372. byteLength = byteLength | 0
  3373. if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)
  3374.  
  3375. var mul = 1
  3376. var i = 0
  3377. this[offset] = value & 0xFF
  3378. while (++i < byteLength && (mul *= 0x100)) {
  3379. this[offset + i] = (value / mul) & 0xFF
  3380. }
  3381.  
  3382. return offset + byteLength
  3383. }
  3384.  
  3385. Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {
  3386. value = +value
  3387. offset = offset | 0
  3388. byteLength = byteLength | 0
  3389. if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)
  3390.  
  3391. var i = byteLength - 1
  3392. var mul = 1
  3393. this[offset + i] = value & 0xFF
  3394. while (--i >= 0 && (mul *= 0x100)) {
  3395. this[offset + i] = (value / mul) & 0xFF
  3396. }
  3397.  
  3398. return offset + byteLength
  3399. }
  3400.  
  3401. Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {
  3402. value = +value
  3403. offset = offset | 0
  3404. if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)
  3405. if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)
  3406. this[offset] = (value & 0xff)
  3407. return offset + 1
  3408. }
  3409.  
  3410. function objectWriteUInt16 (buf, value, offset, littleEndian) {
  3411. if (value < 0) value = 0xffff + value + 1
  3412. for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) {
  3413. buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>
  3414. (littleEndian ? i : 1 - i) * 8
  3415. }
  3416. }
  3417.  
  3418. Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {
  3419. value = +value
  3420. offset = offset | 0
  3421. if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)
  3422. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3423. this[offset] = (value & 0xff)
  3424. this[offset + 1] = (value >>> 8)
  3425. } else {
  3426. objectWriteUInt16(this, value, offset, true)
  3427. }
  3428. return offset + 2
  3429. }
  3430.  
  3431. Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {
  3432. value = +value
  3433. offset = offset | 0
  3434. if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)
  3435. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3436. this[offset] = (value >>> 8)
  3437. this[offset + 1] = (value & 0xff)
  3438. } else {
  3439. objectWriteUInt16(this, value, offset, false)
  3440. }
  3441. return offset + 2
  3442. }
  3443.  
  3444. function objectWriteUInt32 (buf, value, offset, littleEndian) {
  3445. if (value < 0) value = 0xffffffff + value + 1
  3446. for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) {
  3447. buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff
  3448. }
  3449. }
  3450.  
  3451. Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {
  3452. value = +value
  3453. offset = offset | 0
  3454. if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)
  3455. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3456. this[offset + 3] = (value >>> 24)
  3457. this[offset + 2] = (value >>> 16)
  3458. this[offset + 1] = (value >>> 8)
  3459. this[offset] = (value & 0xff)
  3460. } else {
  3461. objectWriteUInt32(this, value, offset, true)
  3462. }
  3463. return offset + 4
  3464. }
  3465.  
  3466. Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {
  3467. value = +value
  3468. offset = offset | 0
  3469. if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)
  3470. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3471. this[offset] = (value >>> 24)
  3472. this[offset + 1] = (value >>> 16)
  3473. this[offset + 2] = (value >>> 8)
  3474. this[offset + 3] = (value & 0xff)
  3475. } else {
  3476. objectWriteUInt32(this, value, offset, false)
  3477. }
  3478. return offset + 4
  3479. }
  3480.  
  3481. Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {
  3482. value = +value
  3483. offset = offset | 0
  3484. if (!noAssert) {
  3485. var limit = Math.pow(2, 8 * byteLength - 1)
  3486.  
  3487. checkInt(this, value, offset, byteLength, limit - 1, -limit)
  3488. }
  3489.  
  3490. var i = 0
  3491. var mul = 1
  3492. var sub = value < 0 ? 1 : 0
  3493. this[offset] = value & 0xFF
  3494. while (++i < byteLength && (mul *= 0x100)) {
  3495. this[offset + i] = ((value / mul) >> 0) - sub & 0xFF
  3496. }
  3497.  
  3498. return offset + byteLength
  3499. }
  3500.  
  3501. Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {
  3502. value = +value
  3503. offset = offset | 0
  3504. if (!noAssert) {
  3505. var limit = Math.pow(2, 8 * byteLength - 1)
  3506.  
  3507. checkInt(this, value, offset, byteLength, limit - 1, -limit)
  3508. }
  3509.  
  3510. var i = byteLength - 1
  3511. var mul = 1
  3512. var sub = value < 0 ? 1 : 0
  3513. this[offset + i] = value & 0xFF
  3514. while (--i >= 0 && (mul *= 0x100)) {
  3515. this[offset + i] = ((value / mul) >> 0) - sub & 0xFF
  3516. }
  3517.  
  3518. return offset + byteLength
  3519. }
  3520.  
  3521. Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {
  3522. value = +value
  3523. offset = offset | 0
  3524. if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)
  3525. if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)
  3526. if (value < 0) value = 0xff + value + 1
  3527. this[offset] = (value & 0xff)
  3528. return offset + 1
  3529. }
  3530.  
  3531. Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {
  3532. value = +value
  3533. offset = offset | 0
  3534. if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)
  3535. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3536. this[offset] = (value & 0xff)
  3537. this[offset + 1] = (value >>> 8)
  3538. } else {
  3539. objectWriteUInt16(this, value, offset, true)
  3540. }
  3541. return offset + 2
  3542. }
  3543.  
  3544. Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {
  3545. value = +value
  3546. offset = offset | 0
  3547. if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)
  3548. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3549. this[offset] = (value >>> 8)
  3550. this[offset + 1] = (value & 0xff)
  3551. } else {
  3552. objectWriteUInt16(this, value, offset, false)
  3553. }
  3554. return offset + 2
  3555. }
  3556.  
  3557. Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {
  3558. value = +value
  3559. offset = offset | 0
  3560. if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)
  3561. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3562. this[offset] = (value & 0xff)
  3563. this[offset + 1] = (value >>> 8)
  3564. this[offset + 2] = (value >>> 16)
  3565. this[offset + 3] = (value >>> 24)
  3566. } else {
  3567. objectWriteUInt32(this, value, offset, true)
  3568. }
  3569. return offset + 4
  3570. }
  3571.  
  3572. Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {
  3573. value = +value
  3574. offset = offset | 0
  3575. if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)
  3576. if (value < 0) value = 0xffffffff + value + 1
  3577. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3578. this[offset] = (value >>> 24)
  3579. this[offset + 1] = (value >>> 16)
  3580. this[offset + 2] = (value >>> 8)
  3581. this[offset + 3] = (value & 0xff)
  3582. } else {
  3583. objectWriteUInt32(this, value, offset, false)
  3584. }
  3585. return offset + 4
  3586. }
  3587.  
  3588. function checkIEEE754 (buf, value, offset, ext, max, min) {
  3589. if (value > max || value < min) throw new RangeError('value is out of bounds')
  3590. if (offset + ext > buf.length) throw new RangeError('index out of range')
  3591. if (offset < 0) throw new RangeError('index out of range')
  3592. }
  3593.  
  3594. function writeFloat (buf, value, offset, littleEndian, noAssert) {
  3595. if (!noAssert) {
  3596. checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)
  3597. }
  3598. ieee754.write(buf, value, offset, littleEndian, 23, 4)
  3599. return offset + 4
  3600. }
  3601.  
  3602. Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {
  3603. return writeFloat(this, value, offset, true, noAssert)
  3604. }
  3605.  
  3606. Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {
  3607. return writeFloat(this, value, offset, false, noAssert)
  3608. }
  3609.  
  3610. function writeDouble (buf, value, offset, littleEndian, noAssert) {
  3611. if (!noAssert) {
  3612. checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)
  3613. }
  3614. ieee754.write(buf, value, offset, littleEndian, 52, 8)
  3615. return offset + 8
  3616. }
  3617.  
  3618. Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {
  3619. return writeDouble(this, value, offset, true, noAssert)
  3620. }
  3621.  
  3622. Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {
  3623. return writeDouble(this, value, offset, false, noAssert)
  3624. }
  3625.  
  3626. // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)
  3627. Buffer.prototype.copy = function copy (target, targetStart, start, end) {
  3628. if (!start) start = 0
  3629. if (!end && end !== 0) end = this.length
  3630. if (targetStart >= target.length) targetStart = target.length
  3631. if (!targetStart) targetStart = 0
  3632. if (end > 0 && end < start) end = start
  3633.  
  3634. // Copy 0 bytes; we're done
  3635. if (end === start) return 0
  3636. if (target.length === 0 || this.length === 0) return 0
  3637.  
  3638. // Fatal error conditions
  3639. if (targetStart < 0) {
  3640. throw new RangeError('targetStart out of bounds')
  3641. }
  3642. if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')
  3643. if (end < 0) throw new RangeError('sourceEnd out of bounds')
  3644.  
  3645. // Are we oob?
  3646. if (end > this.length) end = this.length
  3647. if (target.length - targetStart < end - start) {
  3648. end = target.length - targetStart + start
  3649. }
  3650.  
  3651. var len = end - start
  3652. var i
  3653.  
  3654. if (this === target && start < targetStart && targetStart < end) {
  3655. // descending copy from end
  3656. for (i = len - 1; i >= 0; i--) {
  3657. target[i + targetStart] = this[i + start]
  3658. }
  3659. } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {
  3660. // ascending copy from start
  3661. for (i = 0; i < len; i++) {
  3662. target[i + targetStart] = this[i + start]
  3663. }
  3664. } else {
  3665. target._set(this.subarray(start, start + len), targetStart)
  3666. }
  3667.  
  3668. return len
  3669. }
  3670.  
  3671. // fill(value, start=0, end=buffer.length)
  3672. Buffer.prototype.fill = function fill (value, start, end) {
  3673. if (!value) value = 0
  3674. if (!start) start = 0
  3675. if (!end) end = this.length
  3676.  
  3677. if (end < start) throw new RangeError('end < start')
  3678.  
  3679. // Fill 0 bytes; we're done
  3680. if (end === start) return
  3681. if (this.length === 0) return
  3682.  
  3683. if (start < 0 || start >= this.length) throw new RangeError('start out of bounds')
  3684. if (end < 0 || end > this.length) throw new RangeError('end out of bounds')
  3685.  
  3686. var i
  3687. if (typeof value === 'number') {
  3688. for (i = start; i < end; i++) {
  3689. this[i] = value
  3690. }
  3691. } else {
  3692. var bytes = utf8ToBytes(value.toString())
  3693. var len = bytes.length
  3694. for (i = start; i < end; i++) {
  3695. this[i] = bytes[i % len]
  3696. }
  3697. }
  3698.  
  3699. return this
  3700. }
  3701.  
  3702. /**
  3703. * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.
  3704. * Added in Node 0.12. Only available in browsers that support ArrayBuffer.
  3705. */
  3706. Buffer.prototype.toArrayBuffer = function toArrayBuffer () {
  3707. if (typeof Uint8Array !== 'undefined') {
  3708. if (Buffer.TYPED_ARRAY_SUPPORT) {
  3709. return (new Buffer(this)).buffer
  3710. } else {
  3711. var buf = new Uint8Array(this.length)
  3712. for (var i = 0, len = buf.length; i < len; i += 1) {
  3713. buf[i] = this[i]
  3714. }
  3715. return buf.buffer
  3716. }
  3717. } else {
  3718. throw new TypeError('Buffer.toArrayBuffer not supported in this browser')
  3719. }
  3720. }
  3721.  
  3722. // HELPER FUNCTIONS
  3723. // ================
  3724.  
  3725. var BP = Buffer.prototype
  3726.  
  3727. /**
  3728. * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods
  3729. */
  3730. Buffer._augment = function _augment (arr) {
  3731. arr.constructor = Buffer
  3732. arr._isBuffer = true
  3733.  
  3734. // save reference to original Uint8Array set method before overwriting
  3735. arr._set = arr.set
  3736.  
  3737. // deprecated
  3738. arr.get = BP.get
  3739. arr.set = BP.set
  3740.  
  3741. arr.write = BP.write
  3742. arr.toString = BP.toString
  3743. arr.toLocaleString = BP.toString
  3744. arr.toJSON = BP.toJSON
  3745. arr.equals = BP.equals
  3746. arr.compare = BP.compare
  3747. arr.indexOf = BP.indexOf
  3748. arr.copy = BP.copy
  3749. arr.slice = BP.slice
  3750. arr.readUIntLE = BP.readUIntLE
  3751. arr.readUIntBE = BP.readUIntBE
  3752. arr.readUInt8 = BP.readUInt8
  3753. arr.readUInt16LE = BP.readUInt16LE
  3754. arr.readUInt16BE = BP.readUInt16BE
  3755. arr.readUInt32LE = BP.readUInt32LE
  3756. arr.readUInt32BE = BP.readUInt32BE
  3757. arr.readIntLE = BP.readIntLE
  3758. arr.readIntBE = BP.readIntBE
  3759. arr.readInt8 = BP.readInt8
  3760. arr.readInt16LE = BP.readInt16LE
  3761. arr.readInt16BE = BP.readInt16BE
  3762. arr.readInt32LE = BP.readInt32LE
  3763. arr.readInt32BE = BP.readInt32BE
  3764. arr.readFloatLE = BP.readFloatLE
  3765. arr.readFloatBE = BP.readFloatBE
  3766. arr.readDoubleLE = BP.readDoubleLE
  3767. arr.readDoubleBE = BP.readDoubleBE
  3768. arr.writeUInt8 = BP.writeUInt8
  3769. arr.writeUIntLE = BP.writeUIntLE
  3770. arr.writeUIntBE = BP.writeUIntBE
  3771. arr.writeUInt16LE = BP.writeUInt16LE
  3772. arr.writeUInt16BE = BP.writeUInt16BE
  3773. arr.writeUInt32LE = BP.writeUInt32LE
  3774. arr.writeUInt32BE = BP.writeUInt32BE
  3775. arr.writeIntLE = BP.writeIntLE
  3776. arr.writeIntBE = BP.writeIntBE
  3777. arr.writeInt8 = BP.writeInt8
  3778. arr.writeInt16LE = BP.writeInt16LE
  3779. arr.writeInt16BE = BP.writeInt16BE
  3780. arr.writeInt32LE = BP.writeInt32LE
  3781. arr.writeInt32BE = BP.writeInt32BE
  3782. arr.writeFloatLE = BP.writeFloatLE
  3783. arr.writeFloatBE = BP.writeFloatBE
  3784. arr.writeDoubleLE = BP.writeDoubleLE
  3785. arr.writeDoubleBE = BP.writeDoubleBE
  3786. arr.fill = BP.fill
  3787. arr.inspect = BP.inspect
  3788. arr.toArrayBuffer = BP.toArrayBuffer
  3789.  
  3790. return arr
  3791. }
  3792.  
  3793. var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g
  3794.  
  3795. function base64clean (str) {
  3796. // Node strips out invalid characters like \n and \t from the string, base64-js does not
  3797. str = stringtrim(str).replace(INVALID_BASE64_RE, '')
  3798. // Node converts strings with length < 2 to ''
  3799. if (str.length < 2) return ''
  3800. // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not
  3801. while (str.length % 4 !== 0) {
  3802. str = str + '='
  3803. }
  3804. return str
  3805. }
  3806.  
  3807. function stringtrim (str) {
  3808. if (str.trim) return str.trim()
  3809. return str.replace(/^\s+|\s+$/g, '')
  3810. }
  3811.  
  3812. function toHex (n) {
  3813. if (n < 16) return '0' + n.toString(16)
  3814. return n.toString(16)
  3815. }
  3816.  
  3817. function utf8ToBytes (string, units) {
  3818. units = units || Infinity
  3819. var codePoint
  3820. var length = string.length
  3821. var leadSurrogate = null
  3822. var bytes = []
  3823.  
  3824. for (var i = 0; i < length; i++) {
  3825. codePoint = string.charCodeAt(i)
  3826.  
  3827. // is surrogate component
  3828. if (codePoint > 0xD7FF && codePoint < 0xE000) {
  3829. // last char was a lead
  3830. if (!leadSurrogate) {
  3831. // no lead yet
  3832. if (codePoint > 0xDBFF) {
  3833. // unexpected trail
  3834. if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
  3835. continue
  3836. } else if (i + 1 === length) {
  3837. // unpaired lead
  3838. if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
  3839. continue
  3840. }
  3841.  
  3842. // valid lead
  3843. leadSurrogate = codePoint
  3844.  
  3845. continue
  3846. }
  3847.  
  3848. // 2 leads in a row
  3849. if (codePoint < 0xDC00) {
  3850. if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
  3851. leadSurrogate = codePoint
  3852. continue
  3853. }
  3854.  
  3855. // valid surrogate pair
  3856. codePoint = leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00 | 0x10000
  3857. } else if (leadSurrogate) {
  3858. // valid bmp char, but last char was a lead
  3859. if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
  3860. }
  3861.  
  3862. leadSurrogate = null
  3863.  
  3864. // encode utf8
  3865. if (codePoint < 0x80) {
  3866. if ((units -= 1) < 0) break
  3867. bytes.push(codePoint)
  3868. } else if (codePoint < 0x800) {
  3869. if ((units -= 2) < 0) break
  3870. bytes.push(
  3871. codePoint >> 0x6 | 0xC0,
  3872. codePoint & 0x3F | 0x80
  3873. )
  3874. } else if (codePoint < 0x10000) {
  3875. if ((units -= 3) < 0) break
  3876. bytes.push(
  3877. codePoint >> 0xC | 0xE0,
  3878. codePoint >> 0x6 & 0x3F | 0x80,
  3879. codePoint & 0x3F | 0x80
  3880. )
  3881. } else if (codePoint < 0x110000) {
  3882. if ((units -= 4) < 0) break
  3883. bytes.push(
  3884. codePoint >> 0x12 | 0xF0,
  3885. codePoint >> 0xC & 0x3F | 0x80,
  3886. codePoint >> 0x6 & 0x3F | 0x80,
  3887. codePoint & 0x3F | 0x80
  3888. )
  3889. } else {
  3890. throw new Error('Invalid code point')
  3891. }
  3892. }
  3893.  
  3894. return bytes
  3895. }
  3896.  
  3897. function asciiToBytes (str) {
  3898. var byteArray = []
  3899. for (var i = 0; i < str.length; i++) {
  3900. // Node's code seems to be doing this and not & 0x7F..
  3901. byteArray.push(str.charCodeAt(i) & 0xFF)
  3902. }
  3903. return byteArray
  3904. }
  3905.  
  3906. function utf16leToBytes (str, units) {
  3907. var c, hi, lo
  3908. var byteArray = []
  3909. for (var i = 0; i < str.length; i++) {
  3910. if ((units -= 2) < 0) break
  3911.  
  3912. c = str.charCodeAt(i)
  3913. hi = c >> 8
  3914. lo = c % 256
  3915. byteArray.push(lo)
  3916. byteArray.push(hi)
  3917. }
  3918.  
  3919. return byteArray
  3920. }
  3921.  
  3922. function base64ToBytes (str) {
  3923. return base64.toByteArray(base64clean(str))
  3924. }
  3925.  
  3926. function blitBuffer (src, dst, offset, length) {
  3927. for (var i = 0; i < length; i++) {
  3928. if ((i + offset >= dst.length) || (i >= src.length)) break
  3929. dst[i + offset] = src[i]
  3930. }
  3931. return i
  3932. }
  3933.  
  3934. }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
  3935.  
  3936. },{"base64-js":15,"ieee754":16,"is-array":17}],15:[function(require,module,exports){
  3937. var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
  3938.  
  3939. ;(function (exports) {
  3940. 'use strict';
  3941.  
  3942. var Arr = (typeof Uint8Array !== 'undefined')
  3943. ? Uint8Array
  3944. : Array
  3945.  
  3946. var PLUS = '+'.charCodeAt(0)
  3947. var SLASH = '/'.charCodeAt(0)
  3948. var NUMBER = '0'.charCodeAt(0)
  3949. var LOWER = 'a'.charCodeAt(0)
  3950. var UPPER = 'A'.charCodeAt(0)
  3951. var PLUS_URL_SAFE = '-'.charCodeAt(0)
  3952. var SLASH_URL_SAFE = '_'.charCodeAt(0)
  3953.  
  3954. function decode (elt) {
  3955. var code = elt.charCodeAt(0)
  3956. if (code === PLUS ||
  3957. code === PLUS_URL_SAFE)
  3958. return 62 // '+'
  3959. if (code === SLASH ||
  3960. code === SLASH_URL_SAFE)
  3961. return 63 // '/'
  3962. if (code < NUMBER)
  3963. return -1 //no match
  3964. if (code < NUMBER + 10)
  3965. return code - NUMBER + 26 + 26
  3966. if (code < UPPER + 26)
  3967. return code - UPPER
  3968. if (code < LOWER + 26)
  3969. return code - LOWER + 26
  3970. }
  3971.  
  3972. function b64ToByteArray (b64) {
  3973. var i, j, l, tmp, placeHolders, arr
  3974.  
  3975. if (b64.length % 4 > 0) {
  3976. throw new Error('Invalid string. Length must be a multiple of 4')
  3977. }
  3978.  
  3979. // the number of equal signs (place holders)
  3980. // if there are two placeholders, than the two characters before it
  3981. // represent one byte
  3982. // if there is only one, then the three characters before it represent 2 bytes
  3983. // this is just a cheap hack to not do indexOf twice
  3984. var len = b64.length
  3985. placeHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0
  3986.  
  3987. // base64 is 4/3 + up to two characters of the original data
  3988. arr = new Arr(b64.length * 3 / 4 - placeHolders)
  3989.  
  3990. // if there are placeholders, only get up to the last complete 4 chars
  3991. l = placeHolders > 0 ? b64.length - 4 : b64.length
  3992.  
  3993. var L = 0
  3994.  
  3995. function push (v) {
  3996. arr[L++] = v
  3997. }
  3998.  
  3999. for (i = 0, j = 0; i < l; i += 4, j += 3) {
  4000. tmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))
  4001. push((tmp & 0xFF0000) >> 16)
  4002. push((tmp & 0xFF00) >> 8)
  4003. push(tmp & 0xFF)
  4004. }
  4005.  
  4006. if (placeHolders === 2) {
  4007. tmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)
  4008. push(tmp & 0xFF)
  4009. } else if (placeHolders === 1) {
  4010. tmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)
  4011. push((tmp >> 8) & 0xFF)
  4012. push(tmp & 0xFF)
  4013. }
  4014.  
  4015. return arr
  4016. }
  4017.  
  4018. function uint8ToBase64 (uint8) {
  4019. var i,
  4020. extraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes
  4021. output = "",
  4022. temp, length
  4023.  
  4024. function encode (num) {
  4025. return lookup.charAt(num)
  4026. }
  4027.  
  4028. function tripletToBase64 (num) {
  4029. return encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)
  4030. }
  4031.  
  4032. // go through the array every three bytes, we'll deal with trailing stuff later
  4033. for (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {
  4034. temp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])
  4035. output += tripletToBase64(temp)
  4036. }
  4037.  
  4038. // pad the end with zeros, but make sure to not forget the extra bytes
  4039. switch (extraBytes) {
  4040. case 1:
  4041. temp = uint8[uint8.length - 1]
  4042. output += encode(temp >> 2)
  4043. output += encode((temp << 4) & 0x3F)
  4044. output += '=='
  4045. break
  4046. case 2:
  4047. temp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])
  4048. output += encode(temp >> 10)
  4049. output += encode((temp >> 4) & 0x3F)
  4050. output += encode((temp << 2) & 0x3F)
  4051. output += '='
  4052. break
  4053. }
  4054.  
  4055. return output
  4056. }
  4057.  
  4058. exports.toByteArray = b64ToByteArray
  4059. exports.fromByteArray = uint8ToBase64
  4060. }(typeof exports === 'undefined' ? (this.base64js = {}) : exports))
  4061.  
  4062. },{}],16:[function(require,module,exports){
  4063. arguments[4][2][0].apply(exports,arguments)
  4064. },{"dup":2}],17:[function(require,module,exports){
  4065.  
  4066. /**
  4067. * isArray
  4068. */
  4069.  
  4070. var isArray = Array.isArray;
  4071.  
  4072. /**
  4073. * toString
  4074. */
  4075.  
  4076. var str = Object.prototype.toString;
  4077.  
  4078. /**
  4079. * Whether or not the given `val`
  4080. * is an array.
  4081. *
  4082. * example:
  4083. *
  4084. * isArray([]);
  4085. * // > true
  4086. * isArray(arguments);
  4087. * // > false
  4088. * isArray('');
  4089. * // > false
  4090. *
  4091. * @param {mixed} val
  4092. * @return {bool}
  4093. */
  4094.  
  4095. module.exports = isArray || function (val) {
  4096. return !! val && '[object Array]' == str.call(val);
  4097. };
  4098.  
  4099. },{}]},{},[13])
  4100. //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["../../../../usr/local/lib/node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/pbf/index.js","node_modules/pbf/node_modules/ieee754/index.js","node_modules/point-geometry/index.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","src/MVTFeature.js","src/MVTLayer.js","src/MVTSource.js","src/MVTUtil.js","src/StaticLabel/StaticLabel.js","src/index.js","../../../../usr/local/lib/node_modules/browserify/node_modules/buffer/index.js","../../../../usr/local/lib/node_modules/browserify/node_modules/buffer/node_modules/base64-js/lib/b64.js","../../../../usr/local/lib/node_modules/browserify/node_modules/buffer/node_modules/is-array/index.js"],"names":[],"mappings":"AAAA;;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;;;;AChSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;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;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;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC/EA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxgDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":["(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})","'use strict';\n\nvar ieee754 = require('ieee754');\n\nmodule.exports = Protobuf;\nfunction Protobuf(buf) {\n    this.buf = buf;\n    this.pos = 0;\n}\n\nProtobuf.prototype = {\n    get length() { return this.buf.length; }\n};\n\nProtobuf.Varint = 0;\nProtobuf.Int64 = 1;\nProtobuf.Message = 2;\nProtobuf.String = 2;\nProtobuf.Packed = 2;\nProtobuf.Int32 = 5;\n\nProtobuf.prototype.destroy = function() {\n    this.buf = null;\n};\n\n// === READING =================================================================\n\nProtobuf.prototype.readUInt32 = function() {\n    var val = this.buf.readUInt32LE(this.pos);\n    this.pos += 4;\n    return val;\n};\n\nProtobuf.prototype.readUInt64 = function() {\n    var val = this.buf.readUInt64LE(this.pos);\n    this.pos += 8;\n    return val;\n};\n\nProtobuf.prototype.readDouble = function() {\n    var val = ieee754.read(this.buf, this.pos, true, 52, 8);\n    this.pos += 8;\n    return val;\n};\n\nProtobuf.prototype.readVarint = function() {\n    // TODO: bounds checking\n    var pos = this.pos;\n    if (this.buf[pos] <= 0x7f) {\n        this.pos++;\n        return this.buf[pos];\n    } else if (this.buf[pos + 1] <= 0x7f) {\n        this.pos += 2;\n        return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] << 7);\n    } else if (this.buf[pos + 2] <= 0x7f) {\n        this.pos += 3;\n        return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2]) << 14;\n    } else if (this.buf[pos + 3] <= 0x7f) {\n        this.pos += 4;\n        return (this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2] & 0x7f) << 14 | (this.buf[pos + 3]) << 21;\n    } else if (this.buf[pos + 4] <= 0x7f) {\n        this.pos += 5;\n        return ((this.buf[pos] & 0x7f) | (this.buf[pos + 1] & 0x7f) << 7 | (this.buf[pos + 2] & 0x7f) << 14 | (this.buf[pos + 3]) << 21) + (this.buf[pos + 4] * 268435456);\n    } else {\n        this.skip(Protobuf.Varint);\n        return 0;\n        // throw new Error(\"TODO: Handle 6+ byte varints\");\n    }\n};\n\nProtobuf.prototype.readSVarint = function() {\n    var num = this.readVarint();\n    if (num > 2147483647) throw new Error('TODO: Handle numbers >= 2^30');\n    // zigzag encoding\n    return ((num >> 1) ^ -(num & 1));\n};\n\nProtobuf.prototype.readString = function() {\n    var bytes = this.readVarint();\n    // TODO: bounds checking\n    var chr = String.fromCharCode;\n    var b = this.buf;\n    var p = this.pos;\n    var end = this.pos + bytes;\n    var str = '';\n    while (p < end) {\n        if (b[p] <= 0x7F) str += chr(b[p++]);\n        else if (b[p] <= 0xBF) throw new Error('Invalid UTF-8 codepoint: ' + b[p]);\n        else if (b[p] <= 0xDF) str += chr((b[p++] & 0x1F) << 6 | (b[p++] & 0x3F));\n        else if (b[p] <= 0xEF) str += chr((b[p++] & 0x1F) << 12 | (b[p++] & 0x3F) << 6 | (b[p++] & 0x3F));\n        else if (b[p] <= 0xF7) p += 4; // We can't handle these codepoints in JS, so skip.\n        else if (b[p] <= 0xFB) p += 5;\n        else if (b[p] <= 0xFD) p += 6;\n        else throw new Error('Invalid UTF-8 codepoint: ' + b[p]);\n    }\n    this.pos += bytes;\n    return str;\n};\n\nProtobuf.prototype.readBuffer = function() {\n    var bytes = this.readVarint();\n    var buffer = this.buf.subarray(this.pos, this.pos + bytes);\n    this.pos += bytes;\n    return buffer;\n};\n\nProtobuf.prototype.readPacked = function(type) {\n    // TODO: bounds checking\n    var bytes = this.readVarint();\n    var end = this.pos + bytes;\n    var array = [];\n    while (this.pos < end) {\n        array.push(this['read' + type]());\n    }\n    return array;\n};\n\nProtobuf.prototype.skip = function(val) {\n    // TODO: bounds checking\n    var type = val & 0x7;\n    switch (type) {\n        /* varint */ case Protobuf.Varint: while (this.buf[this.pos++] > 0x7f); break;\n        /* 64 bit */ case Protobuf.Int64: this.pos += 8; break;\n        /* length */ case Protobuf.Message: var bytes = this.readVarint(); this.pos += bytes; break;\n        /* 32 bit */ case Protobuf.Int32: this.pos += 4; break;\n        default: throw new Error('Unimplemented type: ' + type);\n    }\n};\n\n// === WRITING =================================================================\n\nProtobuf.prototype.writeTag = function(tag, type) {\n    this.writeVarint((tag << 3) | type);\n};\n\nProtobuf.prototype.realloc = function(min) {\n    var length = this.buf.length;\n    while (length < this.pos + min) length *= 2;\n    if (length != this.buf.length) {\n        var buf = new Buffer(length);\n        this.buf.copy(buf);\n        this.buf = buf;\n    }\n};\n\nProtobuf.prototype.finish = function() {\n    return this.buf.slice(0, this.pos);\n};\n\nProtobuf.prototype.writePacked = function(type, tag, items) {\n    if (!items.length) return;\n\n    var message = new Protobuf();\n    for (var i = 0; i < items.length; i++) {\n        message['write' + type](items[i]);\n    }\n    var data = message.finish();\n\n    this.writeTag(tag, Protobuf.Packed);\n    this.writeBuffer(data);\n};\n\nProtobuf.prototype.writeUInt32 = function(val) {\n    this.realloc(4);\n    this.buf.writeUInt32LE(val, this.pos);\n    this.pos += 4;\n};\n\nProtobuf.prototype.writeTaggedUInt32 = function(tag, val) {\n    this.writeTag(tag, Protobuf.Int32);\n    this.writeUInt32(val);\n};\n\nProtobuf.prototype.writeVarint = function(val) {\n    val = Number(val);\n    if (isNaN(val)) {\n        val = 0;\n    }\n\n    if (val <= 0x7f) {\n        this.realloc(1);\n        this.buf[this.pos++] = val;\n    } else if (val <= 0x3fff) {\n        this.realloc(2);\n        this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);\n        this.buf[this.pos++] = 0x00 | ((val >>> 7) & 0x7f);\n    } else if (val <= 0x1ffffff) {\n        this.realloc(3);\n        this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);\n        this.buf[this.pos++] = 0x80 | ((val >>> 7) & 0x7f);\n        this.buf[this.pos++] = 0x00 | ((val >>> 14) & 0x7f);\n    } else if (val <= 0xfffffff) {\n        this.realloc(4);\n        this.buf[this.pos++] = 0x80 | ((val >>> 0) & 0x7f);\n        this.buf[this.pos++] = 0x80 | ((val >>> 7) & 0x7f);\n        this.buf[this.pos++] = 0x80 | ((val >>> 14) & 0x7f);\n        this.buf[this.pos++] = 0x00 | ((val >>> 21) & 0x7f);\n    } else {\n        while (val > 0) {\n            var b = val & 0x7f;\n            val = Math.floor(val / 128);\n            if (val > 0) b |= 0x80\n            this.realloc(1);\n            this.buf[this.pos++] = b;\n        }\n    }\n};\n\nProtobuf.prototype.writeTaggedVarint = function(tag, val) {\n    this.writeTag(tag, Protobuf.Varint);\n    this.writeVarint(val);\n};\n\nProtobuf.prototype.writeSVarint = function(val) {\n    if (val >= 0) {\n        this.writeVarint(val * 2);\n    } else {\n        this.writeVarint(val * -2 - 1);\n    }\n};\n\nProtobuf.prototype.writeTaggedSVarint = function(tag, val) {\n    this.writeTag(tag, Protobuf.Varint);\n    this.writeSVarint(val);\n};\n\nProtobuf.prototype.writeBoolean = function(val) {\n    this.writeVarint(Boolean(val));\n};\n\nProtobuf.prototype.writeTaggedBoolean = function(tag, val) {\n    this.writeTaggedVarint(tag, Boolean(val));\n};\n\nProtobuf.prototype.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\nProtobuf.prototype.writeTaggedString = function(tag, str) {\n    this.writeTag(tag, Protobuf.String);\n    this.writeString(str);\n};\n\nProtobuf.prototype.writeFloat = function(val) {\n    this.realloc(4);\n    this.buf.writeFloatLE(val, this.pos);\n    this.pos += 4;\n};\n\nProtobuf.prototype.writeTaggedFloat = function(tag, val) {\n    this.writeTag(tag, Protobuf.Int32);\n    this.writeFloat(val);\n};\n\nProtobuf.prototype.writeDouble = function(val) {\n    this.realloc(8);\n    this.buf.writeDoubleLE(val, this.pos);\n    this.pos += 8;\n};\n\nProtobuf.prototype.writeTaggedDouble = function(tag, val) {\n    this.writeTag(tag, Protobuf.Int64);\n    this.writeDouble(val);\n};\n\nProtobuf.prototype.writeBuffer = function(buffer) {\n    var bytes = buffer.length;\n    this.writeVarint(bytes);\n    this.realloc(bytes);\n    buffer.copy(this.buf, this.pos);\n    this.pos += bytes;\n};\n\nProtobuf.prototype.writeTaggedBuffer = function(tag, buffer) {\n    this.writeTag(tag, Protobuf.String);\n    this.writeBuffer(buffer);\n};\n\nProtobuf.prototype.writeMessage = function(tag, protobuf) {\n    var buffer = protobuf.finish();\n    this.writeTag(tag, Protobuf.Message);\n    this.writeBuffer(buffer);\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","'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","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(buffer, end) {\n\n    this.layers = {};\n    this._buffer = buffer;\n\n    end = end || buffer.length;\n\n    while (buffer.pos < end) {\n        var val = buffer.readVarint(),\n            tag = val >> 3;\n\n        if (tag == 3) {\n            var layer = this.readLayer();\n            if (layer.length) this.layers[layer.name] = layer;\n        } else {\n            buffer.skip(val);\n        }\n    }\n}\n\nVectorTile.prototype.readLayer = function() {\n    var buffer = this._buffer,\n        bytes = buffer.readVarint(),\n        end = buffer.pos + bytes,\n        layer = new VectorTileLayer(buffer, end);\n\n    buffer.pos = end;\n\n    return layer;\n};\n","'use strict';\n\nvar Point = require('point-geometry');\n\nmodule.exports = VectorTileFeature;\n\nfunction VectorTileFeature(buffer, end, extent, keys, values) {\n\n    this.properties = {};\n\n    // Public\n    this.extent = extent;\n    this.type = 0;\n\n    // Private\n    this._buffer = buffer;\n    this._geometry = -1;\n\n    end = end || buffer.length;\n\n    while (buffer.pos < end) {\n        var val = buffer.readVarint(),\n            tag = val >> 3;\n\n        if (tag == 1) {\n            this._id = buffer.readVarint();\n\n        } else if (tag == 2) {\n            var tagLen = buffer.readVarint(),\n                tagEnd = buffer.pos + tagLen;\n\n            while (buffer.pos < tagEnd) {\n                var key = keys[buffer.readVarint()];\n                var value = values[buffer.readVarint()];\n                this.properties[key] = value;\n            }\n\n        } else if (tag == 3) {\n            this.type = buffer.readVarint();\n\n        } else if (tag == 4) {\n            this._geometry = buffer.pos;\n            buffer.skip(val);\n\n        } else {\n            buffer.skip(val);\n        }\n    }\n}\n\nVectorTileFeature.types = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nVectorTileFeature.prototype.loadGeometry = function() {\n    var buffer = this._buffer;\n    buffer.pos = this._geometry;\n\n    var bytes = buffer.readVarint(),\n        end = buffer.pos + bytes,\n        cmd = 1,\n        length = 0,\n        x = 0,\n        y = 0,\n        lines = [],\n        line;\n\n    while (buffer.pos < end) {\n        if (!length) {\n            var cmd_length = buffer.readVarint();\n            cmd = cmd_length & 0x7;\n            length = cmd_length >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += buffer.readSVarint();\n            y += buffer.readSVarint();\n\n            if (cmd === 1) {\n                // moveTo\n                if (line) {\n                    lines.push(line);\n                }\n                line = [];\n            }\n\n            line.push(new Point(x, y));\n        } else if (cmd === 7) {\n            // closePolygon\n            line.push(line[0].clone());\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 buffer = this._buffer;\n    buffer.pos = this._geometry;\n\n    var bytes = buffer.readVarint(),\n        end = buffer.pos + bytes,\n\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 (buffer.pos < end) {\n        if (!length) {\n            var cmd_length = buffer.readVarint();\n            cmd = cmd_length & 0x7;\n            length = cmd_length >> 3;\n        }\n\n        length--;\n\n        if (cmd === 1 || cmd === 2) {\n            x += buffer.readSVarint();\n            y += buffer.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","'use strict';\n\nvar VectorTileFeature = require('./vectortilefeature.js');\n\nmodule.exports = VectorTileLayer;\nfunction VectorTileLayer(buffer, end) {\n    // Public\n    this.version = 1;\n    this.name = null;\n    this.extent = 4096;\n    this.length = 0;\n\n    // Private\n    this._buffer = buffer;\n    this._keys = [];\n    this._values = [];\n    this._features = [];\n\n    var val, tag;\n\n    end = end || buffer.length;\n\n    while (buffer.pos < end) {\n        val = buffer.readVarint();\n        tag = val >> 3;\n\n        if (tag === 15) {\n            this.version = buffer.readVarint();\n        } else if (tag === 1) {\n            this.name = buffer.readString();\n        } else if (tag === 5) {\n            this.extent = buffer.readVarint();\n        } else if (tag === 2) {\n            this.length++;\n            this._features.push(buffer.pos);\n            buffer.skip(val);\n\n        } else if (tag === 3) {\n            this._keys.push(buffer.readString());\n        } else if (tag === 4) {\n            this._values.push(this.readFeatureValue());\n        } else {\n            buffer.skip(val);\n        }\n    }\n}\n\nVectorTileLayer.prototype.readFeatureValue = function() {\n    var buffer = this._buffer,\n        value = null,\n        bytes = buffer.readVarint(),\n        end = buffer.pos + bytes,\n        val, tag;\n\n    while (buffer.pos < end) {\n        val = buffer.readVarint();\n        tag = val >> 3;\n\n        if (tag == 1) {\n            value = buffer.readString();\n        } else if (tag == 2) {\n            throw new Error('read float');\n        } else if (tag == 3) {\n            value = buffer.readDouble();\n        } else if (tag == 4) {\n            value = buffer.readVarint();\n        } else if (tag == 5) {\n            throw new Error('read uint');\n        } else if (tag == 6) {\n            value = buffer.readSVarint();\n        } else if (tag == 7) {\n            value = Boolean(buffer.readVarint());\n        } else {\n            buffer.skip(val);\n        }\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._buffer.pos = this._features[i];\n    var end = this._buffer.readVarint() + this._buffer.pos;\n\n    return new VectorTileFeature(this._buffer, end, this.extent, this._keys, this._values);\n};\n","/**\n * Created by Ryan Whitley, Daniel Duarte, and Nicholas Hallahan\n *    on 6/03/14.\n */\nvar Util = require('./MVTUtil');\nvar StaticLabel = require('./StaticLabel/StaticLabel.js');\n\nmodule.exports = MVTFeature;\n\nfunction MVTFeature(mvtLayer, vtf, ctx, id, style) {\n  if (!vtf) return null;\n\n  // Apply all of the properties of vtf to this object.\n  for (var key in vtf) {\n    this[key] = vtf[key];\n  }\n\n  this.mvtLayer = mvtLayer;\n  this.mvtSource = mvtLayer.mvtSource;\n  this.map = mvtLayer.mvtSource.map;\n\n  this.id = id;\n\n  this.layerLink = this.mvtSource.layerLink;\n  this.toggleEnabled = true;\n  this.selected = false;\n\n  // how much we divide the coordinate from the vector tile\n  this.divisor = vtf.extent / ctx.tileSize;\n  this.extent = vtf.extent;\n  this.tileSize = ctx.tileSize;\n\n  //An object to store the paths and contexts for this feature\n  this.tiles = {};\n\n  this.style = style;\n\n  //Add to the collection\n  this.addTileFeature(vtf, ctx);\n\n  var self = this;\n  this.map.on('zoomend', function() {\n    self.staticLabel = null;\n  });\n\n  if (style && style.dynamicLabel && typeof style.dynamicLabel === 'function') {\n    this.dynamicLabel = this.mvtSource.dynamicLabel.createFeature(this);\n  }\n\n  ajax(self);\n}\n\n\nfunction ajax(self) {\n  var style = self.style;\n  if (style && style.ajaxSource && typeof style.ajaxSource === 'function') {\n    var ajaxEndpoint = style.ajaxSource(self);\n    if (ajaxEndpoint) {\n      Util.getJSON(ajaxEndpoint, function(error, response, body) {\n        if (error) {\n          throw ['ajaxSource AJAX Error', error];\n        } else {\n          ajaxCallback(self, response);\n          return true;\n        }\n      });\n    }\n  }\n  return false;\n}\n\nfunction ajaxCallback(self, response) {\n  self.ajaxData = response;\n\n  /**\n   * You can attach a callback function to a feature in your app\n   * that will get called whenever new ajaxData comes in. This\n   * can be used to update UI that looks at data from within a feature.\n   *\n   * setStyle may possibly have a style with a different ajaxData source,\n   * and you would potentially get new contextual data for your feature.\n   *\n   * TODO: This needs to be documented.\n   */\n  if (typeof self.ajaxDataReceived === 'function') {\n    self.ajaxDataReceived(self, response);\n  }\n\n  self._setStyle(self.mvtLayer.style);\n  redrawTiles(self);\n}\n\nMVTFeature.prototype._setStyle = function(styleFn) {\n  this.style = styleFn(this, this.ajaxData);\n\n  // The label gets removed, and the (re)draw,\n  // that is initiated by the MVTLayer creates a new label.\n  this.removeLabel();\n};\n\nMVTFeature.prototype.setStyle = function(styleFn) {\n  this.ajaxData = null;\n  this.style = styleFn(this, null);\n  var hasAjaxSource = ajax(this);\n  if (!hasAjaxSource) {\n    // The label gets removed, and the (re)draw,\n    // that is initiated by the MVTLayer creates a new label.\n    this.removeLabel();\n  }\n};\n\nMVTFeature.prototype.draw = function(canvasID) {\n  //Get the info from the tiles list\n  var tileInfo =  this.tiles[canvasID];\n\n  var vtf = tileInfo.vtf;\n  var ctx = tileInfo.ctx;\n\n  //Get the actual canvas from the parent layer's _tiles object.\n  var xy = canvasID.split(\":\").slice(1, 3).join(\":\");\n  ctx.canvas = this.mvtLayer._tiles[xy];\n\n//  This could be used to directly compute the style function from the layer on every draw.\n//  This is much less efficient...\n//  this.style = this.mvtLayer.style(this);\n\n  if (this.selected) {\n    var style = this.style.selected || this.style;\n  } else {\n    var style = this.style;\n  }\n\n  switch (vtf.type) {\n    case 1: //Point\n      this._drawPoint(ctx, vtf.coordinates, style);\n      if (!this.staticLabel && typeof this.style.staticLabel === 'function') {\n        if (this.style.ajaxSource && !this.ajaxData) {\n          break;\n        }\n        this._drawStaticLabel(ctx, vtf.coordinates, style);\n      }\n      break;\n\n    case 2: //LineString\n      this._drawLineString(ctx, vtf.coordinates, style);\n      break;\n\n    case 3: //Polygon\n      this._drawPolygon(ctx, vtf.coordinates, style);\n      break;\n\n    default:\n      throw new Error('Unmanaged type: ' + vtf.type);\n  }\n\n};\n\nMVTFeature.prototype.getPathsForTile = function(canvasID) {\n  //Get the info from the parts list\n  return this.tiles[canvasID].paths;\n};\n\nMVTFeature.prototype.addTileFeature = function(vtf, ctx) {\n  //Store the important items in the tiles list\n\n  //We only want to store info for tiles for the current map zoom.  If it is tile info for another zoom level, ignore it\n  //Also, if there are existing tiles in the list for other zoom levels, expunge them.\n  var zoom = this.map.getZoom();\n\n  if(ctx.zoom != zoom) return;\n\n  this.clearTileFeatures(zoom); //TODO: This iterates thru all tiles every time a new tile is added.  Figure out a better way to do this.\n\n  this.tiles[ctx.id] = {\n    ctx: ctx,\n    vtf: vtf,\n    paths: []\n  };\n\n};\n\n\n/**\n * Clear the inner list of tile features if they don't match the given zoom.\n *\n * @param zoom\n */\nMVTFeature.prototype.clearTileFeatures = function(zoom) {\n  //If stored tiles exist for other zoom levels, expunge them from the list.\n  for (var key in this.tiles) {\n     if(key.split(\":\")[0] != zoom) delete this.tiles[key];\n  }\n};\n\n/**\n * Redraws all of the tiles associated with a feature. Useful for\n * style change and toggling.\n *\n * @param self\n */\nfunction redrawTiles(self) {\n  //Redraw the whole tile, not just this vtf\n  var tiles = self.tiles;\n  var mvtLayer = self.mvtLayer;\n\n  for (var id in tiles) {\n    var tileZoom = parseInt(id.split(':')[0]);\n    var mapZoom = self.map.getZoom();\n    if (tileZoom === mapZoom) {\n      //Redraw the tile\n      mvtLayer.redrawTile(id);\n    }\n  }\n}\n\nMVTFeature.prototype.toggle = function() {\n  if (this.selected) {\n    this.deselect();\n  } else {\n    this.select();\n  }\n};\n\nMVTFeature.prototype.select = function() {\n  this.selected = true;\n  this.mvtSource.featureSelected(this);\n  redrawTiles(this);\n  var linkedFeature = this.linkedFeature();\n  if (linkedFeature && linkedFeature.staticLabel && !linkedFeature.staticLabel.selected) {\n    linkedFeature.staticLabel.select();\n  }\n};\n\nMVTFeature.prototype.deselect = function() {\n  this.selected = false;\n  this.mvtSource.featureDeselected(this);\n  redrawTiles(this);\n  var linkedFeature = this.linkedFeature();\n  if (linkedFeature && linkedFeature.staticLabel && linkedFeature.staticLabel.selected) {\n    linkedFeature.staticLabel.deselect();\n  }\n};\n\nMVTFeature.prototype.on = function(eventType, callback) {\n  this._eventHandlers[eventType] = callback;\n};\n\nMVTFeature.prototype._drawPoint = function(ctx, coordsArray, style) {\n  if (!style) return;\n  if (!ctx || !ctx.canvas) return;\n\n  var tile = this.tiles[ctx.id];\n\n  //Get radius\n  var radius = 1;\n  if (typeof style.radius === 'function') {\n    radius = style.radius(ctx.zoom); //Allows for scale dependent rednering\n  }\n  else{\n    radius = style.radius;\n  }\n\n  var p = this._tilePoint(coordsArray[0][0]);\n  var c = ctx.canvas;\n  var ctx2d;\n  try{\n    ctx2d = c.getContext('2d');\n  }\n  catch(e){\n    console.log(\"_drawPoint error: \" + e);\n    return;\n  }\n\n  ctx2d.beginPath();\n  ctx2d.fillStyle = style.color;\n  ctx2d.arc(p.x, p.y, radius, 0, Math.PI * 2);\n  ctx2d.closePath();\n  ctx2d.fill();\n\n  if(style.lineWidth && style.strokeStyle){\n    ctx2d.lineWidth = style.lineWidth;\n    ctx2d.strokeStyle = style.strokeStyle;\n    ctx2d.stroke();\n  }\n\n  ctx2d.restore();\n  tile.paths.push([p]);\n};\n\nMVTFeature.prototype._drawLineString = function(ctx, coordsArray, style) {\n  if (!style) return;\n  if (!ctx || !ctx.canvas) return;\n\n  var ctx2d = ctx.canvas.getContext('2d');\n  ctx2d.strokeStyle = style.color;\n  ctx2d.lineWidth = style.size;\n  ctx2d.beginPath();\n\n  var projCoords = [];\n  var tile = this.tiles[ctx.id];\n\n  for (var gidx in coordsArray) {\n    var coords = coordsArray[gidx];\n\n    for (i = 0; i < coords.length; i++) {\n      var method = (i === 0 ? 'move' : 'line') + 'To';\n      var proj = this._tilePoint(coords[i]);\n      projCoords.push(proj);\n      ctx2d[method](proj.x, proj.y);\n    }\n  }\n\n  ctx2d.stroke();\n  ctx2d.restore();\n\n  tile.paths.push(projCoords);\n};\n\nMVTFeature.prototype._drawPolygon = function(ctx, coordsArray, style) {\n  if (!style) return;\n  if (!ctx || !ctx.canvas) return;\n\n  var ctx2d = ctx.canvas.getContext('2d');\n  var outline = style.outline;\n\n  // color may be defined via function to make choropleth work right\n  if (typeof style.color === 'function') {\n    ctx2d.fillStyle = style.color(ctx2d);\n  } else {\n    ctx2d.fillStyle = style.color;\n  }\n\n  if (outline) {\n    ctx2d.strokeStyle = outline.color;\n    ctx2d.lineWidth = outline.size;\n  }\n  ctx2d.beginPath();\n\n  var projCoords = [];\n  var tile = this.tiles[ctx.id];\n\n  var featureLabel = this.dynamicLabel;\n  if (featureLabel) {\n    featureLabel.addTilePolys(ctx, coordsArray);\n  }\n\n  for (var gidx = 0, len = coordsArray.length; gidx < len; gidx++) {\n    var coords = coordsArray[gidx];\n\n    for (var i = 0; i < coords.length; i++) {\n      var coord = coords[i];\n      var method = (i === 0 ? 'move' : 'line') + 'To';\n      var proj = this._tilePoint(coords[i]);\n      projCoords.push(proj);\n      ctx2d[method](proj.x, proj.y);\n    }\n  }\n\n  ctx2d.closePath();\n  ctx2d.fill();\n  if (outline) {\n    ctx2d.stroke();\n  }\n\n  tile.paths.push(projCoords);\n\n};\n\nMVTFeature.prototype._drawStaticLabel = function(ctx, coordsArray, style) {\n  if (!style) return;\n  if (!ctx) return;\n\n  // If the corresponding layer is not on the map, \n  // we dont want to put on a label.\n  if (!this.mvtLayer._map) return;\n\n  var vecPt = this._tilePoint(coordsArray[0][0]);\n\n  // We're making a standard Leaflet Marker for this label.\n  var p = this._project(vecPt, ctx.tile.x, ctx.tile.y, this.extent, this.tileSize); //vectile pt to merc pt\n  var mercPt = L.point(p.x, p.y); // make into leaflet obj\n  var latLng = this.map.unproject(mercPt); // merc pt to latlng\n\n  this.staticLabel = new StaticLabel(this, ctx, latLng, style);\n  this.mvtLayer.featureWithLabelAdded(this);\n};\n\nMVTFeature.prototype.removeLabel = function() {\n  if (!this.staticLabel) return;\n  this.staticLabel.remove();\n  this.staticLabel = null;\n};\n\n/**\n * Projects a vector tile point to the Spherical Mercator pixel space for a given zoom level.\n *\n * @param vecPt\n * @param tileX\n * @param tileY\n * @param extent\n * @param tileSize\n */\nMVTFeature.prototype._project = function(vecPt, tileX, tileY, extent, tileSize) {\n  var xOffset = tileX * tileSize;\n  var yOffset = tileY * tileSize;\n  return {\n    x: Math.floor(vecPt.x + xOffset),\n    y: Math.floor(vecPt.y + yOffset)\n  };\n};\n\n/**\n * Takes a coordinate from a vector tile and turns it into a Leaflet Point.\n *\n * @param ctx\n * @param coords\n * @returns {eGeomType.Point}\n * @private\n */\nMVTFeature.prototype._tilePoint = function(coords) {\n  return new L.Point(coords.x / this.divisor, coords.y / this.divisor);\n};\n\nMVTFeature.prototype.linkedFeature = function() {\n  var linkedLayer = this.mvtLayer.linkedLayer();\n  if(linkedLayer){\n    var linkedFeature = linkedLayer.features[this.id];\n    return linkedFeature;\n  }else{\n    return null;\n  }\n};\n\n","/**\n * Created by Ryan Whitley on 5/17/14.\n */\n/** Forked from https://gist.github.com/DGuidi/1716010 **/\nvar MVTFeature = require('./MVTFeature');\nvar Util = require('./MVTUtil');\n\nmodule.exports = L.TileLayer.Canvas.extend({\n\n  options: {\n    debug: false,\n    isHiddenLayer: false,\n    getIDForLayerFeature: function() {},\n    tileSize: 256,\n    lineClickTolerance: 2\n  },\n\n  _featureIsClicked: {},\n\n  _isPointInPoly: function(pt, poly) {\n    if(poly && poly.length) {\n      for (var c = false, i = -1, l = poly.length, j = l - 1; ++i < l; j = i)\n        ((poly[i].y <= pt.y && pt.y < poly[j].y) || (poly[j].y <= pt.y && pt.y < poly[i].y))\n        && (pt.x < (poly[j].x - poly[i].x) * (pt.y - poly[i].y) / (poly[j].y - poly[i].y) + poly[i].x)\n        && (c = !c);\n      return c;\n    }\n  },\n\n  _getDistanceFromLine: function(pt, pts) {\n    var min = Number.POSITIVE_INFINITY;\n    if (pts && pts.length > 1) {\n      pt = L.point(pt.x, pt.y);\n      for (var i = 0, l = pts.length - 1; i < l; i++) {\n        var test = this._projectPointOnLineSegment(pt, pts[i], pts[i + 1]);\n        if (test.distance <= min) {\n          min = test.distance;\n        }\n      }\n    }\n    return min;\n  },\n\n  _projectPointOnLineSegment: function(p, r0, r1) {\n    var lineLength = r0.distanceTo(r1);\n    if (lineLength < 1) {\n        return {distance: p.distanceTo(r0), coordinate: r0};\n    }\n    var u = ((p.x - r0.x) * (r1.x - r0.x) + (p.y - r0.y) * (r1.y - r0.y)) / Math.pow(lineLength, 2);\n    if (u < 0.0000001) {\n        return {distance: p.distanceTo(r0), coordinate: r0};\n    }\n    if (u > 0.9999999) {\n        return {distance: p.distanceTo(r1), coordinate: r1};\n    }\n    var a = L.point(r0.x + u * (r1.x - r0.x), r0.y + u * (r1.y - r0.y));\n    return {distance: p.distanceTo(a), point: a};\n  },\n\n  initialize: function(mvtSource, options) {\n    var self = this;\n    self.mvtSource = mvtSource;\n    L.Util.setOptions(this, options);\n\n    this.style = options.style;\n    this.name = options.name;\n    this._canvasIDToFeatures = {};\n    this.features = {};\n    this.featuresWithLabels = [];\n    this._highestCount = 0;\n  },\n\n  onAdd: function(map) {\n    var self = this;\n    self.map = map;\n    L.TileLayer.Canvas.prototype.onAdd.call(this, map);\n    map.on('layerremove', function(e) {\n      // we only want to do stuff when the layerremove event is on this layer\n      if (e.layer._leaflet_id === self._leaflet_id) {\n        removeLabels(self);\n      }\n    });\n  },\n\n  drawTile: function(canvas, tilePoint, zoom) {\n\n    var ctx = {\n      canvas: canvas,\n      tile: tilePoint,\n      zoom: zoom,\n      tileSize: this.options.tileSize\n    };\n\n    ctx.id = Util.getContextID(ctx);\n\n    if (!this._canvasIDToFeatures[ctx.id]) {\n      this._initializeFeaturesHash(ctx);\n    }\n    if (!this.features) {\n      this.features = {};\n    }\n\n  },\n\n  _initializeFeaturesHash: function(ctx){\n    this._canvasIDToFeatures[ctx.id] = {};\n    this._canvasIDToFeatures[ctx.id].features = [];\n    this._canvasIDToFeatures[ctx.id].canvas = ctx.canvas;\n  },\n\n  _draw: function(ctx) {\n    //Draw is handled by the parent MVTSource object\n  },\n  getCanvas: function(parentCtx){\n    //This gets called if a vector tile feature has already been parsed.\n    //We've already got the geom, just get on with the drawing.\n    //Need a way to pluck a canvas element from this layer given the parent layer's id.\n    //Wait for it to get loaded before proceeding.\n    var tilePoint = parentCtx.tile;\n    var ctx = this._tiles[tilePoint.x + \":\" + tilePoint.y];\n\n    if(ctx){\n      parentCtx.canvas = ctx;\n      this.redrawTile(parentCtx.id);\n      return;\n    }\n\n    var self = this;\n\n    //This is a timer that will wait for a criterion to return true.\n    //If not true within the timeout duration, it will move on.\n    waitFor(function () {\n        ctx = self._tiles[tilePoint.x + \":\" + tilePoint.y];\n        if(ctx) {\n          return true;\n        }\n      },\n      function(){\n        //When it finishes, do this.\n        ctx = self._tiles[tilePoint.x + \":\" + tilePoint.y];\n        parentCtx.canvas = ctx;\n        self.redrawTile(parentCtx.id);\n\n      }, //when done, go to next flow\n      2000); //The Timeout milliseconds.  After this, give up and move on\n\n  },\n\n  parseVectorTileLayer: function(vtl, ctx) {\n    var self = this;\n    var tilePoint = ctx.tile;\n    var layerCtx  = { canvas: null, id: ctx.id, tile: ctx.tile, zoom: ctx.zoom, tileSize: ctx.tileSize};\n\n    //See if we can pluck the child tile from this PBF tile layer based on the master layer's tile id.\n    layerCtx.canvas = self._tiles[tilePoint.x + \":\" + tilePoint.y];\n\n\n\n    //Initialize this tile's feature storage hash, if it hasn't already been created.  Used for when filters are updated, and features are cleared to prepare for a fresh redraw.\n    if (!this._canvasIDToFeatures[layerCtx.id]) {\n      this._initializeFeaturesHash(layerCtx);\n    }else{\n      //Clear this tile's previously saved features.\n      this.clearTileFeatureHash(layerCtx.id);\n    }\n\n    var features = vtl.parsedFeatures;\n    for (var i = 0, len = features.length; i < len; i++) {\n      var vtf = features[i]; //vector tile feature\n      vtf.layer = vtl;\n\n      /**\n       * Apply filter on feature if there is one. Defined in the options object\n       * of TileLayer.MVTSource.js\n       */\n      var filter = self.options.filter;\n      if (typeof filter === 'function') {\n        if ( filter(vtf, layerCtx) === false ) continue;\n      }\n\n      var getIDForLayerFeature;\n      if (typeof self.options.getIDForLayerFeature === 'function') {\n        getIDForLayerFeature = self.options.getIDForLayerFeature;\n      } else {\n        getIDForLayerFeature = Util.getIDForLayerFeature;\n      }\n      var uniqueID = self.options.getIDForLayerFeature(vtf) || i;\n      var mvtFeature = self.features[uniqueID];\n\n      /**\n       * Use layerOrdering function to apply a zIndex property to each vtf.  This is defined in\n       * TileLayer.MVTSource.js.  Used below to sort features.npm\n       */\n      var layerOrdering = self.options.layerOrdering;\n      if (typeof layerOrdering === 'function') {\n        layerOrdering(vtf, layerCtx); //Applies a custom property to the feature, which is used after we're thru iterating to sort\n      }\n\n      //Create a new MVTFeature if one doesn't already exist for this feature.\n      if (!mvtFeature) {\n        //Get a style for the feature - set it just once for each new MVTFeature\n        var style = self.style(vtf);\n\n        //create a new feature\n        self.features[uniqueID] = mvtFeature = new MVTFeature(self, vtf, layerCtx, uniqueID, style);\n        if (style && style.dynamicLabel && typeof style.dynamicLabel === 'function') {\n          self.featuresWithLabels.push(mvtFeature);\n        }\n      } else {\n        //Add the new part to the existing feature\n        mvtFeature.addTileFeature(vtf, layerCtx);\n      }\n\n      //Associate & Save this feature with this tile for later\n      if(layerCtx && layerCtx.id) self._canvasIDToFeatures[layerCtx.id]['features'].push(mvtFeature);\n\n    }\n\n    /**\n     * Apply sorting (zIndex) on feature if there is a function defined in the options object\n     * of TileLayer.MVTSource.js\n     */\n    var layerOrdering = self.options.layerOrdering;\n    if (layerOrdering) {\n      //We've assigned the custom zIndex property when iterating above.  Now just sort.\n      self._canvasIDToFeatures[layerCtx.id].features = self._canvasIDToFeatures[layerCtx.id].features.sort(function(a, b) {\n        return -(b.properties.zIndex - a.properties.zIndex)\n      });\n    }\n\n    self.redrawTile(layerCtx.id);\n  },\n\n  setStyle: function(styleFn) {\n    // refresh the number for the highest count value\n    // this is used only for choropleth\n    this._highestCount = 0;\n\n    // lowest count should not be 0, since we want to figure out the lowest\n    this._lowestCount = null;\n\n    this.style = styleFn;\n    for (var key in this.features) {\n      var feat = this.features[key];\n      feat.setStyle(styleFn);\n    }\n    var z = this.map.getZoom();\n    for (var key in this._tiles) {\n      var id = z + ':' + key;\n      this.redrawTile(id);\n    }\n  },\n\n  /**\n   * As counts for choropleths come in with the ajax data,\n   * we want to keep track of which value is the highest\n   * to create the color ramp for the fills of polygons.\n   * @param count\n   */\n  setHighestCount: function(count) {\n    if (count > this._highestCount) {\n      this._highestCount = count;\n    }\n  },\n\n  /**\n   * Returns the highest number of all of the counts that have come in\n   * from setHighestCount. This is assumed to be set via ajax callbacks.\n   * @returns {number}\n   */\n  getHighestCount: function() {\n    return this._highestCount;\n  },\n\n  setLowestCount: function(count) {\n    if (!this._lowestCount || count < this._lowestCount) {\n      this._lowestCount = count;\n    }\n  },\n\n  getLowestCount: function() {\n    return this._lowestCount;\n  },\n\n  setCountRange: function(count) {\n    this.setHighestCount(count);\n    this.setLowestCount(count);\n  },\n\n  //This is the old way.  It works, but is slow for mouseover events.  Fine for click events.\n  handleClickEvent: function(evt, cb) {\n    //Click happened on the GroupLayer (Manager) and passed it here\n    var tileID = evt.tileID.split(\":\").slice(1, 3).join(\":\");\n    var zoom = evt.tileID.split(\":\")[0];\n    var canvas = this._tiles[tileID];\n    if(!canvas) (cb(evt)); //break out\n    var x = evt.layerPoint.x - canvas._leaflet_pos.x;\n    var y = evt.layerPoint.y - canvas._leaflet_pos.y;\n\n    var tilePoint = {x: x, y: y};\n    var features = this._canvasIDToFeatures[evt.tileID].features;\n\n    var minDistance = Number.POSITIVE_INFINITY;\n    var nearest = null;\n    var j, paths, distance;\n\n    for (var i = 0; i < features.length; i++) {\n      var feature = features[i];\n      switch (feature.type) {\n\n        case 1: //Point - currently rendered as circular paths.  Intersect with that.\n\n          //Find the radius of the point.\n          var radius = 3;\n          if (typeof feature.style.radius === 'function') {\n            radius = feature.style.radius(zoom); //Allows for scale dependent rednering\n          }\n          else{\n            radius = feature.style.radius;\n          }\n\n          paths = feature.getPathsForTile(evt.tileID);\n          for (j = 0; j < paths.length; j++) {\n            //Builds a circle of radius feature.style.radius (assuming circular point symbology).\n            if(in_circle(paths[j][0].x, paths[j][0].y, radius, x, y)){\n              nearest = feature;\n              minDistance = 0;\n            }\n          }\n          break;\n\n        case 2: //LineString\n          paths = feature.getPathsForTile(evt.tileID);\n          for (j = 0; j < paths.length; j++) {\n            if (feature.style) {\n              var distance = this._getDistanceFromLine(tilePoint, paths[j]);\n              var thickness = (feature.selected && feature.style.selected ? feature.style.selected.size : feature.style.size);\n              if (distance < thickness / 2 + this.options.lineClickTolerance && distance < minDistance) {\n                nearest = feature;\n                minDistance = distance;\n              }\n            }\n          }\n          break;\n\n        case 3: //Polygon\n          paths = feature.getPathsForTile(evt.tileID);\n          for (j = 0; j < paths.length; j++) {\n            if (this._isPointInPoly(tilePoint, paths[j])) {\n              nearest = feature;\n              minDistance = 0; // point is inside the polygon, so distance is zero\n            }\n          }\n          break;\n      }\n      if (minDistance == 0) break;\n    }\n\n    if (nearest && nearest.toggleEnabled) {\n        nearest.toggle();\n    }\n    evt.feature = nearest;\n    cb(evt);\n  },\n\n  clearTile: function(id) {\n    //id is the entire zoom:x:y.  we just want x:y.\n    var ca = id.split(\":\");\n    var canvasId = ca[1] + \":\" + ca[2];\n    if (typeof this._tiles[canvasId] === 'undefined') {\n      console.error(\"typeof this._tiles[canvasId] === 'undefined'\");\n      return;\n    }\n    var canvas = this._tiles[canvasId];\n\n    var context = canvas.getContext('2d');\n    context.clearRect(0, 0, canvas.width, canvas.height);\n  },\n\n  clearTileFeatureHash: function(canvasID){\n    this._canvasIDToFeatures[canvasID] = { features: []}; //Get rid of all saved features\n  },\n\n  clearLayerFeatureHash: function(){\n    this.features = {};\n  },\n\n  redrawTile: function(canvasID) {\n    //First, clear the canvas\n    this.clearTile(canvasID);\n\n    // If the features are not in the tile, then there is nothing to redraw.\n    // This may happen if you call redraw before features have loaded and initially\n    // drawn the tile.\n    var featfeats = this._canvasIDToFeatures[canvasID];\n    if (!featfeats) {\n      return;\n    }\n\n    //Get the features for this tile, and redraw them.\n    var features = featfeats.features;\n\n    // we want to skip drawing the selected features and draw them last\n    var selectedFeatures = [];\n\n    // drawing all of the non-selected features\n    for (var i = 0; i < features.length; i++) {\n      var feature = features[i];\n      if (feature.selected) {\n        selectedFeatures.push(feature);\n      } else {\n        feature.draw(canvasID);\n      }\n    }\n\n    // drawing the selected features last\n    for (var j = 0, len2 = selectedFeatures.length; j < len2; j++) {\n      var selFeat = selectedFeatures[j];\n      selFeat.draw(canvasID);\n    }\n  },\n\n  _resetCanvasIDToFeatures: function(canvasID, canvas) {\n\n    this._canvasIDToFeatures[canvasID] = {};\n    this._canvasIDToFeatures[canvasID].features = [];\n    this._canvasIDToFeatures[canvasID].canvas = canvas;\n\n  },\n\n  linkedLayer: function() {\n    if(this.mvtSource.layerLink) {\n      var linkName = this.mvtSource.layerLink(this.name);\n      return this.mvtSource.layers[linkName];\n    }\n    else{\n      return null;\n    }\n  },\n\n  featureWithLabelAdded: function(feature) {\n    this.featuresWithLabels.push(feature);\n  }\n\n});\n\n\nfunction removeLabels(self) {\n  var features = self.featuresWithLabels;\n  for (var i = 0, len = features.length; i < len; i++) {\n    var feat = features[i];\n    feat.removeLabel();\n  }\n  self.featuresWithLabels = [];\n}\n\nfunction in_circle(center_x, center_y, radius, x, y) {\n  var square_dist = Math.pow((center_x - x), 2) + Math.pow((center_y - y), 2);\n  return square_dist <= Math.pow(radius, 2);\n}\n/**\n * See https://github.com/ariya/phantomjs/blob/master/examples/waitfor.js\n *\n * Wait until the test condition is true or a timeout occurs. Useful for waiting\n * on a server response or for a ui change (fadeIn, etc.) to occur.\n *\n * @param testFx javascript condition that evaluates to a boolean,\n * it can be passed in as a string (e.g.: \"1 == 1\" or \"$('#bar').is(':visible')\" or\n * as a callback function.\n * @param onReady what to do when testFx condition is fulfilled,\n * it can be passed in as a string (e.g.: \"1 == 1\" or \"$('#bar').is(':visible')\" or\n * as a callback function.\n * @param timeOutMillis the max amount of time to wait. If not specified, 3 sec is used.\n */\nfunction waitFor(testFx, onReady, timeOutMillis) {\n  var maxtimeOutMillis = timeOutMillis ? timeOutMillis : 3000, //< Default Max Timout is 3s\n    start = new Date().getTime(),\n    condition = (typeof (testFx) === \"string\" ? eval(testFx) : testFx()), //< defensive code\n    interval = setInterval(function () {\n      if ((new Date().getTime() - start < maxtimeOutMillis) && !condition) {\n        // If not time-out yet and condition not yet fulfilled\n        condition = (typeof (testFx) === \"string\" ? eval(testFx) : testFx()); //< defensive code\n      } else {\n        if (!condition) {\n          // If condition still not fulfilled (timeout but condition is 'false')\n          console.log(\"'waitFor()' timeout\");\n          clearInterval(interval); //< Stop this interval\n          typeof (onReady) === \"string\" ? eval(onReady) : onReady('timeout'); //< Do what it's supposed to do once the condition is fulfilled\n        } else {\n          // Condition fulfilled (timeout and/or condition is 'true')\n          console.log(\"'waitFor()' finished in \" + (new Date().getTime() - start) + \"ms.\");\n          clearInterval(interval); //< Stop this interval\n          typeof (onReady) === \"string\" ? eval(onReady) : onReady('success'); //< Do what it's supposed to do once the condition is fulfilled\n        }\n      }\n    }, 50); //< repeat check every 50ms\n};","var VectorTile = require('vector-tile').VectorTile;\nvar Protobuf = require('pbf');\nvar Point = require('point-geometry');\nvar Util = require('./MVTUtil');\nvar MVTLayer = require('./MVTLayer');\n\n\nmodule.exports = L.TileLayer.MVTSource = L.TileLayer.Canvas.extend({\n\n  options: {\n    debug: false,\n    url: \"\", //URL TO Vector Tile Source,\n    getIDForLayerFeature: function() {},\n    tileSize: 256,\n    visibleLayers: [],\n    xhrHeaders: {}\n  },\n  layers: {}, //Keep a list of the layers contained in the PBFs\n  processedTiles: {}, //Keep a list of tiles that have been processed already\n  _eventHandlers: {},\n  _triggerOnTilesLoadedEvent: true, //whether or not to fire the onTilesLoaded event when all of the tiles finish loading.\n  _url: \"\", //internal URL property\n\n  style: function(feature) {\n    var style = {};\n\n    var type = feature.type;\n    switch (type) {\n      case 1: //'Point'\n        style.color = 'rgba(49,79,79,1)';\n        style.radius = 5;\n        style.selected = {\n          color: 'rgba(255,255,0,0.5)',\n          radius: 6\n        };\n        break;\n      case 2: //'LineString'\n        style.color = 'rgba(161,217,155,0.8)';\n        style.size = 3;\n        style.selected = {\n          color: 'rgba(255,25,0,0.5)',\n          size: 4\n        };\n        break;\n      case 3: //'Polygon'\n        style.color = 'rgba(49,79,79,1)';\n        style.outline = {\n          color: 'rgba(161,217,155,0.8)',\n          size: 1\n        };\n        style.selected = {\n          color: 'rgba(255,140,0,0.3)',\n          outline: {\n            color: 'rgba(255,140,0,1)',\n            size: 2\n          }\n        };\n        break;\n    }\n    return style;\n  },\n\n\n  initialize: function(options) {\n    L.Util.setOptions(this, options);\n\n    //a list of the layers contained in the PBFs\n    this.layers = {};\n\n    // tiles currently in the viewport\n    this.activeTiles = {};\n\n    // thats that have been loaded and drawn\n    this.loadedTiles = {};\n\n    this._url = this.options.url;\n\n    /**\n     * For some reason, Leaflet has some code that resets the\n     * z index in the options object. I'm having trouble tracking\n     * down exactly what does this and why, so for now, we should\n     * just copy the value to this.zIndex so we can have the right\n     * number when we make the subsequent MVTLayers.\n     */\n    this.zIndex = options.zIndex;\n\n    if (typeof options.style === 'function') {\n      this.style = options.style;\n    }\n\n    if (typeof options.ajaxSource === 'function') {\n      this.ajaxSource = options.ajaxSource;\n    }\n\n    this.layerLink = options.layerLink;\n\n    this._eventHandlers = {};\n\n    this._tilesToProcess = 0; //store the max number of tiles to be loaded.  Later, we can use this count to count down PBF loading.\n  },\n\n  redraw: function(triggerOnTilesLoadedEvent){\n    //Only set to false if it actually is passed in as 'false'\n    if (triggerOnTilesLoadedEvent === false) {\n      this._triggerOnTilesLoadedEvent = false;\n    }\n\n    L.TileLayer.Canvas.prototype.redraw.call(this);\n  },\n\n  onAdd: function(map) {\n    var self = this;\n    self.map = map;\n    L.TileLayer.Canvas.prototype.onAdd.call(this, map);\n\n    var mapOnClickCallback = function(e) {\n      self._onClick(e);\n    };\n\n    map.on('click', mapOnClickCallback);\n\n    map.on(\"layerremove\", function(e) {\n      // check to see if the layer removed is this one\n      // call a method to remove the child layers (the ones that actually have something drawn on them).\n      if (e.layer._leaflet_id === self._leaflet_id && e.layer.removeChildLayers) {\n        e.layer.removeChildLayers(map);\n        map.off('click', mapOnClickCallback);\n      }\n    });\n\n    self.addChildLayers(map);\n\n    if (typeof DynamicLabel === 'function' ) {\n      this.dynamicLabel = new DynamicLabel(map, this, {});\n    }\n\n  },\n\n  drawTile: function(canvas, tilePoint, zoom) {\n    var ctx = {\n      id: [zoom, tilePoint.x, tilePoint.y].join(\":\"),\n      canvas: canvas,\n      tile: tilePoint,\n      zoom: zoom,\n      tileSize: this.options.tileSize\n    };\n\n    //Capture the max number of the tiles to load here. this._tilesToProcess is an internal number we use to know when we've finished requesting PBFs.\n    if(this._tilesToProcess < this._tilesToLoad) this._tilesToProcess = this._tilesToLoad;\n\n    var id = ctx.id = Util.getContextID(ctx);\n    this.activeTiles[id] = ctx;\n\n    if(!this.processedTiles[ctx.zoom]) this.processedTiles[ctx.zoom] = {};\n\n    if (this.options.debug) {\n      this._drawDebugInfo(ctx);\n    }\n    this._draw(ctx);\n  },\n\n  setOpacity:function(opacity) {\n    this._setVisibleLayersStyle('opacity',opacity);\n  },\n\n  setZIndex:function(zIndex) {\n    this._setVisibleLayersStyle('zIndex',zIndex);\n  },\n\n  _setVisibleLayersStyle:function(style, value) {\n    for(var key in this.layers) {\n      this.layers[key]._tileContainer.style[style] = value;\n    }\n  },\n\n  _drawDebugInfo: function(ctx) {\n    var max = this.options.tileSize;\n    var g = ctx.canvas.getContext('2d');\n    g.strokeStyle = '#000000';\n    g.fillStyle = '#FFFF00';\n    g.strokeRect(0, 0, max, max);\n    g.font = \"12px Arial\";\n    g.fillRect(0, 0, 5, 5);\n    g.fillRect(0, max - 5, 5, 5);\n    g.fillRect(max - 5, 0, 5, 5);\n    g.fillRect(max - 5, max - 5, 5, 5);\n    g.fillRect(max / 2 - 5, max / 2 - 5, 10, 10);\n    g.strokeText(ctx.zoom + ' ' + ctx.tile.x + ' ' + ctx.tile.y, max / 2 - 30, max / 2 - 10);\n  },\n\n  _draw: function(ctx) {\n    var self = this;\n\n//    //This works to skip fetching and processing tiles if they've already been processed.\n//    var vectorTile = this.processedTiles[ctx.zoom][ctx.id];\n//    //if we've already parsed it, don't get it again.\n//    if(vectorTile){\n//      console.log(\"Skipping fetching \" + ctx.id);\n//      self.checkVectorTileLayers(parseVT(vectorTile), ctx, true);\n//      self.reduceTilesToProcessCount();\n//      return;\n//    }\n\n    if (!this._url) return;\n    var src = this.getTileUrl({ x: ctx.tile.x, y: ctx.tile.y, z: ctx.zoom });\n\n    var xhr = new XMLHttpRequest();\n    xhr.onload = function() {\n      if (xhr.status == \"200\") {\n\n        if(!xhr.response) return;\n\n        var arrayBuffer = new Uint8Array(xhr.response);\n        var buf = new Protobuf(arrayBuffer);\n        var vt = new VectorTile(buf);\n        //Check the current map layer zoom.  If fast zooming is occurring, then short circuit tiles that are for a different zoom level than we're currently on.\n        if(self.map && self.map.getZoom() != ctx.zoom) {\n          console.log(\"Fetched tile for zoom level \" + ctx.zoom + \". Map is at zoom level \" + self._map.getZoom());\n          return;\n        }\n        self.checkVectorTileLayers(parseVT(vt), ctx);\n        tileLoaded(self, ctx);\n      }\n\n      //either way, reduce the count of tilesToProcess tiles here\n      self.reduceTilesToProcessCount();\n    };\n\n    xhr.onerror = function() {\n      console.log(\"xhr error: \" + xhr.status)\n    };\n\n    xhr.open('GET', src, true); //async is true\n    var headers = self.options.xhrHeaders;\n    for (var header in headers) {\n      xhr.setRequestHeader(header, headers[header])\n    }\n    xhr.responseType = 'arraybuffer';\n    xhr.send();\n  },\n\n  reduceTilesToProcessCount: function(){\n    this._tilesToProcess--;\n    if(!this._tilesToProcess){\n      //Trigger event letting us know that all PBFs have been loaded and processed (or 404'd).\n      if(this._eventHandlers[\"PBFLoad\"]) this._eventHandlers[\"PBFLoad\"]();\n      this._pbfLoaded();\n    }\n  },\n\n  checkVectorTileLayers: function(vt, ctx, parsed) {\n    var self = this;\n\n    //Check if there are specified visible layers\n    if(self.options.visibleLayers && self.options.visibleLayers.length > 0){\n      //only let thru the layers listed in the visibleLayers array\n      for(var i=0; i < self.options.visibleLayers.length; i++){\n        var layerName = self.options.visibleLayers[i];\n        if(vt.layers[layerName]){\n           //Proceed with parsing\n          self.prepareMVTLayers(vt.layers[layerName], layerName, ctx, parsed);\n        }\n      }\n    }else{\n      //Parse all vt.layers\n      for (var key in vt.layers) {\n        self.prepareMVTLayers(vt.layers[key], key, ctx, parsed);\n      }\n    }\n  },\n\n  prepareMVTLayers: function(lyr ,key, ctx, parsed) {\n    var self = this;\n\n    if (!self.layers[key]) {\n      //Create MVTLayer or MVTPointLayer for user\n      self.layers[key] = self.createMVTLayer(key, lyr.parsedFeatures[0].type || null);\n    }\n\n    if (parsed) {\n      //We've already parsed it.  Go get canvas and draw.\n      self.layers[key].getCanvas(ctx, lyr);\n    } else {\n      self.layers[key].parseVectorTileLayer(lyr, ctx);\n    }\n\n  },\n\n  createMVTLayer: function(key, type) {\n    var self = this;\n\n    var getIDForLayerFeature;\n    if (typeof self.options.getIDForLayerFeature === 'function') {\n      getIDForLayerFeature = self.options.getIDForLayerFeature;\n    } else {\n      getIDForLayerFeature = Util.getIDForLayerFeature;\n    }\n\n    var options = {\n      getIDForLayerFeature: getIDForLayerFeature,\n      filter: self.options.filter,\n      layerOrdering: self.options.layerOrdering,\n      style: self.style,\n      name: key,\n      asynch: true\n    };\n\n    if (self.options.zIndex) {\n      options.zIndex = self.zIndex;\n    }\n\n    //Take the layer and create a new MVTLayer or MVTPointLayer if one doesn't exist.\n    var layer = new MVTLayer(self, options).addTo(self.map);\n\n    return layer;\n  },\n\n  getLayers: function() {\n    return this.layers;\n  },\n\n  hideLayer: function(id) {\n    if (this.layers[id]) {\n      this._map.removeLayer(this.layers[id]);\n      if(this.options.visibleLayers.indexOf(\"id\") > -1){\n        this.visibleLayers.splice(this.options.visibleLayers.indexOf(\"id\"), 1);\n      }\n    }\n  },\n\n  showLayer: function(id) {\n    if (this.layers[id]) {\n      this._map.addLayer(this.layers[id]);\n      if(this.options.visibleLayers.indexOf(\"id\") == -1){\n        this.visibleLayers.push(id);\n      }\n    }\n    //Make sure manager layer is always in front\n    this.bringToFront();\n  },\n\n  removeChildLayers: function(map){\n    //Remove child layers of this group layer\n    for (var key in this.layers) {\n      var layer = this.layers[key];\n      map.removeLayer(layer);\n    }\n  },\n\n  addChildLayers: function(map) {\n    var self = this;\n    if(self.options.visibleLayers.length > 0){\n      //only let thru the layers listed in the visibleLayers array\n      for(var i=0; i < self.options.visibleLayers.length; i++){\n        var layerName = self.options.visibleLayers[i];\n        var layer = this.layers[layerName];\n        if(layer){\n          //Proceed with parsing\n          map.addLayer(layer);\n        }\n      }\n    }else{\n      //Add all layers\n      for (var key in this.layers) {\n        var layer = this.layers[key];\n        // layer is set to visible and is not already on map\n        if (!layer._map) {\n          map.addLayer(layer);\n        }\n      }\n    }\n  },\n\n  bind: function(eventType, callback) {\n    this._eventHandlers[eventType] = callback;\n  },\n\n  _onClick: function(evt) {\n    //Here, pass the event on to the child MVTLayer and have it do the hit test and handle the result.\n    var self = this;\n    var onClick = self.options.onClick;\n    var clickableLayers = self.options.clickableLayers;\n    var layers = self.layers;\n\n    evt.tileID =  getTileURL(evt.latlng.lat, evt.latlng.lng, this.map.getZoom());\n\n    // We must have an array of clickable layers, otherwise, we just pass\n    // the event to the public onClick callback in options.\n\n    if(!clickableLayers){\n      clickableLayers = Object.keys(self.layers);\n    }\n\n    if (clickableLayers && clickableLayers.length > 0) {\n      for (var i = 0, len = clickableLayers.length; i < len; i++) {\n        var key = clickableLayers[i];\n        var layer = layers[key];\n        if (layer) {\n          layer.handleClickEvent(evt, function(evt) {\n            if (typeof onClick === 'function') {\n              onClick(evt);\n            }\n          });\n        }\n      }\n    } else {\n      if (typeof onClick === 'function') {\n        onClick(evt);\n      }\n    }\n\n  },\n\n  setFilter: function(filterFunction, layerName) {\n    //take in a new filter function.\n    //Propagate to child layers.\n\n    //Add filter to all child layers if no layer is specified.\n    for (var key in this.layers) {\n      var layer = this.layers[key];\n\n      if (layerName){\n        if(key.toLowerCase() == layerName.toLowerCase()){\n          layer.options.filter = filterFunction; //Assign filter to child layer, only if name matches\n          //After filter is set, the old feature hashes are invalid.  Clear them for next draw.\n          layer.clearLayerFeatureHash();\n          //layer.clearTileFeatureHash();\n        }\n      }\n      else{\n        layer.options.filter = filterFunction; //Assign filter to child layer\n        //After filter is set, the old feature hashes are invalid.  Clear them for next draw.\n        layer.clearLayerFeatureHash();\n        //layer.clearTileFeatureHash();\n      }\n    }\n  },\n\n  /**\n   * Take in a new style function and propogate to child layers.\n   * If you do not set a layer name, it resets the style for all of the layers.\n   * @param styleFunction\n   * @param layerName\n   */\n  setStyle: function(styleFn, layerName) {\n    for (var key in this.layers) {\n      var layer = this.layers[key];\n      if (layerName) {\n        if(key.toLowerCase() == layerName.toLowerCase()) {\n          layer.setStyle(styleFn);\n        }\n      } else {\n        layer.setStyle(styleFn);\n      }\n    }\n  },\n\n  featureSelected: function(mvtFeature) {\n    if (this.options.mutexToggle) {\n      if (this._selectedFeature) {\n        this._selectedFeature.deselect();\n      }\n      this._selectedFeature = mvtFeature;\n    }\n    if (this.options.onSelect) {\n      this.options.onSelect(mvtFeature);\n    }\n  },\n\n  featureDeselected: function(mvtFeature) {\n    if (this.options.mutexToggle && this._selectedFeature) {\n      this._selectedFeature = null;\n    }\n    if (this.options.onDeselect) {\n      this.options.onDeselect(mvtFeature);\n    }\n  },\n\n  _pbfLoaded: function() {\n    //Fires when all tiles from this layer have been loaded and drawn (or 404'd).\n\n    //Make sure manager layer is always in front\n    this.bringToFront();\n\n    //See if there is an event to execute\n    var self = this;\n    var onTilesLoaded = self.options.onTilesLoaded;\n\n    if (onTilesLoaded && typeof onTilesLoaded === 'function' && this._triggerOnTilesLoadedEvent === true) {\n      onTilesLoaded(this);\n    }\n    self._triggerOnTilesLoadedEvent = true; //reset - if redraw() is called with the optinal 'false' parameter to temporarily disable the onTilesLoaded event from firing.  This resets it back to true after a single time of firing as 'false'.\n  }\n\n});\n\n\nif (typeof(Number.prototype.toRad) === \"undefined\") {\n  Number.prototype.toRad = function() {\n    return this * Math.PI / 180;\n  }\n}\n\nfunction getTileURL(lat, lon, zoom) {\n  var xtile = parseInt(Math.floor( (lon + 180) / 360 * (1<<zoom) ));\n  var ytile = parseInt(Math.floor( (1 - Math.log(Math.tan(lat.toRad()) + 1 / Math.cos(lat.toRad())) / Math.PI) / 2 * (1<<zoom) ));\n  return \"\" + zoom + \":\" + xtile + \":\" + ytile;\n}\n\nfunction tileLoaded(pbfSource, ctx) {\n  pbfSource.loadedTiles[ctx.id] = ctx;\n}\n\nfunction parseVT(vt){\n  for (var key in vt.layers) {\n    var lyr = vt.layers[key];\n    parseVTFeatures(lyr);\n  }\n  return vt;\n}\n\nfunction parseVTFeatures(vtl){\n  vtl.parsedFeatures = [];\n  var features = vtl._features;\n  for (var i = 0, len = features.length; i < len; i++) {\n    var vtf = vtl.feature(i);\n    vtf.coordinates = vtf.loadGeometry();\n    vtl.parsedFeatures.push(vtf);\n  }\n  return vtl;\n}\n","/**\n * Created by Nicholas Hallahan <nhallahan@spatialdev.com>\n *       on 8/15/14.\n */\nvar Util = module.exports = {};\n\nUtil.getContextID = function(ctx) {\n  return [ctx.zoom, ctx.tile.x, ctx.tile.y].join(\":\");\n};\n\n/**\n * Default function that gets the id for a layer feature.\n * Sometimes this needs to be done in a different way and\n * can be specified by the user in the options for L.TileLayer.MVTSource.\n *\n * @param feature\n * @returns {ctx.id|*|id|string|jsts.index.chain.MonotoneChain.id|number}\n */\nUtil.getIDForLayerFeature = function(feature) {\n  return feature.properties.id;\n};\n\nUtil.getJSON = function(url, callback) {\n  var xmlhttp = typeof XMLHttpRequest !== 'undefined' ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP');\n  xmlhttp.onreadystatechange = function() {\n    var status = xmlhttp.status;\n    if (xmlhttp.readyState === 4 && status >= 200 && status < 300) {\n      var json = JSON.parse(xmlhttp.responseText);\n      callback(null, json);\n    } else {\n      callback( { error: true, status: status } );\n    }\n  };\n  xmlhttp.open(\"GET\", url, true);\n  xmlhttp.send();\n};\n","/**\n * Created by Nicholas Hallahan <nhallahan@spatialdev.com>\n *       on 7/31/14.\n */\nvar Util = require('../MVTUtil');\nmodule.exports = StaticLabel;\n\nfunction StaticLabel(mvtFeature, ctx, latLng, style) {\n  var self = this;\n  this.mvtFeature = mvtFeature;\n  this.map = mvtFeature.map;\n  this.zoom = ctx.zoom;\n  this.latLng = latLng;\n  this.selected = false;\n\n  if (mvtFeature.linkedFeature) {\n    var linkedFeature = mvtFeature.linkedFeature();\n    if (linkedFeature && linkedFeature.selected) {\n      self.selected = true;\n    }\n  }\n\n  init(self, mvtFeature, ctx, latLng, style)\n}\n\nfunction init(self, mvtFeature, ctx, latLng, style) {\n  var ajaxData = mvtFeature.ajaxData;\n  var sty = self.style = style.staticLabel(mvtFeature, ajaxData);\n  var icon = self.icon = L.divIcon({\n    className: sty.cssClass || 'label-icon-text',\n    html: sty.html,\n    iconSize: sty.iconSize || [50,50]\n  });\n\n  self.marker = L.marker(latLng, {icon: icon}).addTo(self.map);\n\n  if (self.selected) {\n    self.marker._icon.classList.add(self.style.cssSelectedClass || 'label-icon-text-selected');\n  }\n\n  self.marker.on('click', function(e) {\n    self.toggle();\n  });\n\n  self.map.on('zoomend', function(e) {\n    var newZoom = e.target.getZoom();\n    if (self.zoom !== newZoom) {\n      self.map.removeLayer(self.marker);\n    }\n  });\n}\n\n\nStaticLabel.prototype.toggle = function() {\n  if (this.selected) {\n    this.deselect();\n  } else {\n    this.select();\n  }\n};\n\nStaticLabel.prototype.select = function() {\n  this.selected = true;\n  this.marker._icon.classList.add(this.style.cssSelectedClass || 'label-icon-text-selected');\n  var linkedFeature = this.mvtFeature.linkedFeature();\n  if (!linkedFeature.selected) linkedFeature.select();\n};\n\nStaticLabel.prototype.deselect = function() {\n  this.selected = false;\n  this.marker._icon.classList.remove(this.style.cssSelectedClass || 'label-icon-text-selected');\n  var linkedFeature = this.mvtFeature.linkedFeature();\n  if (linkedFeature.selected) linkedFeature.deselect();\n};\n\nStaticLabel.prototype.remove = function() {\n  if (!this.map || !this.marker) return;\n  this.map.removeLayer(this.marker);\n};\n","/**\n * Copyright (c) 2014, Spatial Development International\n * All rights reserved.\n *\n * Source code can be found at:\n * https://github.com/SpatialServer/Leaflet.MapboxVectorTile\n *\n * @license ISC\n */\n\nmodule.exports = require('./MVTSource');\n","/*!\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/* eslint-disable no-proto */\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('is-array')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192 // not used by this implementation\n\nvar rootParent = {}\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 * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property\n *     on objects.\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\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n  ? global.TYPED_ARRAY_SUPPORT\n  : typedArraySupport()\n\nfunction typedArraySupport () {\n  function Bar () {}\n  try {\n    var arr = new Uint8Array(1)\n    arr.foo = function () { return 42 }\n    arr.constructor = Bar\n    return arr.foo() === 42 && // typed array instances can be augmented\n        arr.constructor === Bar && // constructor can be set\n        typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n        arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  } catch (e) {\n    return false\n  }\n}\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\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 (arg) {\n  if (!(this instanceof Buffer)) {\n    // Avoid going through an ArgumentsAdaptorTrampoline in the common case.\n    if (arguments.length > 1) return new Buffer(arg, arguments[1])\n    return new Buffer(arg)\n  }\n\n  this.length = 0\n  this.parent = undefined\n\n  // Common case.\n  if (typeof arg === 'number') {\n    return fromNumber(this, arg)\n  }\n\n  // Slightly less common case.\n  if (typeof arg === 'string') {\n    return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8')\n  }\n\n  // Unusual.\n  return fromObject(this, arg)\n}\n\nfunction fromNumber (that, length) {\n  that = allocate(that, length < 0 ? 0 : checked(length) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < length; i++) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8'\n\n  // Assumption: byteLength() return value is always < kMaxLength.\n  var length = byteLength(string, encoding) | 0\n  that = allocate(that, length)\n\n  that.write(string, encoding)\n  return that\n}\n\nfunction fromObject (that, object) {\n  if (Buffer.isBuffer(object)) return fromBuffer(that, object)\n\n  if (isArray(object)) return fromArray(that, object)\n\n  if (object == null) {\n    throw new TypeError('must start with number, buffer, array or string')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined') {\n    if (object.buffer instanceof ArrayBuffer) {\n      return fromTypedArray(that, object)\n    }\n    if (object instanceof ArrayBuffer) {\n      return fromArrayBuffer(that, object)\n    }\n  }\n\n  if (object.length) return fromArrayLike(that, object)\n\n  return fromJsonObject(that, object)\n}\n\nfunction fromBuffer (that, buffer) {\n  var length = checked(buffer.length) | 0\n  that = allocate(that, length)\n  buffer.copy(that, 0, 0, length)\n  return that\n}\n\nfunction fromArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Duplicate of fromArray() to keep fromArray() monomorphic.\nfunction fromTypedArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  // Truncating the elements is probably not what people expect from typed\n  // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior\n  // of the old Buffer constructor.\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array) {\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    array.byteLength\n    that = Buffer._augment(new Uint8Array(array))\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromTypedArray(that, new Uint8Array(array))\n  }\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object.\n// Returns a zero-length buffer for inputs that don't conform to the spec.\nfunction fromJsonObject (that, object) {\n  var array\n  var length = 0\n\n  if (object.type === 'Buffer' && isArray(object.data)) {\n    array = object.data\n    length = checked(array.length) | 0\n  }\n  that = allocate(that, length)\n\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n  Buffer.prototype.__proto__ = Uint8Array.prototype\n  Buffer.__proto__ = Uint8Array\n}\n\nfunction allocate (that, length) {\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = Buffer._augment(new Uint8Array(length))\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that.length = length\n    that._isBuffer = true\n  }\n\n  var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1\n  if (fromPool) that.parent = rootParent\n\n  return that\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nfunction SlowBuffer (subject, encoding) {\n  if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding)\n\n  var buf = new Buffer(subject, encoding)\n  delete buf.parent\n  return buf\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  var i = 0\n  var len = Math.min(x, y)\n  while (i < len) {\n    if (a[i] !== b[i]) break\n\n    ++i\n  }\n\n  if (i !== len) {\n    x = a[i]\n    y = b[i]\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (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 concat (list, length) {\n  if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; i++) {\n      length += list[i].length\n    }\n  }\n\n  var buf = new Buffer(length)\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\nfunction byteLength (string, encoding) {\n  if (typeof string !== 'string') string = '' + string\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'binary':\n      // Deprecated\n      case 'raw':\n      case 'raws':\n        return len\n      case 'utf8':\n      case 'utf-8':\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\n// pre-set for values that may exist in the future\nBuffer.prototype.length = undefined\nBuffer.prototype.parent = undefined\n\nfunction slowToString (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) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\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) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return 0\n  return Buffer.compare(this, b)\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset) {\n  if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff\n  else if (byteOffset < -0x80000000) byteOffset = -0x80000000\n  byteOffset >>= 0\n\n  if (this.length === 0) return -1\n  if (byteOffset >= this.length) return -1\n\n  // Negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0)\n\n  if (typeof val === 'string') {\n    if (val.length === 0) return -1 // special case: looking for empty string always fails\n    return String.prototype.indexOf.call(this, val, byteOffset)\n  }\n  if (Buffer.isBuffer(val)) {\n    return arrayIndexOf(this, val, byteOffset)\n  }\n  if (typeof val === 'number') {\n    if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') {\n      return Uint8Array.prototype.indexOf.call(this, val, byteOffset)\n    }\n    return arrayIndexOf(this, [ val ], byteOffset)\n  }\n\n  function arrayIndexOf (arr, val, byteOffset) {\n    var foundIndex = -1\n    for (var i = 0; byteOffset + i < arr.length; i++) {\n      if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex\n      } else {\n        foundIndex = -1\n      }\n    }\n    return -1\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\n// `get` is deprecated\nBuffer.prototype.get = function get (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` is deprecated\nBuffer.prototype.set = function set (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 parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(parsed)) throw new Error('Invalid hex string')\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction binaryWrite (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset | 0\n    if (isFinite(length)) {\n      length = length | 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    var swap = encoding\n    encoding = offset\n    offset = length | 0\n    length = swap\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'binary':\n        return binaryWrite(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\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  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\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] & 0x7F)\n  }\n  return ret\n}\n\nfunction binarySlice (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 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 slice (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) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  if (newBuf.length) newBuf.parent = this.parent || this\n\n  return newBuf\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) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  if (!noAssert) 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 readUInt32BE (offset, noAssert) {\n  if (!noAssert) 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.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  if (!noAssert) 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 readInt16BE (offset, noAssert) {\n  if (!noAssert) 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 readInt32LE (offset, noAssert) {\n  if (!noAssert) 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 readInt32BE (offset, noAssert) {\n  if (!noAssert) 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 readFloatLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  if (!noAssert) 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 RangeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = (value & 0xff)\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 writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\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 writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) 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 & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) 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 & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = value < 0 ? 1 : 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = value < 0 ? 1 : 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) 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 & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) 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 & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (value > max || value < min) throw new RangeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('index out of range')\n  if (offset < 0) throw new RangeError('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  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (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  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (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 copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; i--) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; i++) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    target._set(this.subarray(start, start + len), targetStart)\n  }\n\n  return len\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function fill (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 RangeError('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 RangeError('start out of bounds')\n  if (end < 0 || end > this.length) throw new RangeError('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 toArrayBuffer () {\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 _augment (arr) {\n  arr.constructor = Buffer\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array set method before overwriting\n  arr._set = arr.set\n\n  // deprecated\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.indexOf = BP.indexOf\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUIntLE = BP.readUIntLE\n  arr.readUIntBE = BP.readUIntBE\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.readIntLE = BP.readIntLE\n  arr.readIntBE = BP.readIntBE\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.writeUIntLE = BP.writeUIntLE\n  arr.writeUIntBE = BP.writeUIntBE\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeIntLE = BP.writeIntLE\n  arr.writeIntBE = BP.writeIntBE\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-Za-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 converts strings with length < 2 to ''\n  if (str.length < 2) return ''\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 toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; i++) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00 | 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\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, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    if ((units -= 2) < 0) break\n\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(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\tvar PLUS_URL_SAFE = '-'.charCodeAt(0)\n\tvar SLASH_URL_SAFE = '_'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS ||\n\t\t    code === PLUS_URL_SAFE)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH ||\n\t\t    code === SLASH_URL_SAFE)\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/**\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"]}