src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/resources/jquery/jszip/dist/jszip.js
branchJDK-8200758-branch
changeset 57329 8009cf5b833d
parent 57328 b33e5f36b59b
parent 54532 e9c62d960d64
child 57330 a30edd277572
equal deleted inserted replaced
57328:b33e5f36b59b 57329:8009cf5b833d
     1 /*!
       
     2 
       
     3 JSZip v3.1.5 - A JavaScript class for generating and reading zip files
       
     4 <http://stuartk.com/jszip>
       
     5 
       
     6 (c) 2009-2016 Stuart Knightley <stuart [at] stuartk.com>
       
     7 Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/master/LICENSE.markdown.
       
     8 
       
     9 JSZip uses the library pako released under the MIT license :
       
    10 https://github.com/nodeca/pako/blob/master/LICENSE
       
    11 */
       
    12 
       
    13 (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.JSZip = f()}})(function(){var define,module,exports;return (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){
       
    14 'use strict';
       
    15 var utils = require('./utils');
       
    16 var support = require('./support');
       
    17 // private property
       
    18 var _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
       
    19 
       
    20 
       
    21 // public method for encoding
       
    22 exports.encode = function(input) {
       
    23     var output = [];
       
    24     var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
       
    25     var i = 0, len = input.length, remainingBytes = len;
       
    26 
       
    27     var isArray = utils.getTypeOf(input) !== "string";
       
    28     while (i < input.length) {
       
    29         remainingBytes = len - i;
       
    30 
       
    31         if (!isArray) {
       
    32             chr1 = input.charCodeAt(i++);
       
    33             chr2 = i < len ? input.charCodeAt(i++) : 0;
       
    34             chr3 = i < len ? input.charCodeAt(i++) : 0;
       
    35         } else {
       
    36             chr1 = input[i++];
       
    37             chr2 = i < len ? input[i++] : 0;
       
    38             chr3 = i < len ? input[i++] : 0;
       
    39         }
       
    40 
       
    41         enc1 = chr1 >> 2;
       
    42         enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
       
    43         enc3 = remainingBytes > 1 ? (((chr2 & 15) << 2) | (chr3 >> 6)) : 64;
       
    44         enc4 = remainingBytes > 2 ? (chr3 & 63) : 64;
       
    45 
       
    46         output.push(_keyStr.charAt(enc1) + _keyStr.charAt(enc2) + _keyStr.charAt(enc3) + _keyStr.charAt(enc4));
       
    47 
       
    48     }
       
    49 
       
    50     return output.join("");
       
    51 };
       
    52 
       
    53 // public method for decoding
       
    54 exports.decode = function(input) {
       
    55     var chr1, chr2, chr3;
       
    56     var enc1, enc2, enc3, enc4;
       
    57     var i = 0, resultIndex = 0;
       
    58 
       
    59     var dataUrlPrefix = "data:";
       
    60 
       
    61     if (input.substr(0, dataUrlPrefix.length) === dataUrlPrefix) {
       
    62         // This is a common error: people give a data url
       
    63         // (...) with a {base64: true} and
       
    64         // wonders why things don't work.
       
    65         // We can detect that the string input looks like a data url but we
       
    66         // *can't* be sure it is one: removing everything up to the comma would
       
    67         // be too dangerous.
       
    68         throw new Error("Invalid base64 input, it looks like a data url.");
       
    69     }
       
    70 
       
    71     input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
       
    72 
       
    73     var totalLength = input.length * 3 / 4;
       
    74     if(input.charAt(input.length - 1) === _keyStr.charAt(64)) {
       
    75         totalLength--;
       
    76     }
       
    77     if(input.charAt(input.length - 2) === _keyStr.charAt(64)) {
       
    78         totalLength--;
       
    79     }
       
    80     if (totalLength % 1 !== 0) {
       
    81         // totalLength is not an integer, the length does not match a valid
       
    82         // base64 content. That can happen if:
       
    83         // - the input is not a base64 content
       
    84         // - the input is *almost* a base64 content, with a extra chars at the
       
    85         //   beginning or at the end
       
    86         // - the input uses a base64 variant (base64url for example)
       
    87         throw new Error("Invalid base64 input, bad content length.");
       
    88     }
       
    89     var output;
       
    90     if (support.uint8array) {
       
    91         output = new Uint8Array(totalLength|0);
       
    92     } else {
       
    93         output = new Array(totalLength|0);
       
    94     }
       
    95 
       
    96     while (i < input.length) {
       
    97 
       
    98         enc1 = _keyStr.indexOf(input.charAt(i++));
       
    99         enc2 = _keyStr.indexOf(input.charAt(i++));
       
   100         enc3 = _keyStr.indexOf(input.charAt(i++));
       
   101         enc4 = _keyStr.indexOf(input.charAt(i++));
       
   102 
       
   103         chr1 = (enc1 << 2) | (enc2 >> 4);
       
   104         chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
       
   105         chr3 = ((enc3 & 3) << 6) | enc4;
       
   106 
       
   107         output[resultIndex++] = chr1;
       
   108 
       
   109         if (enc3 !== 64) {
       
   110             output[resultIndex++] = chr2;
       
   111         }
       
   112         if (enc4 !== 64) {
       
   113             output[resultIndex++] = chr3;
       
   114         }
       
   115 
       
   116     }
       
   117 
       
   118     return output;
       
   119 };
       
   120 
       
   121 },{"./support":30,"./utils":32}],2:[function(require,module,exports){
       
   122 'use strict';
       
   123 
       
   124 var external = require("./external");
       
   125 var DataWorker = require('./stream/DataWorker');
       
   126 var DataLengthProbe = require('./stream/DataLengthProbe');
       
   127 var Crc32Probe = require('./stream/Crc32Probe');
       
   128 var DataLengthProbe = require('./stream/DataLengthProbe');
       
   129 
       
   130 /**
       
   131  * Represent a compressed object, with everything needed to decompress it.
       
   132  * @constructor
       
   133  * @param {number} compressedSize the size of the data compressed.
       
   134  * @param {number} uncompressedSize the size of the data after decompression.
       
   135  * @param {number} crc32 the crc32 of the decompressed file.
       
   136  * @param {object} compression the type of compression, see lib/compressions.js.
       
   137  * @param {String|ArrayBuffer|Uint8Array|Buffer} data the compressed data.
       
   138  */
       
   139 function CompressedObject(compressedSize, uncompressedSize, crc32, compression, data) {
       
   140     this.compressedSize = compressedSize;
       
   141     this.uncompressedSize = uncompressedSize;
       
   142     this.crc32 = crc32;
       
   143     this.compression = compression;
       
   144     this.compressedContent = data;
       
   145 }
       
   146 
       
   147 CompressedObject.prototype = {
       
   148     /**
       
   149      * Create a worker to get the uncompressed content.
       
   150      * @return {GenericWorker} the worker.
       
   151      */
       
   152     getContentWorker : function () {
       
   153         var worker = new DataWorker(external.Promise.resolve(this.compressedContent))
       
   154         .pipe(this.compression.uncompressWorker())
       
   155         .pipe(new DataLengthProbe("data_length"));
       
   156 
       
   157         var that = this;
       
   158         worker.on("end", function () {
       
   159             if(this.streamInfo['data_length'] !== that.uncompressedSize) {
       
   160                 throw new Error("Bug : uncompressed data size mismatch");
       
   161             }
       
   162         });
       
   163         return worker;
       
   164     },
       
   165     /**
       
   166      * Create a worker to get the compressed content.
       
   167      * @return {GenericWorker} the worker.
       
   168      */
       
   169     getCompressedWorker : function () {
       
   170         return new DataWorker(external.Promise.resolve(this.compressedContent))
       
   171         .withStreamInfo("compressedSize", this.compressedSize)
       
   172         .withStreamInfo("uncompressedSize", this.uncompressedSize)
       
   173         .withStreamInfo("crc32", this.crc32)
       
   174         .withStreamInfo("compression", this.compression)
       
   175         ;
       
   176     }
       
   177 };
       
   178 
       
   179 /**
       
   180  * Chain the given worker with other workers to compress the content with the
       
   181  * given compresion.
       
   182  * @param {GenericWorker} uncompressedWorker the worker to pipe.
       
   183  * @param {Object} compression the compression object.
       
   184  * @param {Object} compressionOptions the options to use when compressing.
       
   185  * @return {GenericWorker} the new worker compressing the content.
       
   186  */
       
   187 CompressedObject.createWorkerFrom = function (uncompressedWorker, compression, compressionOptions) {
       
   188     return uncompressedWorker
       
   189     .pipe(new Crc32Probe())
       
   190     .pipe(new DataLengthProbe("uncompressedSize"))
       
   191     .pipe(compression.compressWorker(compressionOptions))
       
   192     .pipe(new DataLengthProbe("compressedSize"))
       
   193     .withStreamInfo("compression", compression);
       
   194 };
       
   195 
       
   196 module.exports = CompressedObject;
       
   197 
       
   198 },{"./external":6,"./stream/Crc32Probe":25,"./stream/DataLengthProbe":26,"./stream/DataWorker":27}],3:[function(require,module,exports){
       
   199 'use strict';
       
   200 
       
   201 var GenericWorker = require("./stream/GenericWorker");
       
   202 
       
   203 exports.STORE = {
       
   204     magic: "\x00\x00",
       
   205     compressWorker : function (compressionOptions) {
       
   206         return new GenericWorker("STORE compression");
       
   207     },
       
   208     uncompressWorker : function () {
       
   209         return new GenericWorker("STORE decompression");
       
   210     }
       
   211 };
       
   212 exports.DEFLATE = require('./flate');
       
   213 
       
   214 },{"./flate":7,"./stream/GenericWorker":28}],4:[function(require,module,exports){
       
   215 'use strict';
       
   216 
       
   217 var utils = require('./utils');
       
   218 
       
   219 /**
       
   220  * The following functions come from pako, from pako/lib/zlib/crc32.js
       
   221  * released under the MIT license, see pako https://github.com/nodeca/pako/
       
   222  */
       
   223 
       
   224 // Use ordinary array, since untyped makes no boost here
       
   225 function makeTable() {
       
   226     var c, table = [];
       
   227 
       
   228     for(var n =0; n < 256; n++){
       
   229         c = n;
       
   230         for(var k =0; k < 8; k++){
       
   231             c = ((c&1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));
       
   232         }
       
   233         table[n] = c;
       
   234     }
       
   235 
       
   236     return table;
       
   237 }
       
   238 
       
   239 // Create table on load. Just 255 signed longs. Not a problem.
       
   240 var crcTable = makeTable();
       
   241 
       
   242 
       
   243 function crc32(crc, buf, len, pos) {
       
   244     var t = crcTable, end = pos + len;
       
   245 
       
   246     crc = crc ^ (-1);
       
   247 
       
   248     for (var i = pos; i < end; i++ ) {
       
   249         crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];
       
   250     }
       
   251 
       
   252     return (crc ^ (-1)); // >>> 0;
       
   253 }
       
   254 
       
   255 // That's all for the pako functions.
       
   256 
       
   257 /**
       
   258  * Compute the crc32 of a string.
       
   259  * This is almost the same as the function crc32, but for strings. Using the
       
   260  * same function for the two use cases leads to horrible performances.
       
   261  * @param {Number} crc the starting value of the crc.
       
   262  * @param {String} str the string to use.
       
   263  * @param {Number} len the length of the string.
       
   264  * @param {Number} pos the starting position for the crc32 computation.
       
   265  * @return {Number} the computed crc32.
       
   266  */
       
   267 function crc32str(crc, str, len, pos) {
       
   268     var t = crcTable, end = pos + len;
       
   269 
       
   270     crc = crc ^ (-1);
       
   271 
       
   272     for (var i = pos; i < end; i++ ) {
       
   273         crc = (crc >>> 8) ^ t[(crc ^ str.charCodeAt(i)) & 0xFF];
       
   274     }
       
   275 
       
   276     return (crc ^ (-1)); // >>> 0;
       
   277 }
       
   278 
       
   279 module.exports = function crc32wrapper(input, crc) {
       
   280     if (typeof input === "undefined" || !input.length) {
       
   281         return 0;
       
   282     }
       
   283 
       
   284     var isArray = utils.getTypeOf(input) !== "string";
       
   285 
       
   286     if(isArray) {
       
   287         return crc32(crc|0, input, input.length, 0);
       
   288     } else {
       
   289         return crc32str(crc|0, input, input.length, 0);
       
   290     }
       
   291 };
       
   292 
       
   293 },{"./utils":32}],5:[function(require,module,exports){
       
   294 'use strict';
       
   295 exports.base64 = false;
       
   296 exports.binary = false;
       
   297 exports.dir = false;
       
   298 exports.createFolders = true;
       
   299 exports.date = null;
       
   300 exports.compression = null;
       
   301 exports.compressionOptions = null;
       
   302 exports.comment = null;
       
   303 exports.unixPermissions = null;
       
   304 exports.dosPermissions = null;
       
   305 
       
   306 },{}],6:[function(require,module,exports){
       
   307 /* global Promise */
       
   308 'use strict';
       
   309 
       
   310 // load the global object first:
       
   311 // - it should be better integrated in the system (unhandledRejection in node)
       
   312 // - the environment may have a custom Promise implementation (see zone.js)
       
   313 var ES6Promise = null;
       
   314 if (typeof Promise !== "undefined") {
       
   315     ES6Promise = Promise;
       
   316 } else {
       
   317     ES6Promise = require("lie");
       
   318 }
       
   319 
       
   320 /**
       
   321  * Let the user use/change some implementations.
       
   322  */
       
   323 module.exports = {
       
   324     Promise: ES6Promise
       
   325 };
       
   326 
       
   327 },{"lie":58}],7:[function(require,module,exports){
       
   328 'use strict';
       
   329 var USE_TYPEDARRAY = (typeof Uint8Array !== 'undefined') && (typeof Uint16Array !== 'undefined') && (typeof Uint32Array !== 'undefined');
       
   330 
       
   331 var pako = require("pako");
       
   332 var utils = require("./utils");
       
   333 var GenericWorker = require("./stream/GenericWorker");
       
   334 
       
   335 var ARRAY_TYPE = USE_TYPEDARRAY ? "uint8array" : "array";
       
   336 
       
   337 exports.magic = "\x08\x00";
       
   338 
       
   339 /**
       
   340  * Create a worker that uses pako to inflate/deflate.
       
   341  * @constructor
       
   342  * @param {String} action the name of the pako function to call : either "Deflate" or "Inflate".
       
   343  * @param {Object} options the options to use when (de)compressing.
       
   344  */
       
   345 function FlateWorker(action, options) {
       
   346     GenericWorker.call(this, "FlateWorker/" + action);
       
   347 
       
   348     this._pako = null;
       
   349     this._pakoAction = action;
       
   350     this._pakoOptions = options;
       
   351     // the `meta` object from the last chunk received
       
   352     // this allow this worker to pass around metadata
       
   353     this.meta = {};
       
   354 }
       
   355 
       
   356 utils.inherits(FlateWorker, GenericWorker);
       
   357 
       
   358 /**
       
   359  * @see GenericWorker.processChunk
       
   360  */
       
   361 FlateWorker.prototype.processChunk = function (chunk) {
       
   362     this.meta = chunk.meta;
       
   363     if (this._pako === null) {
       
   364         this._createPako();
       
   365     }
       
   366     this._pako.push(utils.transformTo(ARRAY_TYPE, chunk.data), false);
       
   367 };
       
   368 
       
   369 /**
       
   370  * @see GenericWorker.flush
       
   371  */
       
   372 FlateWorker.prototype.flush = function () {
       
   373     GenericWorker.prototype.flush.call(this);
       
   374     if (this._pako === null) {
       
   375         this._createPako();
       
   376     }
       
   377     this._pako.push([], true);
       
   378 };
       
   379 /**
       
   380  * @see GenericWorker.cleanUp
       
   381  */
       
   382 FlateWorker.prototype.cleanUp = function () {
       
   383     GenericWorker.prototype.cleanUp.call(this);
       
   384     this._pako = null;
       
   385 };
       
   386 
       
   387 /**
       
   388  * Create the _pako object.
       
   389  * TODO: lazy-loading this object isn't the best solution but it's the
       
   390  * quickest. The best solution is to lazy-load the worker list. See also the
       
   391  * issue #446.
       
   392  */
       
   393 FlateWorker.prototype._createPako = function () {
       
   394     this._pako = new pako[this._pakoAction]({
       
   395         raw: true,
       
   396         level: this._pakoOptions.level || -1 // default compression
       
   397     });
       
   398     var self = this;
       
   399     this._pako.onData = function(data) {
       
   400         self.push({
       
   401             data : data,
       
   402             meta : self.meta
       
   403         });
       
   404     };
       
   405 };
       
   406 
       
   407 exports.compressWorker = function (compressionOptions) {
       
   408     return new FlateWorker("Deflate", compressionOptions);
       
   409 };
       
   410 exports.uncompressWorker = function () {
       
   411     return new FlateWorker("Inflate", {});
       
   412 };
       
   413 
       
   414 },{"./stream/GenericWorker":28,"./utils":32,"pako":59}],8:[function(require,module,exports){
       
   415 'use strict';
       
   416 
       
   417 var utils = require('../utils');
       
   418 var GenericWorker = require('../stream/GenericWorker');
       
   419 var utf8 = require('../utf8');
       
   420 var crc32 = require('../crc32');
       
   421 var signature = require('../signature');
       
   422 
       
   423 /**
       
   424  * Transform an integer into a string in hexadecimal.
       
   425  * @private
       
   426  * @param {number} dec the number to convert.
       
   427  * @param {number} bytes the number of bytes to generate.
       
   428  * @returns {string} the result.
       
   429  */
       
   430 var decToHex = function(dec, bytes) {
       
   431     var hex = "", i;
       
   432     for (i = 0; i < bytes; i++) {
       
   433         hex += String.fromCharCode(dec & 0xff);
       
   434         dec = dec >>> 8;
       
   435     }
       
   436     return hex;
       
   437 };
       
   438 
       
   439 /**
       
   440  * Generate the UNIX part of the external file attributes.
       
   441  * @param {Object} unixPermissions the unix permissions or null.
       
   442  * @param {Boolean} isDir true if the entry is a directory, false otherwise.
       
   443  * @return {Number} a 32 bit integer.
       
   444  *
       
   445  * adapted from http://unix.stackexchange.com/questions/14705/the-zip-formats-external-file-attribute :
       
   446  *
       
   447  * TTTTsstrwxrwxrwx0000000000ADVSHR
       
   448  * ^^^^____________________________ file type, see zipinfo.c (UNX_*)
       
   449  *     ^^^_________________________ setuid, setgid, sticky
       
   450  *        ^^^^^^^^^________________ permissions
       
   451  *                 ^^^^^^^^^^______ not used ?
       
   452  *                           ^^^^^^ DOS attribute bits : Archive, Directory, Volume label, System file, Hidden, Read only
       
   453  */
       
   454 var generateUnixExternalFileAttr = function (unixPermissions, isDir) {
       
   455 
       
   456     var result = unixPermissions;
       
   457     if (!unixPermissions) {
       
   458         // I can't use octal values in strict mode, hence the hexa.
       
   459         //  040775 => 0x41fd
       
   460         // 0100664 => 0x81b4
       
   461         result = isDir ? 0x41fd : 0x81b4;
       
   462     }
       
   463     return (result & 0xFFFF) << 16;
       
   464 };
       
   465 
       
   466 /**
       
   467  * Generate the DOS part of the external file attributes.
       
   468  * @param {Object} dosPermissions the dos permissions or null.
       
   469  * @param {Boolean} isDir true if the entry is a directory, false otherwise.
       
   470  * @return {Number} a 32 bit integer.
       
   471  *
       
   472  * Bit 0     Read-Only
       
   473  * Bit 1     Hidden
       
   474  * Bit 2     System
       
   475  * Bit 3     Volume Label
       
   476  * Bit 4     Directory
       
   477  * Bit 5     Archive
       
   478  */
       
   479 var generateDosExternalFileAttr = function (dosPermissions, isDir) {
       
   480 
       
   481     // the dir flag is already set for compatibility
       
   482     return (dosPermissions || 0)  & 0x3F;
       
   483 };
       
   484 
       
   485 /**
       
   486  * Generate the various parts used in the construction of the final zip file.
       
   487  * @param {Object} streamInfo the hash with informations about the compressed file.
       
   488  * @param {Boolean} streamedContent is the content streamed ?
       
   489  * @param {Boolean} streamingEnded is the stream finished ?
       
   490  * @param {number} offset the current offset from the start of the zip file.
       
   491  * @param {String} platform let's pretend we are this platform (change platform dependents fields)
       
   492  * @param {Function} encodeFileName the function to encode the file name / comment.
       
   493  * @return {Object} the zip parts.
       
   494  */
       
   495 var generateZipParts = function(streamInfo, streamedContent, streamingEnded, offset, platform, encodeFileName) {
       
   496     var file = streamInfo['file'],
       
   497     compression = streamInfo['compression'],
       
   498     useCustomEncoding = encodeFileName !== utf8.utf8encode,
       
   499     encodedFileName = utils.transformTo("string", encodeFileName(file.name)),
       
   500     utfEncodedFileName = utils.transformTo("string", utf8.utf8encode(file.name)),
       
   501     comment = file.comment,
       
   502     encodedComment = utils.transformTo("string", encodeFileName(comment)),
       
   503     utfEncodedComment = utils.transformTo("string", utf8.utf8encode(comment)),
       
   504     useUTF8ForFileName = utfEncodedFileName.length !== file.name.length,
       
   505     useUTF8ForComment = utfEncodedComment.length !== comment.length,
       
   506     dosTime,
       
   507     dosDate,
       
   508     extraFields = "",
       
   509     unicodePathExtraField = "",
       
   510     unicodeCommentExtraField = "",
       
   511     dir = file.dir,
       
   512     date = file.date;
       
   513 
       
   514 
       
   515     var dataInfo = {
       
   516         crc32 : 0,
       
   517         compressedSize : 0,
       
   518         uncompressedSize : 0
       
   519     };
       
   520 
       
   521     // if the content is streamed, the sizes/crc32 are only available AFTER
       
   522     // the end of the stream.
       
   523     if (!streamedContent || streamingEnded) {
       
   524         dataInfo.crc32 = streamInfo['crc32'];
       
   525         dataInfo.compressedSize = streamInfo['compressedSize'];
       
   526         dataInfo.uncompressedSize = streamInfo['uncompressedSize'];
       
   527     }
       
   528 
       
   529     var bitflag = 0;
       
   530     if (streamedContent) {
       
   531         // Bit 3: the sizes/crc32 are set to zero in the local header.
       
   532         // The correct values are put in the data descriptor immediately
       
   533         // following the compressed data.
       
   534         bitflag |= 0x0008;
       
   535     }
       
   536     if (!useCustomEncoding && (useUTF8ForFileName || useUTF8ForComment)) {
       
   537         // Bit 11: Language encoding flag (EFS).
       
   538         bitflag |= 0x0800;
       
   539     }
       
   540 
       
   541 
       
   542     var extFileAttr = 0;
       
   543     var versionMadeBy = 0;
       
   544     if (dir) {
       
   545         // dos or unix, we set the dos dir flag
       
   546         extFileAttr |= 0x00010;
       
   547     }
       
   548     if(platform === "UNIX") {
       
   549         versionMadeBy = 0x031E; // UNIX, version 3.0
       
   550         extFileAttr |= generateUnixExternalFileAttr(file.unixPermissions, dir);
       
   551     } else { // DOS or other, fallback to DOS
       
   552         versionMadeBy = 0x0014; // DOS, version 2.0
       
   553         extFileAttr |= generateDosExternalFileAttr(file.dosPermissions, dir);
       
   554     }
       
   555 
       
   556     // date
       
   557     // @see http://www.delorie.com/djgpp/doc/rbinter/it/52/13.html
       
   558     // @see http://www.delorie.com/djgpp/doc/rbinter/it/65/16.html
       
   559     // @see http://www.delorie.com/djgpp/doc/rbinter/it/66/16.html
       
   560 
       
   561     dosTime = date.getUTCHours();
       
   562     dosTime = dosTime << 6;
       
   563     dosTime = dosTime | date.getUTCMinutes();
       
   564     dosTime = dosTime << 5;
       
   565     dosTime = dosTime | date.getUTCSeconds() / 2;
       
   566 
       
   567     dosDate = date.getUTCFullYear() - 1980;
       
   568     dosDate = dosDate << 4;
       
   569     dosDate = dosDate | (date.getUTCMonth() + 1);
       
   570     dosDate = dosDate << 5;
       
   571     dosDate = dosDate | date.getUTCDate();
       
   572 
       
   573     if (useUTF8ForFileName) {
       
   574         // set the unicode path extra field. unzip needs at least one extra
       
   575         // field to correctly handle unicode path, so using the path is as good
       
   576         // as any other information. This could improve the situation with
       
   577         // other archive managers too.
       
   578         // This field is usually used without the utf8 flag, with a non
       
   579         // unicode path in the header (winrar, winzip). This helps (a bit)
       
   580         // with the messy Windows' default compressed folders feature but
       
   581         // breaks on p7zip which doesn't seek the unicode path extra field.
       
   582         // So for now, UTF-8 everywhere !
       
   583         unicodePathExtraField =
       
   584             // Version
       
   585             decToHex(1, 1) +
       
   586             // NameCRC32
       
   587             decToHex(crc32(encodedFileName), 4) +
       
   588             // UnicodeName
       
   589             utfEncodedFileName;
       
   590 
       
   591         extraFields +=
       
   592             // Info-ZIP Unicode Path Extra Field
       
   593             "\x75\x70" +
       
   594             // size
       
   595             decToHex(unicodePathExtraField.length, 2) +
       
   596             // content
       
   597             unicodePathExtraField;
       
   598     }
       
   599 
       
   600     if(useUTF8ForComment) {
       
   601 
       
   602         unicodeCommentExtraField =
       
   603             // Version
       
   604             decToHex(1, 1) +
       
   605             // CommentCRC32
       
   606             decToHex(crc32(encodedComment), 4) +
       
   607             // UnicodeName
       
   608             utfEncodedComment;
       
   609 
       
   610         extraFields +=
       
   611             // Info-ZIP Unicode Path Extra Field
       
   612             "\x75\x63" +
       
   613             // size
       
   614             decToHex(unicodeCommentExtraField.length, 2) +
       
   615             // content
       
   616             unicodeCommentExtraField;
       
   617     }
       
   618 
       
   619     var header = "";
       
   620 
       
   621     // version needed to extract
       
   622     header += "\x0A\x00";
       
   623     // general purpose bit flag
       
   624     header += decToHex(bitflag, 2);
       
   625     // compression method
       
   626     header += compression.magic;
       
   627     // last mod file time
       
   628     header += decToHex(dosTime, 2);
       
   629     // last mod file date
       
   630     header += decToHex(dosDate, 2);
       
   631     // crc-32
       
   632     header += decToHex(dataInfo.crc32, 4);
       
   633     // compressed size
       
   634     header += decToHex(dataInfo.compressedSize, 4);
       
   635     // uncompressed size
       
   636     header += decToHex(dataInfo.uncompressedSize, 4);
       
   637     // file name length
       
   638     header += decToHex(encodedFileName.length, 2);
       
   639     // extra field length
       
   640     header += decToHex(extraFields.length, 2);
       
   641 
       
   642 
       
   643     var fileRecord = signature.LOCAL_FILE_HEADER + header + encodedFileName + extraFields;
       
   644 
       
   645     var dirRecord = signature.CENTRAL_FILE_HEADER +
       
   646         // version made by (00: DOS)
       
   647         decToHex(versionMadeBy, 2) +
       
   648         // file header (common to file and central directory)
       
   649         header +
       
   650         // file comment length
       
   651         decToHex(encodedComment.length, 2) +
       
   652         // disk number start
       
   653         "\x00\x00" +
       
   654         // internal file attributes TODO
       
   655         "\x00\x00" +
       
   656         // external file attributes
       
   657         decToHex(extFileAttr, 4) +
       
   658         // relative offset of local header
       
   659         decToHex(offset, 4) +
       
   660         // file name
       
   661         encodedFileName +
       
   662         // extra field
       
   663         extraFields +
       
   664         // file comment
       
   665         encodedComment;
       
   666 
       
   667     return {
       
   668         fileRecord: fileRecord,
       
   669         dirRecord: dirRecord
       
   670     };
       
   671 };
       
   672 
       
   673 /**
       
   674  * Generate the EOCD record.
       
   675  * @param {Number} entriesCount the number of entries in the zip file.
       
   676  * @param {Number} centralDirLength the length (in bytes) of the central dir.
       
   677  * @param {Number} localDirLength the length (in bytes) of the local dir.
       
   678  * @param {String} comment the zip file comment as a binary string.
       
   679  * @param {Function} encodeFileName the function to encode the comment.
       
   680  * @return {String} the EOCD record.
       
   681  */
       
   682 var generateCentralDirectoryEnd = function (entriesCount, centralDirLength, localDirLength, comment, encodeFileName) {
       
   683     var dirEnd = "";
       
   684     var encodedComment = utils.transformTo("string", encodeFileName(comment));
       
   685 
       
   686     // end of central dir signature
       
   687     dirEnd = signature.CENTRAL_DIRECTORY_END +
       
   688         // number of this disk
       
   689         "\x00\x00" +
       
   690         // number of the disk with the start of the central directory
       
   691         "\x00\x00" +
       
   692         // total number of entries in the central directory on this disk
       
   693         decToHex(entriesCount, 2) +
       
   694         // total number of entries in the central directory
       
   695         decToHex(entriesCount, 2) +
       
   696         // size of the central directory   4 bytes
       
   697         decToHex(centralDirLength, 4) +
       
   698         // offset of start of central directory with respect to the starting disk number
       
   699         decToHex(localDirLength, 4) +
       
   700         // .ZIP file comment length
       
   701         decToHex(encodedComment.length, 2) +
       
   702         // .ZIP file comment
       
   703         encodedComment;
       
   704 
       
   705     return dirEnd;
       
   706 };
       
   707 
       
   708 /**
       
   709  * Generate data descriptors for a file entry.
       
   710  * @param {Object} streamInfo the hash generated by a worker, containing informations
       
   711  * on the file entry.
       
   712  * @return {String} the data descriptors.
       
   713  */
       
   714 var generateDataDescriptors = function (streamInfo) {
       
   715     var descriptor = "";
       
   716     descriptor = signature.DATA_DESCRIPTOR +
       
   717         // crc-32                          4 bytes
       
   718         decToHex(streamInfo['crc32'], 4) +
       
   719         // compressed size                 4 bytes
       
   720         decToHex(streamInfo['compressedSize'], 4) +
       
   721         // uncompressed size               4 bytes
       
   722         decToHex(streamInfo['uncompressedSize'], 4);
       
   723 
       
   724     return descriptor;
       
   725 };
       
   726 
       
   727 
       
   728 /**
       
   729  * A worker to concatenate other workers to create a zip file.
       
   730  * @param {Boolean} streamFiles `true` to stream the content of the files,
       
   731  * `false` to accumulate it.
       
   732  * @param {String} comment the comment to use.
       
   733  * @param {String} platform the platform to use, "UNIX" or "DOS".
       
   734  * @param {Function} encodeFileName the function to encode file names and comments.
       
   735  */
       
   736 function ZipFileWorker(streamFiles, comment, platform, encodeFileName) {
       
   737     GenericWorker.call(this, "ZipFileWorker");
       
   738     // The number of bytes written so far. This doesn't count accumulated chunks.
       
   739     this.bytesWritten = 0;
       
   740     // The comment of the zip file
       
   741     this.zipComment = comment;
       
   742     // The platform "generating" the zip file.
       
   743     this.zipPlatform = platform;
       
   744     // the function to encode file names and comments.
       
   745     this.encodeFileName = encodeFileName;
       
   746     // Should we stream the content of the files ?
       
   747     this.streamFiles = streamFiles;
       
   748     // If `streamFiles` is false, we will need to accumulate the content of the
       
   749     // files to calculate sizes / crc32 (and write them *before* the content).
       
   750     // This boolean indicates if we are accumulating chunks (it will change a lot
       
   751     // during the lifetime of this worker).
       
   752     this.accumulate = false;
       
   753     // The buffer receiving chunks when accumulating content.
       
   754     this.contentBuffer = [];
       
   755     // The list of generated directory records.
       
   756     this.dirRecords = [];
       
   757     // The offset (in bytes) from the beginning of the zip file for the current source.
       
   758     this.currentSourceOffset = 0;
       
   759     // The total number of entries in this zip file.
       
   760     this.entriesCount = 0;
       
   761     // the name of the file currently being added, null when handling the end of the zip file.
       
   762     // Used for the emited metadata.
       
   763     this.currentFile = null;
       
   764 
       
   765 
       
   766 
       
   767     this._sources = [];
       
   768 }
       
   769 utils.inherits(ZipFileWorker, GenericWorker);
       
   770 
       
   771 /**
       
   772  * @see GenericWorker.push
       
   773  */
       
   774 ZipFileWorker.prototype.push = function (chunk) {
       
   775 
       
   776     var currentFilePercent = chunk.meta.percent || 0;
       
   777     var entriesCount = this.entriesCount;
       
   778     var remainingFiles = this._sources.length;
       
   779 
       
   780     if(this.accumulate) {
       
   781         this.contentBuffer.push(chunk);
       
   782     } else {
       
   783         this.bytesWritten += chunk.data.length;
       
   784 
       
   785         GenericWorker.prototype.push.call(this, {
       
   786             data : chunk.data,
       
   787             meta : {
       
   788                 currentFile : this.currentFile,
       
   789                 percent : entriesCount ? (currentFilePercent + 100 * (entriesCount - remainingFiles - 1)) / entriesCount : 100
       
   790             }
       
   791         });
       
   792     }
       
   793 };
       
   794 
       
   795 /**
       
   796  * The worker started a new source (an other worker).
       
   797  * @param {Object} streamInfo the streamInfo object from the new source.
       
   798  */
       
   799 ZipFileWorker.prototype.openedSource = function (streamInfo) {
       
   800     this.currentSourceOffset = this.bytesWritten;
       
   801     this.currentFile = streamInfo['file'].name;
       
   802 
       
   803     var streamedContent = this.streamFiles && !streamInfo['file'].dir;
       
   804 
       
   805     // don't stream folders (because they don't have any content)
       
   806     if(streamedContent) {
       
   807         var record = generateZipParts(streamInfo, streamedContent, false, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
       
   808         this.push({
       
   809             data : record.fileRecord,
       
   810             meta : {percent:0}
       
   811         });
       
   812     } else {
       
   813         // we need to wait for the whole file before pushing anything
       
   814         this.accumulate = true;
       
   815     }
       
   816 };
       
   817 
       
   818 /**
       
   819  * The worker finished a source (an other worker).
       
   820  * @param {Object} streamInfo the streamInfo object from the finished source.
       
   821  */
       
   822 ZipFileWorker.prototype.closedSource = function (streamInfo) {
       
   823     this.accumulate = false;
       
   824     var streamedContent = this.streamFiles && !streamInfo['file'].dir;
       
   825     var record = generateZipParts(streamInfo, streamedContent, true, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
       
   826 
       
   827     this.dirRecords.push(record.dirRecord);
       
   828     if(streamedContent) {
       
   829         // after the streamed file, we put data descriptors
       
   830         this.push({
       
   831             data : generateDataDescriptors(streamInfo),
       
   832             meta : {percent:100}
       
   833         });
       
   834     } else {
       
   835         // the content wasn't streamed, we need to push everything now
       
   836         // first the file record, then the content
       
   837         this.push({
       
   838             data : record.fileRecord,
       
   839             meta : {percent:0}
       
   840         });
       
   841         while(this.contentBuffer.length) {
       
   842             this.push(this.contentBuffer.shift());
       
   843         }
       
   844     }
       
   845     this.currentFile = null;
       
   846 };
       
   847 
       
   848 /**
       
   849  * @see GenericWorker.flush
       
   850  */
       
   851 ZipFileWorker.prototype.flush = function () {
       
   852 
       
   853     var localDirLength = this.bytesWritten;
       
   854     for(var i = 0; i < this.dirRecords.length; i++) {
       
   855         this.push({
       
   856             data : this.dirRecords[i],
       
   857             meta : {percent:100}
       
   858         });
       
   859     }
       
   860     var centralDirLength = this.bytesWritten - localDirLength;
       
   861 
       
   862     var dirEnd = generateCentralDirectoryEnd(this.dirRecords.length, centralDirLength, localDirLength, this.zipComment, this.encodeFileName);
       
   863 
       
   864     this.push({
       
   865         data : dirEnd,
       
   866         meta : {percent:100}
       
   867     });
       
   868 };
       
   869 
       
   870 /**
       
   871  * Prepare the next source to be read.
       
   872  */
       
   873 ZipFileWorker.prototype.prepareNextSource = function () {
       
   874     this.previous = this._sources.shift();
       
   875     this.openedSource(this.previous.streamInfo);
       
   876     if (this.isPaused) {
       
   877         this.previous.pause();
       
   878     } else {
       
   879         this.previous.resume();
       
   880     }
       
   881 };
       
   882 
       
   883 /**
       
   884  * @see GenericWorker.registerPrevious
       
   885  */
       
   886 ZipFileWorker.prototype.registerPrevious = function (previous) {
       
   887     this._sources.push(previous);
       
   888     var self = this;
       
   889 
       
   890     previous.on('data', function (chunk) {
       
   891         self.processChunk(chunk);
       
   892     });
       
   893     previous.on('end', function () {
       
   894         self.closedSource(self.previous.streamInfo);
       
   895         if(self._sources.length) {
       
   896             self.prepareNextSource();
       
   897         } else {
       
   898             self.end();
       
   899         }
       
   900     });
       
   901     previous.on('error', function (e) {
       
   902         self.error(e);
       
   903     });
       
   904     return this;
       
   905 };
       
   906 
       
   907 /**
       
   908  * @see GenericWorker.resume
       
   909  */
       
   910 ZipFileWorker.prototype.resume = function () {
       
   911     if(!GenericWorker.prototype.resume.call(this)) {
       
   912         return false;
       
   913     }
       
   914 
       
   915     if (!this.previous && this._sources.length) {
       
   916         this.prepareNextSource();
       
   917         return true;
       
   918     }
       
   919     if (!this.previous && !this._sources.length && !this.generatedError) {
       
   920         this.end();
       
   921         return true;
       
   922     }
       
   923 };
       
   924 
       
   925 /**
       
   926  * @see GenericWorker.error
       
   927  */
       
   928 ZipFileWorker.prototype.error = function (e) {
       
   929     var sources = this._sources;
       
   930     if(!GenericWorker.prototype.error.call(this, e)) {
       
   931         return false;
       
   932     }
       
   933     for(var i = 0; i < sources.length; i++) {
       
   934         try {
       
   935             sources[i].error(e);
       
   936         } catch(e) {
       
   937             // the `error` exploded, nothing to do
       
   938         }
       
   939     }
       
   940     return true;
       
   941 };
       
   942 
       
   943 /**
       
   944  * @see GenericWorker.lock
       
   945  */
       
   946 ZipFileWorker.prototype.lock = function () {
       
   947     GenericWorker.prototype.lock.call(this);
       
   948     var sources = this._sources;
       
   949     for(var i = 0; i < sources.length; i++) {
       
   950         sources[i].lock();
       
   951     }
       
   952 };
       
   953 
       
   954 module.exports = ZipFileWorker;
       
   955 
       
   956 },{"../crc32":4,"../signature":23,"../stream/GenericWorker":28,"../utf8":31,"../utils":32}],9:[function(require,module,exports){
       
   957 'use strict';
       
   958 
       
   959 var compressions = require('../compressions');
       
   960 var ZipFileWorker = require('./ZipFileWorker');
       
   961 
       
   962 /**
       
   963  * Find the compression to use.
       
   964  * @param {String} fileCompression the compression defined at the file level, if any.
       
   965  * @param {String} zipCompression the compression defined at the load() level.
       
   966  * @return {Object} the compression object to use.
       
   967  */
       
   968 var getCompression = function (fileCompression, zipCompression) {
       
   969 
       
   970     var compressionName = fileCompression || zipCompression;
       
   971     var compression = compressions[compressionName];
       
   972     if (!compression) {
       
   973         throw new Error(compressionName + " is not a valid compression method !");
       
   974     }
       
   975     return compression;
       
   976 };
       
   977 
       
   978 /**
       
   979  * Create a worker to generate a zip file.
       
   980  * @param {JSZip} zip the JSZip instance at the right root level.
       
   981  * @param {Object} options to generate the zip file.
       
   982  * @param {String} comment the comment to use.
       
   983  */
       
   984 exports.generateWorker = function (zip, options, comment) {
       
   985 
       
   986     var zipFileWorker = new ZipFileWorker(options.streamFiles, comment, options.platform, options.encodeFileName);
       
   987     var entriesCount = 0;
       
   988     try {
       
   989 
       
   990         zip.forEach(function (relativePath, file) {
       
   991             entriesCount++;
       
   992             var compression = getCompression(file.options.compression, options.compression);
       
   993             var compressionOptions = file.options.compressionOptions || options.compressionOptions || {};
       
   994             var dir = file.dir, date = file.date;
       
   995 
       
   996             file._compressWorker(compression, compressionOptions)
       
   997             .withStreamInfo("file", {
       
   998                 name : relativePath,
       
   999                 dir : dir,
       
  1000                 date : date,
       
  1001                 comment : file.comment || "",
       
  1002                 unixPermissions : file.unixPermissions,
       
  1003                 dosPermissions : file.dosPermissions
       
  1004             })
       
  1005             .pipe(zipFileWorker);
       
  1006         });
       
  1007         zipFileWorker.entriesCount = entriesCount;
       
  1008     } catch (e) {
       
  1009         zipFileWorker.error(e);
       
  1010     }
       
  1011 
       
  1012     return zipFileWorker;
       
  1013 };
       
  1014 
       
  1015 },{"../compressions":3,"./ZipFileWorker":8}],10:[function(require,module,exports){
       
  1016 'use strict';
       
  1017 
       
  1018 /**
       
  1019  * Representation a of zip file in js
       
  1020  * @constructor
       
  1021  */
       
  1022 function JSZip() {
       
  1023     // if this constructor is used without `new`, it adds `new` before itself:
       
  1024     if(!(this instanceof JSZip)) {
       
  1025         return new JSZip();
       
  1026     }
       
  1027 
       
  1028     if(arguments.length) {
       
  1029         throw new Error("The constructor with parameters has been removed in JSZip 3.0, please check the upgrade guide.");
       
  1030     }
       
  1031 
       
  1032     // object containing the files :
       
  1033     // {
       
  1034     //   "folder/" : {...},
       
  1035     //   "folder/data.txt" : {...}
       
  1036     // }
       
  1037     this.files = {};
       
  1038 
       
  1039     this.comment = null;
       
  1040 
       
  1041     // Where we are in the hierarchy
       
  1042     this.root = "";
       
  1043     this.clone = function() {
       
  1044         var newObj = new JSZip();
       
  1045         for (var i in this) {
       
  1046             if (typeof this[i] !== "function") {
       
  1047                 newObj[i] = this[i];
       
  1048             }
       
  1049         }
       
  1050         return newObj;
       
  1051     };
       
  1052 }
       
  1053 JSZip.prototype = require('./object');
       
  1054 JSZip.prototype.loadAsync = require('./load');
       
  1055 JSZip.support = require('./support');
       
  1056 JSZip.defaults = require('./defaults');
       
  1057 
       
  1058 // TODO find a better way to handle this version,
       
  1059 // a require('package.json').version doesn't work with webpack, see #327
       
  1060 JSZip.version = "3.1.5";
       
  1061 
       
  1062 JSZip.loadAsync = function (content, options) {
       
  1063     return new JSZip().loadAsync(content, options);
       
  1064 };
       
  1065 
       
  1066 JSZip.external = require("./external");
       
  1067 module.exports = JSZip;
       
  1068 
       
  1069 },{"./defaults":5,"./external":6,"./load":11,"./object":15,"./support":30}],11:[function(require,module,exports){
       
  1070 'use strict';
       
  1071 var utils = require('./utils');
       
  1072 var external = require("./external");
       
  1073 var utf8 = require('./utf8');
       
  1074 var utils = require('./utils');
       
  1075 var ZipEntries = require('./zipEntries');
       
  1076 var Crc32Probe = require('./stream/Crc32Probe');
       
  1077 var nodejsUtils = require("./nodejsUtils");
       
  1078 
       
  1079 /**
       
  1080  * Check the CRC32 of an entry.
       
  1081  * @param {ZipEntry} zipEntry the zip entry to check.
       
  1082  * @return {Promise} the result.
       
  1083  */
       
  1084 function checkEntryCRC32(zipEntry) {
       
  1085     return new external.Promise(function (resolve, reject) {
       
  1086         var worker = zipEntry.decompressed.getContentWorker().pipe(new Crc32Probe());
       
  1087         worker.on("error", function (e) {
       
  1088             reject(e);
       
  1089         })
       
  1090         .on("end", function () {
       
  1091             if (worker.streamInfo.crc32 !== zipEntry.decompressed.crc32) {
       
  1092                 reject(new Error("Corrupted zip : CRC32 mismatch"));
       
  1093             } else {
       
  1094                 resolve();
       
  1095             }
       
  1096         })
       
  1097         .resume();
       
  1098     });
       
  1099 }
       
  1100 
       
  1101 module.exports = function(data, options) {
       
  1102     var zip = this;
       
  1103     options = utils.extend(options || {}, {
       
  1104         base64: false,
       
  1105         checkCRC32: false,
       
  1106         optimizedBinaryString: false,
       
  1107         createFolders: false,
       
  1108         decodeFileName: utf8.utf8decode
       
  1109     });
       
  1110 
       
  1111     if (nodejsUtils.isNode && nodejsUtils.isStream(data)) {
       
  1112         return external.Promise.reject(new Error("JSZip can't accept a stream when loading a zip file."));
       
  1113     }
       
  1114 
       
  1115     return utils.prepareContent("the loaded zip file", data, true, options.optimizedBinaryString, options.base64)
       
  1116     .then(function(data) {
       
  1117         var zipEntries = new ZipEntries(options);
       
  1118         zipEntries.load(data);
       
  1119         return zipEntries;
       
  1120     }).then(function checkCRC32(zipEntries) {
       
  1121         var promises = [external.Promise.resolve(zipEntries)];
       
  1122         var files = zipEntries.files;
       
  1123         if (options.checkCRC32) {
       
  1124             for (var i = 0; i < files.length; i++) {
       
  1125                 promises.push(checkEntryCRC32(files[i]));
       
  1126             }
       
  1127         }
       
  1128         return external.Promise.all(promises);
       
  1129     }).then(function addFiles(results) {
       
  1130         var zipEntries = results.shift();
       
  1131         var files = zipEntries.files;
       
  1132         for (var i = 0; i < files.length; i++) {
       
  1133             var input = files[i];
       
  1134             zip.file(input.fileNameStr, input.decompressed, {
       
  1135                 binary: true,
       
  1136                 optimizedBinaryString: true,
       
  1137                 date: input.date,
       
  1138                 dir: input.dir,
       
  1139                 comment : input.fileCommentStr.length ? input.fileCommentStr : null,
       
  1140                 unixPermissions : input.unixPermissions,
       
  1141                 dosPermissions : input.dosPermissions,
       
  1142                 createFolders: options.createFolders
       
  1143             });
       
  1144         }
       
  1145         if (zipEntries.zipComment.length) {
       
  1146             zip.comment = zipEntries.zipComment;
       
  1147         }
       
  1148 
       
  1149         return zip;
       
  1150     });
       
  1151 };
       
  1152 
       
  1153 },{"./external":6,"./nodejsUtils":14,"./stream/Crc32Probe":25,"./utf8":31,"./utils":32,"./zipEntries":33}],12:[function(require,module,exports){
       
  1154 "use strict";
       
  1155 
       
  1156 var utils = require('../utils');
       
  1157 var GenericWorker = require('../stream/GenericWorker');
       
  1158 
       
  1159 /**
       
  1160  * A worker that use a nodejs stream as source.
       
  1161  * @constructor
       
  1162  * @param {String} filename the name of the file entry for this stream.
       
  1163  * @param {Readable} stream the nodejs stream.
       
  1164  */
       
  1165 function NodejsStreamInputAdapter(filename, stream) {
       
  1166     GenericWorker.call(this, "Nodejs stream input adapter for " + filename);
       
  1167     this._upstreamEnded = false;
       
  1168     this._bindStream(stream);
       
  1169 }
       
  1170 
       
  1171 utils.inherits(NodejsStreamInputAdapter, GenericWorker);
       
  1172 
       
  1173 /**
       
  1174  * Prepare the stream and bind the callbacks on it.
       
  1175  * Do this ASAP on node 0.10 ! A lazy binding doesn't always work.
       
  1176  * @param {Stream} stream the nodejs stream to use.
       
  1177  */
       
  1178 NodejsStreamInputAdapter.prototype._bindStream = function (stream) {
       
  1179     var self = this;
       
  1180     this._stream = stream;
       
  1181     stream.pause();
       
  1182     stream
       
  1183     .on("data", function (chunk) {
       
  1184         self.push({
       
  1185             data: chunk,
       
  1186             meta : {
       
  1187                 percent : 0
       
  1188             }
       
  1189         });
       
  1190     })
       
  1191     .on("error", function (e) {
       
  1192         if(self.isPaused) {
       
  1193             this.generatedError = e;
       
  1194         } else {
       
  1195             self.error(e);
       
  1196         }
       
  1197     })
       
  1198     .on("end", function () {
       
  1199         if(self.isPaused) {
       
  1200             self._upstreamEnded = true;
       
  1201         } else {
       
  1202             self.end();
       
  1203         }
       
  1204     });
       
  1205 };
       
  1206 NodejsStreamInputAdapter.prototype.pause = function () {
       
  1207     if(!GenericWorker.prototype.pause.call(this)) {
       
  1208         return false;
       
  1209     }
       
  1210     this._stream.pause();
       
  1211     return true;
       
  1212 };
       
  1213 NodejsStreamInputAdapter.prototype.resume = function () {
       
  1214     if(!GenericWorker.prototype.resume.call(this)) {
       
  1215         return false;
       
  1216     }
       
  1217 
       
  1218     if(this._upstreamEnded) {
       
  1219         this.end();
       
  1220     } else {
       
  1221         this._stream.resume();
       
  1222     }
       
  1223 
       
  1224     return true;
       
  1225 };
       
  1226 
       
  1227 module.exports = NodejsStreamInputAdapter;
       
  1228 
       
  1229 },{"../stream/GenericWorker":28,"../utils":32}],13:[function(require,module,exports){
       
  1230 'use strict';
       
  1231 
       
  1232 var Readable = require('readable-stream').Readable;
       
  1233 
       
  1234 var utils = require('../utils');
       
  1235 utils.inherits(NodejsStreamOutputAdapter, Readable);
       
  1236 
       
  1237 /**
       
  1238 * A nodejs stream using a worker as source.
       
  1239 * @see the SourceWrapper in http://nodejs.org/api/stream.html
       
  1240 * @constructor
       
  1241 * @param {StreamHelper} helper the helper wrapping the worker
       
  1242 * @param {Object} options the nodejs stream options
       
  1243 * @param {Function} updateCb the update callback.
       
  1244 */
       
  1245 function NodejsStreamOutputAdapter(helper, options, updateCb) {
       
  1246     Readable.call(this, options);
       
  1247     this._helper = helper;
       
  1248 
       
  1249     var self = this;
       
  1250     helper.on("data", function (data, meta) {
       
  1251         if (!self.push(data)) {
       
  1252             self._helper.pause();
       
  1253         }
       
  1254         if(updateCb) {
       
  1255             updateCb(meta);
       
  1256         }
       
  1257     })
       
  1258     .on("error", function(e) {
       
  1259         self.emit('error', e);
       
  1260     })
       
  1261     .on("end", function () {
       
  1262         self.push(null);
       
  1263     });
       
  1264 }
       
  1265 
       
  1266 
       
  1267 NodejsStreamOutputAdapter.prototype._read = function() {
       
  1268     this._helper.resume();
       
  1269 };
       
  1270 
       
  1271 module.exports = NodejsStreamOutputAdapter;
       
  1272 
       
  1273 },{"../utils":32,"readable-stream":16}],14:[function(require,module,exports){
       
  1274 'use strict';
       
  1275 
       
  1276 module.exports = {
       
  1277     /**
       
  1278      * True if this is running in Nodejs, will be undefined in a browser.
       
  1279      * In a browser, browserify won't include this file and the whole module
       
  1280      * will be resolved an empty object.
       
  1281      */
       
  1282     isNode : typeof Buffer !== "undefined",
       
  1283     /**
       
  1284      * Create a new nodejs Buffer from an existing content.
       
  1285      * @param {Object} data the data to pass to the constructor.
       
  1286      * @param {String} encoding the encoding to use.
       
  1287      * @return {Buffer} a new Buffer.
       
  1288      */
       
  1289     newBufferFrom: function(data, encoding) {
       
  1290         // XXX We can't use `Buffer.from` which comes from `Uint8Array.from`
       
  1291         // in nodejs v4 (< v.4.5). It's not the expected implementation (and
       
  1292         // has a different signature).
       
  1293         // see https://github.com/nodejs/node/issues/8053
       
  1294         // A condition on nodejs' version won't solve the issue as we don't
       
  1295         // control the Buffer polyfills that may or may not be used.
       
  1296         return new Buffer(data, encoding);
       
  1297     },
       
  1298     /**
       
  1299      * Create a new nodejs Buffer with the specified size.
       
  1300      * @param {Integer} size the size of the buffer.
       
  1301      * @return {Buffer} a new Buffer.
       
  1302      */
       
  1303     allocBuffer: function (size) {
       
  1304         if (Buffer.alloc) {
       
  1305             return Buffer.alloc(size);
       
  1306         } else {
       
  1307             return new Buffer(size);
       
  1308         }
       
  1309     },
       
  1310     /**
       
  1311      * Find out if an object is a Buffer.
       
  1312      * @param {Object} b the object to test.
       
  1313      * @return {Boolean} true if the object is a Buffer, false otherwise.
       
  1314      */
       
  1315     isBuffer : function(b){
       
  1316         return Buffer.isBuffer(b);
       
  1317     },
       
  1318 
       
  1319     isStream : function (obj) {
       
  1320         return obj &&
       
  1321             typeof obj.on === "function" &&
       
  1322             typeof obj.pause === "function" &&
       
  1323             typeof obj.resume === "function";
       
  1324     }
       
  1325 };
       
  1326 
       
  1327 },{}],15:[function(require,module,exports){
       
  1328 'use strict';
       
  1329 var utf8 = require('./utf8');
       
  1330 var utils = require('./utils');
       
  1331 var GenericWorker = require('./stream/GenericWorker');
       
  1332 var StreamHelper = require('./stream/StreamHelper');
       
  1333 var defaults = require('./defaults');
       
  1334 var CompressedObject = require('./compressedObject');
       
  1335 var ZipObject = require('./zipObject');
       
  1336 var generate = require("./generate");
       
  1337 var nodejsUtils = require("./nodejsUtils");
       
  1338 var NodejsStreamInputAdapter = require("./nodejs/NodejsStreamInputAdapter");
       
  1339 
       
  1340 
       
  1341 /**
       
  1342  * Add a file in the current folder.
       
  1343  * @private
       
  1344  * @param {string} name the name of the file
       
  1345  * @param {String|ArrayBuffer|Uint8Array|Buffer} data the data of the file
       
  1346  * @param {Object} originalOptions the options of the file
       
  1347  * @return {Object} the new file.
       
  1348  */
       
  1349 var fileAdd = function(name, data, originalOptions) {
       
  1350     // be sure sub folders exist
       
  1351     var dataType = utils.getTypeOf(data),
       
  1352         parent;
       
  1353 
       
  1354 
       
  1355     /*
       
  1356      * Correct options.
       
  1357      */
       
  1358 
       
  1359     var o = utils.extend(originalOptions || {}, defaults);
       
  1360     o.date = o.date || new Date();
       
  1361     if (o.compression !== null) {
       
  1362         o.compression = o.compression.toUpperCase();
       
  1363     }
       
  1364 
       
  1365     if (typeof o.unixPermissions === "string") {
       
  1366         o.unixPermissions = parseInt(o.unixPermissions, 8);
       
  1367     }
       
  1368 
       
  1369     // UNX_IFDIR  0040000 see zipinfo.c
       
  1370     if (o.unixPermissions && (o.unixPermissions & 0x4000)) {
       
  1371         o.dir = true;
       
  1372     }
       
  1373     // Bit 4    Directory
       
  1374     if (o.dosPermissions && (o.dosPermissions & 0x0010)) {
       
  1375         o.dir = true;
       
  1376     }
       
  1377 
       
  1378     if (o.dir) {
       
  1379         name = forceTrailingSlash(name);
       
  1380     }
       
  1381     if (o.createFolders && (parent = parentFolder(name))) {
       
  1382         folderAdd.call(this, parent, true);
       
  1383     }
       
  1384 
       
  1385     var isUnicodeString = dataType === "string" && o.binary === false && o.base64 === false;
       
  1386     if (!originalOptions || typeof originalOptions.binary === "undefined") {
       
  1387         o.binary = !isUnicodeString;
       
  1388     }
       
  1389 
       
  1390 
       
  1391     var isCompressedEmpty = (data instanceof CompressedObject) && data.uncompressedSize === 0;
       
  1392 
       
  1393     if (isCompressedEmpty || o.dir || !data || data.length === 0) {
       
  1394         o.base64 = false;
       
  1395         o.binary = true;
       
  1396         data = "";
       
  1397         o.compression = "STORE";
       
  1398         dataType = "string";
       
  1399     }
       
  1400 
       
  1401     /*
       
  1402      * Convert content to fit.
       
  1403      */
       
  1404 
       
  1405     var zipObjectContent = null;
       
  1406     if (data instanceof CompressedObject || data instanceof GenericWorker) {
       
  1407         zipObjectContent = data;
       
  1408     } else if (nodejsUtils.isNode && nodejsUtils.isStream(data)) {
       
  1409         zipObjectContent = new NodejsStreamInputAdapter(name, data);
       
  1410     } else {
       
  1411         zipObjectContent = utils.prepareContent(name, data, o.binary, o.optimizedBinaryString, o.base64);
       
  1412     }
       
  1413 
       
  1414     var object = new ZipObject(name, zipObjectContent, o);
       
  1415     this.files[name] = object;
       
  1416     /*
       
  1417     TODO: we can't throw an exception because we have async promises
       
  1418     (we can have a promise of a Date() for example) but returning a
       
  1419     promise is useless because file(name, data) returns the JSZip
       
  1420     object for chaining. Should we break that to allow the user
       
  1421     to catch the error ?
       
  1422 
       
  1423     return external.Promise.resolve(zipObjectContent)
       
  1424     .then(function () {
       
  1425         return object;
       
  1426     });
       
  1427     */
       
  1428 };
       
  1429 
       
  1430 /**
       
  1431  * Find the parent folder of the path.
       
  1432  * @private
       
  1433  * @param {string} path the path to use
       
  1434  * @return {string} the parent folder, or ""
       
  1435  */
       
  1436 var parentFolder = function (path) {
       
  1437     if (path.slice(-1) === '/') {
       
  1438         path = path.substring(0, path.length - 1);
       
  1439     }
       
  1440     var lastSlash = path.lastIndexOf('/');
       
  1441     return (lastSlash > 0) ? path.substring(0, lastSlash) : "";
       
  1442 };
       
  1443 
       
  1444 /**
       
  1445  * Returns the path with a slash at the end.
       
  1446  * @private
       
  1447  * @param {String} path the path to check.
       
  1448  * @return {String} the path with a trailing slash.
       
  1449  */
       
  1450 var forceTrailingSlash = function(path) {
       
  1451     // Check the name ends with a /
       
  1452     if (path.slice(-1) !== "/") {
       
  1453         path += "/"; // IE doesn't like substr(-1)
       
  1454     }
       
  1455     return path;
       
  1456 };
       
  1457 
       
  1458 /**
       
  1459  * Add a (sub) folder in the current folder.
       
  1460  * @private
       
  1461  * @param {string} name the folder's name
       
  1462  * @param {boolean=} [createFolders] If true, automatically create sub
       
  1463  *  folders. Defaults to false.
       
  1464  * @return {Object} the new folder.
       
  1465  */
       
  1466 var folderAdd = function(name, createFolders) {
       
  1467     createFolders = (typeof createFolders !== 'undefined') ? createFolders : defaults.createFolders;
       
  1468 
       
  1469     name = forceTrailingSlash(name);
       
  1470 
       
  1471     // Does this folder already exist?
       
  1472     if (!this.files[name]) {
       
  1473         fileAdd.call(this, name, null, {
       
  1474             dir: true,
       
  1475             createFolders: createFolders
       
  1476         });
       
  1477     }
       
  1478     return this.files[name];
       
  1479 };
       
  1480 
       
  1481 /**
       
  1482 * Cross-window, cross-Node-context regular expression detection
       
  1483 * @param  {Object}  object Anything
       
  1484 * @return {Boolean}        true if the object is a regular expression,
       
  1485 * false otherwise
       
  1486 */
       
  1487 function isRegExp(object) {
       
  1488     return Object.prototype.toString.call(object) === "[object RegExp]";
       
  1489 }
       
  1490 
       
  1491 // return the actual prototype of JSZip
       
  1492 var out = {
       
  1493     /**
       
  1494      * @see loadAsync
       
  1495      */
       
  1496     load: function() {
       
  1497         throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
       
  1498     },
       
  1499 
       
  1500 
       
  1501     /**
       
  1502      * Call a callback function for each entry at this folder level.
       
  1503      * @param {Function} cb the callback function:
       
  1504      * function (relativePath, file) {...}
       
  1505      * It takes 2 arguments : the relative path and the file.
       
  1506      */
       
  1507     forEach: function(cb) {
       
  1508         var filename, relativePath, file;
       
  1509         for (filename in this.files) {
       
  1510             if (!this.files.hasOwnProperty(filename)) {
       
  1511                 continue;
       
  1512             }
       
  1513             file = this.files[filename];
       
  1514             relativePath = filename.slice(this.root.length, filename.length);
       
  1515             if (relativePath && filename.slice(0, this.root.length) === this.root) { // the file is in the current root
       
  1516                 cb(relativePath, file); // TODO reverse the parameters ? need to be clean AND consistent with the filter search fn...
       
  1517             }
       
  1518         }
       
  1519     },
       
  1520 
       
  1521     /**
       
  1522      * Filter nested files/folders with the specified function.
       
  1523      * @param {Function} search the predicate to use :
       
  1524      * function (relativePath, file) {...}
       
  1525      * It takes 2 arguments : the relative path and the file.
       
  1526      * @return {Array} An array of matching elements.
       
  1527      */
       
  1528     filter: function(search) {
       
  1529         var result = [];
       
  1530         this.forEach(function (relativePath, entry) {
       
  1531             if (search(relativePath, entry)) { // the file matches the function
       
  1532                 result.push(entry);
       
  1533             }
       
  1534 
       
  1535         });
       
  1536         return result;
       
  1537     },
       
  1538 
       
  1539     /**
       
  1540      * Add a file to the zip file, or search a file.
       
  1541      * @param   {string|RegExp} name The name of the file to add (if data is defined),
       
  1542      * the name of the file to find (if no data) or a regex to match files.
       
  1543      * @param   {String|ArrayBuffer|Uint8Array|Buffer} data  The file data, either raw or base64 encoded
       
  1544      * @param   {Object} o     File options
       
  1545      * @return  {JSZip|Object|Array} this JSZip object (when adding a file),
       
  1546      * a file (when searching by string) or an array of files (when searching by regex).
       
  1547      */
       
  1548     file: function(name, data, o) {
       
  1549         if (arguments.length === 1) {
       
  1550             if (isRegExp(name)) {
       
  1551                 var regexp = name;
       
  1552                 return this.filter(function(relativePath, file) {
       
  1553                     return !file.dir && regexp.test(relativePath);
       
  1554                 });
       
  1555             }
       
  1556             else { // text
       
  1557                 var obj = this.files[this.root + name];
       
  1558                 if (obj && !obj.dir) {
       
  1559                     return obj;
       
  1560                 } else {
       
  1561                     return null;
       
  1562                 }
       
  1563             }
       
  1564         }
       
  1565         else { // more than one argument : we have data !
       
  1566             name = this.root + name;
       
  1567             fileAdd.call(this, name, data, o);
       
  1568         }
       
  1569         return this;
       
  1570     },
       
  1571 
       
  1572     /**
       
  1573      * Add a directory to the zip file, or search.
       
  1574      * @param   {String|RegExp} arg The name of the directory to add, or a regex to search folders.
       
  1575      * @return  {JSZip} an object with the new directory as the root, or an array containing matching folders.
       
  1576      */
       
  1577     folder: function(arg) {
       
  1578         if (!arg) {
       
  1579             return this;
       
  1580         }
       
  1581 
       
  1582         if (isRegExp(arg)) {
       
  1583             return this.filter(function(relativePath, file) {
       
  1584                 return file.dir && arg.test(relativePath);
       
  1585             });
       
  1586         }
       
  1587 
       
  1588         // else, name is a new folder
       
  1589         var name = this.root + arg;
       
  1590         var newFolder = folderAdd.call(this, name);
       
  1591 
       
  1592         // Allow chaining by returning a new object with this folder as the root
       
  1593         var ret = this.clone();
       
  1594         ret.root = newFolder.name;
       
  1595         return ret;
       
  1596     },
       
  1597 
       
  1598     /**
       
  1599      * Delete a file, or a directory and all sub-files, from the zip
       
  1600      * @param {string} name the name of the file to delete
       
  1601      * @return {JSZip} this JSZip object
       
  1602      */
       
  1603     remove: function(name) {
       
  1604         name = this.root + name;
       
  1605         var file = this.files[name];
       
  1606         if (!file) {
       
  1607             // Look for any folders
       
  1608             if (name.slice(-1) !== "/") {
       
  1609                 name += "/";
       
  1610             }
       
  1611             file = this.files[name];
       
  1612         }
       
  1613 
       
  1614         if (file && !file.dir) {
       
  1615             // file
       
  1616             delete this.files[name];
       
  1617         } else {
       
  1618             // maybe a folder, delete recursively
       
  1619             var kids = this.filter(function(relativePath, file) {
       
  1620                 return file.name.slice(0, name.length) === name;
       
  1621             });
       
  1622             for (var i = 0; i < kids.length; i++) {
       
  1623                 delete this.files[kids[i].name];
       
  1624             }
       
  1625         }
       
  1626 
       
  1627         return this;
       
  1628     },
       
  1629 
       
  1630     /**
       
  1631      * Generate the complete zip file
       
  1632      * @param {Object} options the options to generate the zip file :
       
  1633      * - compression, "STORE" by default.
       
  1634      * - type, "base64" by default. Values are : string, base64, uint8array, arraybuffer, blob.
       
  1635      * @return {String|Uint8Array|ArrayBuffer|Buffer|Blob} the zip file
       
  1636      */
       
  1637     generate: function(options) {
       
  1638         throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
       
  1639     },
       
  1640 
       
  1641     /**
       
  1642      * Generate the complete zip file as an internal stream.
       
  1643      * @param {Object} options the options to generate the zip file :
       
  1644      * - compression, "STORE" by default.
       
  1645      * - type, "base64" by default. Values are : string, base64, uint8array, arraybuffer, blob.
       
  1646      * @return {StreamHelper} the streamed zip file.
       
  1647      */
       
  1648     generateInternalStream: function(options) {
       
  1649       var worker, opts = {};
       
  1650       try {
       
  1651           opts = utils.extend(options || {}, {
       
  1652               streamFiles: false,
       
  1653               compression: "STORE",
       
  1654               compressionOptions : null,
       
  1655               type: "",
       
  1656               platform: "DOS",
       
  1657               comment: null,
       
  1658               mimeType: 'application/zip',
       
  1659               encodeFileName: utf8.utf8encode
       
  1660           });
       
  1661 
       
  1662           opts.type = opts.type.toLowerCase();
       
  1663           opts.compression = opts.compression.toUpperCase();
       
  1664 
       
  1665           // "binarystring" is prefered but the internals use "string".
       
  1666           if(opts.type === "binarystring") {
       
  1667             opts.type = "string";
       
  1668           }
       
  1669 
       
  1670           if (!opts.type) {
       
  1671             throw new Error("No output type specified.");
       
  1672           }
       
  1673 
       
  1674           utils.checkSupport(opts.type);
       
  1675 
       
  1676           // accept nodejs `process.platform`
       
  1677           if(
       
  1678               opts.platform === 'darwin' ||
       
  1679               opts.platform === 'freebsd' ||
       
  1680               opts.platform === 'linux' ||
       
  1681               opts.platform === 'sunos'
       
  1682           ) {
       
  1683               opts.platform = "UNIX";
       
  1684           }
       
  1685           if (opts.platform === 'win32') {
       
  1686               opts.platform = "DOS";
       
  1687           }
       
  1688 
       
  1689           var comment = opts.comment || this.comment || "";
       
  1690           worker = generate.generateWorker(this, opts, comment);
       
  1691       } catch (e) {
       
  1692         worker = new GenericWorker("error");
       
  1693         worker.error(e);
       
  1694       }
       
  1695       return new StreamHelper(worker, opts.type || "string", opts.mimeType);
       
  1696     },
       
  1697     /**
       
  1698      * Generate the complete zip file asynchronously.
       
  1699      * @see generateInternalStream
       
  1700      */
       
  1701     generateAsync: function(options, onUpdate) {
       
  1702         return this.generateInternalStream(options).accumulate(onUpdate);
       
  1703     },
       
  1704     /**
       
  1705      * Generate the complete zip file asynchronously.
       
  1706      * @see generateInternalStream
       
  1707      */
       
  1708     generateNodeStream: function(options, onUpdate) {
       
  1709         options = options || {};
       
  1710         if (!options.type) {
       
  1711             options.type = "nodebuffer";
       
  1712         }
       
  1713         return this.generateInternalStream(options).toNodejsStream(onUpdate);
       
  1714     }
       
  1715 };
       
  1716 module.exports = out;
       
  1717 
       
  1718 },{"./compressedObject":2,"./defaults":5,"./generate":9,"./nodejs/NodejsStreamInputAdapter":12,"./nodejsUtils":14,"./stream/GenericWorker":28,"./stream/StreamHelper":29,"./utf8":31,"./utils":32,"./zipObject":35}],16:[function(require,module,exports){
       
  1719 /*
       
  1720  * This file is used by module bundlers (browserify/webpack/etc) when
       
  1721  * including a stream implementation. We use "readable-stream" to get a
       
  1722  * consistent behavior between nodejs versions but bundlers often have a shim
       
  1723  * for "stream". Using this shim greatly improve the compatibility and greatly
       
  1724  * reduce the final size of the bundle (only one stream implementation, not
       
  1725  * two).
       
  1726  */
       
  1727 module.exports = require("stream");
       
  1728 
       
  1729 },{"stream":undefined}],17:[function(require,module,exports){
       
  1730 'use strict';
       
  1731 var DataReader = require('./DataReader');
       
  1732 var utils = require('../utils');
       
  1733 
       
  1734 function ArrayReader(data) {
       
  1735     DataReader.call(this, data);
       
  1736 	for(var i = 0; i < this.data.length; i++) {
       
  1737 		data[i] = data[i] & 0xFF;
       
  1738 	}
       
  1739 }
       
  1740 utils.inherits(ArrayReader, DataReader);
       
  1741 /**
       
  1742  * @see DataReader.byteAt
       
  1743  */
       
  1744 ArrayReader.prototype.byteAt = function(i) {
       
  1745     return this.data[this.zero + i];
       
  1746 };
       
  1747 /**
       
  1748  * @see DataReader.lastIndexOfSignature
       
  1749  */
       
  1750 ArrayReader.prototype.lastIndexOfSignature = function(sig) {
       
  1751     var sig0 = sig.charCodeAt(0),
       
  1752         sig1 = sig.charCodeAt(1),
       
  1753         sig2 = sig.charCodeAt(2),
       
  1754         sig3 = sig.charCodeAt(3);
       
  1755     for (var i = this.length - 4; i >= 0; --i) {
       
  1756         if (this.data[i] === sig0 && this.data[i + 1] === sig1 && this.data[i + 2] === sig2 && this.data[i + 3] === sig3) {
       
  1757             return i - this.zero;
       
  1758         }
       
  1759     }
       
  1760 
       
  1761     return -1;
       
  1762 };
       
  1763 /**
       
  1764  * @see DataReader.readAndCheckSignature
       
  1765  */
       
  1766 ArrayReader.prototype.readAndCheckSignature = function (sig) {
       
  1767     var sig0 = sig.charCodeAt(0),
       
  1768         sig1 = sig.charCodeAt(1),
       
  1769         sig2 = sig.charCodeAt(2),
       
  1770         sig3 = sig.charCodeAt(3),
       
  1771         data = this.readData(4);
       
  1772     return sig0 === data[0] && sig1 === data[1] && sig2 === data[2] && sig3 === data[3];
       
  1773 };
       
  1774 /**
       
  1775  * @see DataReader.readData
       
  1776  */
       
  1777 ArrayReader.prototype.readData = function(size) {
       
  1778     this.checkOffset(size);
       
  1779     if(size === 0) {
       
  1780         return [];
       
  1781     }
       
  1782     var result = this.data.slice(this.zero + this.index, this.zero + this.index + size);
       
  1783     this.index += size;
       
  1784     return result;
       
  1785 };
       
  1786 module.exports = ArrayReader;
       
  1787 
       
  1788 },{"../utils":32,"./DataReader":18}],18:[function(require,module,exports){
       
  1789 'use strict';
       
  1790 var utils = require('../utils');
       
  1791 
       
  1792 function DataReader(data) {
       
  1793     this.data = data; // type : see implementation
       
  1794     this.length = data.length;
       
  1795     this.index = 0;
       
  1796     this.zero = 0;
       
  1797 }
       
  1798 DataReader.prototype = {
       
  1799     /**
       
  1800      * Check that the offset will not go too far.
       
  1801      * @param {string} offset the additional offset to check.
       
  1802      * @throws {Error} an Error if the offset is out of bounds.
       
  1803      */
       
  1804     checkOffset: function(offset) {
       
  1805         this.checkIndex(this.index + offset);
       
  1806     },
       
  1807     /**
       
  1808      * Check that the specified index will not be too far.
       
  1809      * @param {string} newIndex the index to check.
       
  1810      * @throws {Error} an Error if the index is out of bounds.
       
  1811      */
       
  1812     checkIndex: function(newIndex) {
       
  1813         if (this.length < this.zero + newIndex || newIndex < 0) {
       
  1814             throw new Error("End of data reached (data length = " + this.length + ", asked index = " + (newIndex) + "). Corrupted zip ?");
       
  1815         }
       
  1816     },
       
  1817     /**
       
  1818      * Change the index.
       
  1819      * @param {number} newIndex The new index.
       
  1820      * @throws {Error} if the new index is out of the data.
       
  1821      */
       
  1822     setIndex: function(newIndex) {
       
  1823         this.checkIndex(newIndex);
       
  1824         this.index = newIndex;
       
  1825     },
       
  1826     /**
       
  1827      * Skip the next n bytes.
       
  1828      * @param {number} n the number of bytes to skip.
       
  1829      * @throws {Error} if the new index is out of the data.
       
  1830      */
       
  1831     skip: function(n) {
       
  1832         this.setIndex(this.index + n);
       
  1833     },
       
  1834     /**
       
  1835      * Get the byte at the specified index.
       
  1836      * @param {number} i the index to use.
       
  1837      * @return {number} a byte.
       
  1838      */
       
  1839     byteAt: function(i) {
       
  1840         // see implementations
       
  1841     },
       
  1842     /**
       
  1843      * Get the next number with a given byte size.
       
  1844      * @param {number} size the number of bytes to read.
       
  1845      * @return {number} the corresponding number.
       
  1846      */
       
  1847     readInt: function(size) {
       
  1848         var result = 0,
       
  1849             i;
       
  1850         this.checkOffset(size);
       
  1851         for (i = this.index + size - 1; i >= this.index; i--) {
       
  1852             result = (result << 8) + this.byteAt(i);
       
  1853         }
       
  1854         this.index += size;
       
  1855         return result;
       
  1856     },
       
  1857     /**
       
  1858      * Get the next string with a given byte size.
       
  1859      * @param {number} size the number of bytes to read.
       
  1860      * @return {string} the corresponding string.
       
  1861      */
       
  1862     readString: function(size) {
       
  1863         return utils.transformTo("string", this.readData(size));
       
  1864     },
       
  1865     /**
       
  1866      * Get raw data without conversion, <size> bytes.
       
  1867      * @param {number} size the number of bytes to read.
       
  1868      * @return {Object} the raw data, implementation specific.
       
  1869      */
       
  1870     readData: function(size) {
       
  1871         // see implementations
       
  1872     },
       
  1873     /**
       
  1874      * Find the last occurence of a zip signature (4 bytes).
       
  1875      * @param {string} sig the signature to find.
       
  1876      * @return {number} the index of the last occurence, -1 if not found.
       
  1877      */
       
  1878     lastIndexOfSignature: function(sig) {
       
  1879         // see implementations
       
  1880     },
       
  1881     /**
       
  1882      * Read the signature (4 bytes) at the current position and compare it with sig.
       
  1883      * @param {string} sig the expected signature
       
  1884      * @return {boolean} true if the signature matches, false otherwise.
       
  1885      */
       
  1886     readAndCheckSignature: function(sig) {
       
  1887         // see implementations
       
  1888     },
       
  1889     /**
       
  1890      * Get the next date.
       
  1891      * @return {Date} the date.
       
  1892      */
       
  1893     readDate: function() {
       
  1894         var dostime = this.readInt(4);
       
  1895         return new Date(Date.UTC(
       
  1896         ((dostime >> 25) & 0x7f) + 1980, // year
       
  1897         ((dostime >> 21) & 0x0f) - 1, // month
       
  1898         (dostime >> 16) & 0x1f, // day
       
  1899         (dostime >> 11) & 0x1f, // hour
       
  1900         (dostime >> 5) & 0x3f, // minute
       
  1901         (dostime & 0x1f) << 1)); // second
       
  1902     }
       
  1903 };
       
  1904 module.exports = DataReader;
       
  1905 
       
  1906 },{"../utils":32}],19:[function(require,module,exports){
       
  1907 'use strict';
       
  1908 var Uint8ArrayReader = require('./Uint8ArrayReader');
       
  1909 var utils = require('../utils');
       
  1910 
       
  1911 function NodeBufferReader(data) {
       
  1912     Uint8ArrayReader.call(this, data);
       
  1913 }
       
  1914 utils.inherits(NodeBufferReader, Uint8ArrayReader);
       
  1915 
       
  1916 /**
       
  1917  * @see DataReader.readData
       
  1918  */
       
  1919 NodeBufferReader.prototype.readData = function(size) {
       
  1920     this.checkOffset(size);
       
  1921     var result = this.data.slice(this.zero + this.index, this.zero + this.index + size);
       
  1922     this.index += size;
       
  1923     return result;
       
  1924 };
       
  1925 module.exports = NodeBufferReader;
       
  1926 
       
  1927 },{"../utils":32,"./Uint8ArrayReader":21}],20:[function(require,module,exports){
       
  1928 'use strict';
       
  1929 var DataReader = require('./DataReader');
       
  1930 var utils = require('../utils');
       
  1931 
       
  1932 function StringReader(data) {
       
  1933     DataReader.call(this, data);
       
  1934 }
       
  1935 utils.inherits(StringReader, DataReader);
       
  1936 /**
       
  1937  * @see DataReader.byteAt
       
  1938  */
       
  1939 StringReader.prototype.byteAt = function(i) {
       
  1940     return this.data.charCodeAt(this.zero + i);
       
  1941 };
       
  1942 /**
       
  1943  * @see DataReader.lastIndexOfSignature
       
  1944  */
       
  1945 StringReader.prototype.lastIndexOfSignature = function(sig) {
       
  1946     return this.data.lastIndexOf(sig) - this.zero;
       
  1947 };
       
  1948 /**
       
  1949  * @see DataReader.readAndCheckSignature
       
  1950  */
       
  1951 StringReader.prototype.readAndCheckSignature = function (sig) {
       
  1952     var data = this.readData(4);
       
  1953     return sig === data;
       
  1954 };
       
  1955 /**
       
  1956  * @see DataReader.readData
       
  1957  */
       
  1958 StringReader.prototype.readData = function(size) {
       
  1959     this.checkOffset(size);
       
  1960     // this will work because the constructor applied the "& 0xff" mask.
       
  1961     var result = this.data.slice(this.zero + this.index, this.zero + this.index + size);
       
  1962     this.index += size;
       
  1963     return result;
       
  1964 };
       
  1965 module.exports = StringReader;
       
  1966 
       
  1967 },{"../utils":32,"./DataReader":18}],21:[function(require,module,exports){
       
  1968 'use strict';
       
  1969 var ArrayReader = require('./ArrayReader');
       
  1970 var utils = require('../utils');
       
  1971 
       
  1972 function Uint8ArrayReader(data) {
       
  1973     ArrayReader.call(this, data);
       
  1974 }
       
  1975 utils.inherits(Uint8ArrayReader, ArrayReader);
       
  1976 /**
       
  1977  * @see DataReader.readData
       
  1978  */
       
  1979 Uint8ArrayReader.prototype.readData = function(size) {
       
  1980     this.checkOffset(size);
       
  1981     if(size === 0) {
       
  1982         // in IE10, when using subarray(idx, idx), we get the array [0x00] instead of [].
       
  1983         return new Uint8Array(0);
       
  1984     }
       
  1985     var result = this.data.subarray(this.zero + this.index, this.zero + this.index + size);
       
  1986     this.index += size;
       
  1987     return result;
       
  1988 };
       
  1989 module.exports = Uint8ArrayReader;
       
  1990 
       
  1991 },{"../utils":32,"./ArrayReader":17}],22:[function(require,module,exports){
       
  1992 'use strict';
       
  1993 
       
  1994 var utils = require('../utils');
       
  1995 var support = require('../support');
       
  1996 var ArrayReader = require('./ArrayReader');
       
  1997 var StringReader = require('./StringReader');
       
  1998 var NodeBufferReader = require('./NodeBufferReader');
       
  1999 var Uint8ArrayReader = require('./Uint8ArrayReader');
       
  2000 
       
  2001 /**
       
  2002  * Create a reader adapted to the data.
       
  2003  * @param {String|ArrayBuffer|Uint8Array|Buffer} data the data to read.
       
  2004  * @return {DataReader} the data reader.
       
  2005  */
       
  2006 module.exports = function (data) {
       
  2007     var type = utils.getTypeOf(data);
       
  2008     utils.checkSupport(type);
       
  2009     if (type === "string" && !support.uint8array) {
       
  2010         return new StringReader(data);
       
  2011     }
       
  2012     if (type === "nodebuffer") {
       
  2013         return new NodeBufferReader(data);
       
  2014     }
       
  2015     if (support.uint8array) {
       
  2016         return new Uint8ArrayReader(utils.transformTo("uint8array", data));
       
  2017     }
       
  2018     return new ArrayReader(utils.transformTo("array", data));
       
  2019 };
       
  2020 
       
  2021 },{"../support":30,"../utils":32,"./ArrayReader":17,"./NodeBufferReader":19,"./StringReader":20,"./Uint8ArrayReader":21}],23:[function(require,module,exports){
       
  2022 'use strict';
       
  2023 exports.LOCAL_FILE_HEADER = "PK\x03\x04";
       
  2024 exports.CENTRAL_FILE_HEADER = "PK\x01\x02";
       
  2025 exports.CENTRAL_DIRECTORY_END = "PK\x05\x06";
       
  2026 exports.ZIP64_CENTRAL_DIRECTORY_LOCATOR = "PK\x06\x07";
       
  2027 exports.ZIP64_CENTRAL_DIRECTORY_END = "PK\x06\x06";
       
  2028 exports.DATA_DESCRIPTOR = "PK\x07\x08";
       
  2029 
       
  2030 },{}],24:[function(require,module,exports){
       
  2031 'use strict';
       
  2032 
       
  2033 var GenericWorker = require('./GenericWorker');
       
  2034 var utils = require('../utils');
       
  2035 
       
  2036 /**
       
  2037  * A worker which convert chunks to a specified type.
       
  2038  * @constructor
       
  2039  * @param {String} destType the destination type.
       
  2040  */
       
  2041 function ConvertWorker(destType) {
       
  2042     GenericWorker.call(this, "ConvertWorker to " + destType);
       
  2043     this.destType = destType;
       
  2044 }
       
  2045 utils.inherits(ConvertWorker, GenericWorker);
       
  2046 
       
  2047 /**
       
  2048  * @see GenericWorker.processChunk
       
  2049  */
       
  2050 ConvertWorker.prototype.processChunk = function (chunk) {
       
  2051     this.push({
       
  2052         data : utils.transformTo(this.destType, chunk.data),
       
  2053         meta : chunk.meta
       
  2054     });
       
  2055 };
       
  2056 module.exports = ConvertWorker;
       
  2057 
       
  2058 },{"../utils":32,"./GenericWorker":28}],25:[function(require,module,exports){
       
  2059 'use strict';
       
  2060 
       
  2061 var GenericWorker = require('./GenericWorker');
       
  2062 var crc32 = require('../crc32');
       
  2063 var utils = require('../utils');
       
  2064 
       
  2065 /**
       
  2066  * A worker which calculate the crc32 of the data flowing through.
       
  2067  * @constructor
       
  2068  */
       
  2069 function Crc32Probe() {
       
  2070     GenericWorker.call(this, "Crc32Probe");
       
  2071     this.withStreamInfo("crc32", 0);
       
  2072 }
       
  2073 utils.inherits(Crc32Probe, GenericWorker);
       
  2074 
       
  2075 /**
       
  2076  * @see GenericWorker.processChunk
       
  2077  */
       
  2078 Crc32Probe.prototype.processChunk = function (chunk) {
       
  2079     this.streamInfo.crc32 = crc32(chunk.data, this.streamInfo.crc32 || 0);
       
  2080     this.push(chunk);
       
  2081 };
       
  2082 module.exports = Crc32Probe;
       
  2083 
       
  2084 },{"../crc32":4,"../utils":32,"./GenericWorker":28}],26:[function(require,module,exports){
       
  2085 'use strict';
       
  2086 
       
  2087 var utils = require('../utils');
       
  2088 var GenericWorker = require('./GenericWorker');
       
  2089 
       
  2090 /**
       
  2091  * A worker which calculate the total length of the data flowing through.
       
  2092  * @constructor
       
  2093  * @param {String} propName the name used to expose the length
       
  2094  */
       
  2095 function DataLengthProbe(propName) {
       
  2096     GenericWorker.call(this, "DataLengthProbe for " + propName);
       
  2097     this.propName = propName;
       
  2098     this.withStreamInfo(propName, 0);
       
  2099 }
       
  2100 utils.inherits(DataLengthProbe, GenericWorker);
       
  2101 
       
  2102 /**
       
  2103  * @see GenericWorker.processChunk
       
  2104  */
       
  2105 DataLengthProbe.prototype.processChunk = function (chunk) {
       
  2106     if(chunk) {
       
  2107         var length = this.streamInfo[this.propName] || 0;
       
  2108         this.streamInfo[this.propName] = length + chunk.data.length;
       
  2109     }
       
  2110     GenericWorker.prototype.processChunk.call(this, chunk);
       
  2111 };
       
  2112 module.exports = DataLengthProbe;
       
  2113 
       
  2114 
       
  2115 },{"../utils":32,"./GenericWorker":28}],27:[function(require,module,exports){
       
  2116 'use strict';
       
  2117 
       
  2118 var utils = require('../utils');
       
  2119 var GenericWorker = require('./GenericWorker');
       
  2120 
       
  2121 // the size of the generated chunks
       
  2122 // TODO expose this as a public variable
       
  2123 var DEFAULT_BLOCK_SIZE = 16 * 1024;
       
  2124 
       
  2125 /**
       
  2126  * A worker that reads a content and emits chunks.
       
  2127  * @constructor
       
  2128  * @param {Promise} dataP the promise of the data to split
       
  2129  */
       
  2130 function DataWorker(dataP) {
       
  2131     GenericWorker.call(this, "DataWorker");
       
  2132     var self = this;
       
  2133     this.dataIsReady = false;
       
  2134     this.index = 0;
       
  2135     this.max = 0;
       
  2136     this.data = null;
       
  2137     this.type = "";
       
  2138 
       
  2139     this._tickScheduled = false;
       
  2140 
       
  2141     dataP.then(function (data) {
       
  2142         self.dataIsReady = true;
       
  2143         self.data = data;
       
  2144         self.max = data && data.length || 0;
       
  2145         self.type = utils.getTypeOf(data);
       
  2146         if(!self.isPaused) {
       
  2147             self._tickAndRepeat();
       
  2148         }
       
  2149     }, function (e) {
       
  2150         self.error(e);
       
  2151     });
       
  2152 }
       
  2153 
       
  2154 utils.inherits(DataWorker, GenericWorker);
       
  2155 
       
  2156 /**
       
  2157  * @see GenericWorker.cleanUp
       
  2158  */
       
  2159 DataWorker.prototype.cleanUp = function () {
       
  2160     GenericWorker.prototype.cleanUp.call(this);
       
  2161     this.data = null;
       
  2162 };
       
  2163 
       
  2164 /**
       
  2165  * @see GenericWorker.resume
       
  2166  */
       
  2167 DataWorker.prototype.resume = function () {
       
  2168     if(!GenericWorker.prototype.resume.call(this)) {
       
  2169         return false;
       
  2170     }
       
  2171 
       
  2172     if (!this._tickScheduled && this.dataIsReady) {
       
  2173         this._tickScheduled = true;
       
  2174         utils.delay(this._tickAndRepeat, [], this);
       
  2175     }
       
  2176     return true;
       
  2177 };
       
  2178 
       
  2179 /**
       
  2180  * Trigger a tick a schedule an other call to this function.
       
  2181  */
       
  2182 DataWorker.prototype._tickAndRepeat = function() {
       
  2183     this._tickScheduled = false;
       
  2184     if(this.isPaused || this.isFinished) {
       
  2185         return;
       
  2186     }
       
  2187     this._tick();
       
  2188     if(!this.isFinished) {
       
  2189         utils.delay(this._tickAndRepeat, [], this);
       
  2190         this._tickScheduled = true;
       
  2191     }
       
  2192 };
       
  2193 
       
  2194 /**
       
  2195  * Read and push a chunk.
       
  2196  */
       
  2197 DataWorker.prototype._tick = function() {
       
  2198 
       
  2199     if(this.isPaused || this.isFinished) {
       
  2200         return false;
       
  2201     }
       
  2202 
       
  2203     var size = DEFAULT_BLOCK_SIZE;
       
  2204     var data = null, nextIndex = Math.min(this.max, this.index + size);
       
  2205     if (this.index >= this.max) {
       
  2206         // EOF
       
  2207         return this.end();
       
  2208     } else {
       
  2209         switch(this.type) {
       
  2210             case "string":
       
  2211                 data = this.data.substring(this.index, nextIndex);
       
  2212             break;
       
  2213             case "uint8array":
       
  2214                 data = this.data.subarray(this.index, nextIndex);
       
  2215             break;
       
  2216             case "array":
       
  2217             case "nodebuffer":
       
  2218                 data = this.data.slice(this.index, nextIndex);
       
  2219             break;
       
  2220         }
       
  2221         this.index = nextIndex;
       
  2222         return this.push({
       
  2223             data : data,
       
  2224             meta : {
       
  2225                 percent : this.max ? this.index / this.max * 100 : 0
       
  2226             }
       
  2227         });
       
  2228     }
       
  2229 };
       
  2230 
       
  2231 module.exports = DataWorker;
       
  2232 
       
  2233 },{"../utils":32,"./GenericWorker":28}],28:[function(require,module,exports){
       
  2234 'use strict';
       
  2235 
       
  2236 /**
       
  2237  * A worker that does nothing but passing chunks to the next one. This is like
       
  2238  * a nodejs stream but with some differences. On the good side :
       
  2239  * - it works on IE 6-9 without any issue / polyfill
       
  2240  * - it weights less than the full dependencies bundled with browserify
       
  2241  * - it forwards errors (no need to declare an error handler EVERYWHERE)
       
  2242  *
       
  2243  * A chunk is an object with 2 attributes : `meta` and `data`. The former is an
       
  2244  * object containing anything (`percent` for example), see each worker for more
       
  2245  * details. The latter is the real data (String, Uint8Array, etc).
       
  2246  *
       
  2247  * @constructor
       
  2248  * @param {String} name the name of the stream (mainly used for debugging purposes)
       
  2249  */
       
  2250 function GenericWorker(name) {
       
  2251     // the name of the worker
       
  2252     this.name = name || "default";
       
  2253     // an object containing metadata about the workers chain
       
  2254     this.streamInfo = {};
       
  2255     // an error which happened when the worker was paused
       
  2256     this.generatedError = null;
       
  2257     // an object containing metadata to be merged by this worker into the general metadata
       
  2258     this.extraStreamInfo = {};
       
  2259     // true if the stream is paused (and should not do anything), false otherwise
       
  2260     this.isPaused = true;
       
  2261     // true if the stream is finished (and should not do anything), false otherwise
       
  2262     this.isFinished = false;
       
  2263     // true if the stream is locked to prevent further structure updates (pipe), false otherwise
       
  2264     this.isLocked = false;
       
  2265     // the event listeners
       
  2266     this._listeners = {
       
  2267         'data':[],
       
  2268         'end':[],
       
  2269         'error':[]
       
  2270     };
       
  2271     // the previous worker, if any
       
  2272     this.previous = null;
       
  2273 }
       
  2274 
       
  2275 GenericWorker.prototype = {
       
  2276     /**
       
  2277      * Push a chunk to the next workers.
       
  2278      * @param {Object} chunk the chunk to push
       
  2279      */
       
  2280     push : function (chunk) {
       
  2281         this.emit("data", chunk);
       
  2282     },
       
  2283     /**
       
  2284      * End the stream.
       
  2285      * @return {Boolean} true if this call ended the worker, false otherwise.
       
  2286      */
       
  2287     end : function () {
       
  2288         if (this.isFinished) {
       
  2289             return false;
       
  2290         }
       
  2291 
       
  2292         this.flush();
       
  2293         try {
       
  2294             this.emit("end");
       
  2295             this.cleanUp();
       
  2296             this.isFinished = true;
       
  2297         } catch (e) {
       
  2298             this.emit("error", e);
       
  2299         }
       
  2300         return true;
       
  2301     },
       
  2302     /**
       
  2303      * End the stream with an error.
       
  2304      * @param {Error} e the error which caused the premature end.
       
  2305      * @return {Boolean} true if this call ended the worker with an error, false otherwise.
       
  2306      */
       
  2307     error : function (e) {
       
  2308         if (this.isFinished) {
       
  2309             return false;
       
  2310         }
       
  2311 
       
  2312         if(this.isPaused) {
       
  2313             this.generatedError = e;
       
  2314         } else {
       
  2315             this.isFinished = true;
       
  2316 
       
  2317             this.emit("error", e);
       
  2318 
       
  2319             // in the workers chain exploded in the middle of the chain,
       
  2320             // the error event will go downward but we also need to notify
       
  2321             // workers upward that there has been an error.
       
  2322             if(this.previous) {
       
  2323                 this.previous.error(e);
       
  2324             }
       
  2325 
       
  2326             this.cleanUp();
       
  2327         }
       
  2328         return true;
       
  2329     },
       
  2330     /**
       
  2331      * Add a callback on an event.
       
  2332      * @param {String} name the name of the event (data, end, error)
       
  2333      * @param {Function} listener the function to call when the event is triggered
       
  2334      * @return {GenericWorker} the current object for chainability
       
  2335      */
       
  2336     on : function (name, listener) {
       
  2337         this._listeners[name].push(listener);
       
  2338         return this;
       
  2339     },
       
  2340     /**
       
  2341      * Clean any references when a worker is ending.
       
  2342      */
       
  2343     cleanUp : function () {
       
  2344         this.streamInfo = this.generatedError = this.extraStreamInfo = null;
       
  2345         this._listeners = [];
       
  2346     },
       
  2347     /**
       
  2348      * Trigger an event. This will call registered callback with the provided arg.
       
  2349      * @param {String} name the name of the event (data, end, error)
       
  2350      * @param {Object} arg the argument to call the callback with.
       
  2351      */
       
  2352     emit : function (name, arg) {
       
  2353         if (this._listeners[name]) {
       
  2354             for(var i = 0; i < this._listeners[name].length; i++) {
       
  2355                 this._listeners[name][i].call(this, arg);
       
  2356             }
       
  2357         }
       
  2358     },
       
  2359     /**
       
  2360      * Chain a worker with an other.
       
  2361      * @param {Worker} next the worker receiving events from the current one.
       
  2362      * @return {worker} the next worker for chainability
       
  2363      */
       
  2364     pipe : function (next) {
       
  2365         return next.registerPrevious(this);
       
  2366     },
       
  2367     /**
       
  2368      * Same as `pipe` in the other direction.
       
  2369      * Using an API with `pipe(next)` is very easy.
       
  2370      * Implementing the API with the point of view of the next one registering
       
  2371      * a source is easier, see the ZipFileWorker.
       
  2372      * @param {Worker} previous the previous worker, sending events to this one
       
  2373      * @return {Worker} the current worker for chainability
       
  2374      */
       
  2375     registerPrevious : function (previous) {
       
  2376         if (this.isLocked) {
       
  2377             throw new Error("The stream '" + this + "' has already been used.");
       
  2378         }
       
  2379 
       
  2380         // sharing the streamInfo...
       
  2381         this.streamInfo = previous.streamInfo;
       
  2382         // ... and adding our own bits
       
  2383         this.mergeStreamInfo();
       
  2384         this.previous =  previous;
       
  2385         var self = this;
       
  2386         previous.on('data', function (chunk) {
       
  2387             self.processChunk(chunk);
       
  2388         });
       
  2389         previous.on('end', function () {
       
  2390             self.end();
       
  2391         });
       
  2392         previous.on('error', function (e) {
       
  2393             self.error(e);
       
  2394         });
       
  2395         return this;
       
  2396     },
       
  2397     /**
       
  2398      * Pause the stream so it doesn't send events anymore.
       
  2399      * @return {Boolean} true if this call paused the worker, false otherwise.
       
  2400      */
       
  2401     pause : function () {
       
  2402         if(this.isPaused || this.isFinished) {
       
  2403             return false;
       
  2404         }
       
  2405         this.isPaused = true;
       
  2406 
       
  2407         if(this.previous) {
       
  2408             this.previous.pause();
       
  2409         }
       
  2410         return true;
       
  2411     },
       
  2412     /**
       
  2413      * Resume a paused stream.
       
  2414      * @return {Boolean} true if this call resumed the worker, false otherwise.
       
  2415      */
       
  2416     resume : function () {
       
  2417         if(!this.isPaused || this.isFinished) {
       
  2418             return false;
       
  2419         }
       
  2420         this.isPaused = false;
       
  2421 
       
  2422         // if true, the worker tried to resume but failed
       
  2423         var withError = false;
       
  2424         if(this.generatedError) {
       
  2425             this.error(this.generatedError);
       
  2426             withError = true;
       
  2427         }
       
  2428         if(this.previous) {
       
  2429             this.previous.resume();
       
  2430         }
       
  2431 
       
  2432         return !withError;
       
  2433     },
       
  2434     /**
       
  2435      * Flush any remaining bytes as the stream is ending.
       
  2436      */
       
  2437     flush : function () {},
       
  2438     /**
       
  2439      * Process a chunk. This is usually the method overridden.
       
  2440      * @param {Object} chunk the chunk to process.
       
  2441      */
       
  2442     processChunk : function(chunk) {
       
  2443         this.push(chunk);
       
  2444     },
       
  2445     /**
       
  2446      * Add a key/value to be added in the workers chain streamInfo once activated.
       
  2447      * @param {String} key the key to use
       
  2448      * @param {Object} value the associated value
       
  2449      * @return {Worker} the current worker for chainability
       
  2450      */
       
  2451     withStreamInfo : function (key, value) {
       
  2452         this.extraStreamInfo[key] = value;
       
  2453         this.mergeStreamInfo();
       
  2454         return this;
       
  2455     },
       
  2456     /**
       
  2457      * Merge this worker's streamInfo into the chain's streamInfo.
       
  2458      */
       
  2459     mergeStreamInfo : function () {
       
  2460         for(var key in this.extraStreamInfo) {
       
  2461             if (!this.extraStreamInfo.hasOwnProperty(key)) {
       
  2462                 continue;
       
  2463             }
       
  2464             this.streamInfo[key] = this.extraStreamInfo[key];
       
  2465         }
       
  2466     },
       
  2467 
       
  2468     /**
       
  2469      * Lock the stream to prevent further updates on the workers chain.
       
  2470      * After calling this method, all calls to pipe will fail.
       
  2471      */
       
  2472     lock: function () {
       
  2473         if (this.isLocked) {
       
  2474             throw new Error("The stream '" + this + "' has already been used.");
       
  2475         }
       
  2476         this.isLocked = true;
       
  2477         if (this.previous) {
       
  2478             this.previous.lock();
       
  2479         }
       
  2480     },
       
  2481 
       
  2482     /**
       
  2483      *
       
  2484      * Pretty print the workers chain.
       
  2485      */
       
  2486     toString : function () {
       
  2487         var me = "Worker " + this.name;
       
  2488         if (this.previous) {
       
  2489             return this.previous + " -> " + me;
       
  2490         } else {
       
  2491             return me;
       
  2492         }
       
  2493     }
       
  2494 };
       
  2495 
       
  2496 module.exports = GenericWorker;
       
  2497 
       
  2498 },{}],29:[function(require,module,exports){
       
  2499 'use strict';
       
  2500 
       
  2501 var utils = require('../utils');
       
  2502 var ConvertWorker = require('./ConvertWorker');
       
  2503 var GenericWorker = require('./GenericWorker');
       
  2504 var base64 = require('../base64');
       
  2505 var support = require("../support");
       
  2506 var external = require("../external");
       
  2507 
       
  2508 var NodejsStreamOutputAdapter = null;
       
  2509 if (support.nodestream) {
       
  2510     try {
       
  2511         NodejsStreamOutputAdapter = require('../nodejs/NodejsStreamOutputAdapter');
       
  2512     } catch(e) {}
       
  2513 }
       
  2514 
       
  2515 /**
       
  2516  * Apply the final transformation of the data. If the user wants a Blob for
       
  2517  * example, it's easier to work with an U8intArray and finally do the
       
  2518  * ArrayBuffer/Blob conversion.
       
  2519  * @param {String} type the name of the final type
       
  2520  * @param {String|Uint8Array|Buffer} content the content to transform
       
  2521  * @param {String} mimeType the mime type of the content, if applicable.
       
  2522  * @return {String|Uint8Array|ArrayBuffer|Buffer|Blob} the content in the right format.
       
  2523  */
       
  2524 function transformZipOutput(type, content, mimeType) {
       
  2525     switch(type) {
       
  2526         case "blob" :
       
  2527             return utils.newBlob(utils.transformTo("arraybuffer", content), mimeType);
       
  2528         case "base64" :
       
  2529             return base64.encode(content);
       
  2530         default :
       
  2531             return utils.transformTo(type, content);
       
  2532     }
       
  2533 }
       
  2534 
       
  2535 /**
       
  2536  * Concatenate an array of data of the given type.
       
  2537  * @param {String} type the type of the data in the given array.
       
  2538  * @param {Array} dataArray the array containing the data chunks to concatenate
       
  2539  * @return {String|Uint8Array|Buffer} the concatenated data
       
  2540  * @throws Error if the asked type is unsupported
       
  2541  */
       
  2542 function concat (type, dataArray) {
       
  2543     var i, index = 0, res = null, totalLength = 0;
       
  2544     for(i = 0; i < dataArray.length; i++) {
       
  2545         totalLength += dataArray[i].length;
       
  2546     }
       
  2547     switch(type) {
       
  2548         case "string":
       
  2549             return dataArray.join("");
       
  2550           case "array":
       
  2551             return Array.prototype.concat.apply([], dataArray);
       
  2552         case "uint8array":
       
  2553             res = new Uint8Array(totalLength);
       
  2554             for(i = 0; i < dataArray.length; i++) {
       
  2555                 res.set(dataArray[i], index);
       
  2556                 index += dataArray[i].length;
       
  2557             }
       
  2558             return res;
       
  2559         case "nodebuffer":
       
  2560             return Buffer.concat(dataArray);
       
  2561         default:
       
  2562             throw new Error("concat : unsupported type '"  + type + "'");
       
  2563     }
       
  2564 }
       
  2565 
       
  2566 /**
       
  2567  * Listen a StreamHelper, accumulate its content and concatenate it into a
       
  2568  * complete block.
       
  2569  * @param {StreamHelper} helper the helper to use.
       
  2570  * @param {Function} updateCallback a callback called on each update. Called
       
  2571  * with one arg :
       
  2572  * - the metadata linked to the update received.
       
  2573  * @return Promise the promise for the accumulation.
       
  2574  */
       
  2575 function accumulate(helper, updateCallback) {
       
  2576     return new external.Promise(function (resolve, reject){
       
  2577         var dataArray = [];
       
  2578         var chunkType = helper._internalType,
       
  2579             resultType = helper._outputType,
       
  2580             mimeType = helper._mimeType;
       
  2581         helper
       
  2582         .on('data', function (data, meta) {
       
  2583             dataArray.push(data);
       
  2584             if(updateCallback) {
       
  2585                 updateCallback(meta);
       
  2586             }
       
  2587         })
       
  2588         .on('error', function(err) {
       
  2589             dataArray = [];
       
  2590             reject(err);
       
  2591         })
       
  2592         .on('end', function (){
       
  2593             try {
       
  2594                 var result = transformZipOutput(resultType, concat(chunkType, dataArray), mimeType);
       
  2595                 resolve(result);
       
  2596             } catch (e) {
       
  2597                 reject(e);
       
  2598             }
       
  2599             dataArray = [];
       
  2600         })
       
  2601         .resume();
       
  2602     });
       
  2603 }
       
  2604 
       
  2605 /**
       
  2606  * An helper to easily use workers outside of JSZip.
       
  2607  * @constructor
       
  2608  * @param {Worker} worker the worker to wrap
       
  2609  * @param {String} outputType the type of data expected by the use
       
  2610  * @param {String} mimeType the mime type of the content, if applicable.
       
  2611  */
       
  2612 function StreamHelper(worker, outputType, mimeType) {
       
  2613     var internalType = outputType;
       
  2614     switch(outputType) {
       
  2615         case "blob":
       
  2616         case "arraybuffer":
       
  2617             internalType = "uint8array";
       
  2618         break;
       
  2619         case "base64":
       
  2620             internalType = "string";
       
  2621         break;
       
  2622     }
       
  2623 
       
  2624     try {
       
  2625         // the type used internally
       
  2626         this._internalType = internalType;
       
  2627         // the type used to output results
       
  2628         this._outputType = outputType;
       
  2629         // the mime type
       
  2630         this._mimeType = mimeType;
       
  2631         utils.checkSupport(internalType);
       
  2632         this._worker = worker.pipe(new ConvertWorker(internalType));
       
  2633         // the last workers can be rewired without issues but we need to
       
  2634         // prevent any updates on previous workers.
       
  2635         worker.lock();
       
  2636     } catch(e) {
       
  2637         this._worker = new GenericWorker("error");
       
  2638         this._worker.error(e);
       
  2639     }
       
  2640 }
       
  2641 
       
  2642 StreamHelper.prototype = {
       
  2643     /**
       
  2644      * Listen a StreamHelper, accumulate its content and concatenate it into a
       
  2645      * complete block.
       
  2646      * @param {Function} updateCb the update callback.
       
  2647      * @return Promise the promise for the accumulation.
       
  2648      */
       
  2649     accumulate : function (updateCb) {
       
  2650         return accumulate(this, updateCb);
       
  2651     },
       
  2652     /**
       
  2653      * Add a listener on an event triggered on a stream.
       
  2654      * @param {String} evt the name of the event
       
  2655      * @param {Function} fn the listener
       
  2656      * @return {StreamHelper} the current helper.
       
  2657      */
       
  2658     on : function (evt, fn) {
       
  2659         var self = this;
       
  2660 
       
  2661         if(evt === "data") {
       
  2662             this._worker.on(evt, function (chunk) {
       
  2663                 fn.call(self, chunk.data, chunk.meta);
       
  2664             });
       
  2665         } else {
       
  2666             this._worker.on(evt, function () {
       
  2667                 utils.delay(fn, arguments, self);
       
  2668             });
       
  2669         }
       
  2670         return this;
       
  2671     },
       
  2672     /**
       
  2673      * Resume the flow of chunks.
       
  2674      * @return {StreamHelper} the current helper.
       
  2675      */
       
  2676     resume : function () {
       
  2677         utils.delay(this._worker.resume, [], this._worker);
       
  2678         return this;
       
  2679     },
       
  2680     /**
       
  2681      * Pause the flow of chunks.
       
  2682      * @return {StreamHelper} the current helper.
       
  2683      */
       
  2684     pause : function () {
       
  2685         this._worker.pause();
       
  2686         return this;
       
  2687     },
       
  2688     /**
       
  2689      * Return a nodejs stream for this helper.
       
  2690      * @param {Function} updateCb the update callback.
       
  2691      * @return {NodejsStreamOutputAdapter} the nodejs stream.
       
  2692      */
       
  2693     toNodejsStream : function (updateCb) {
       
  2694         utils.checkSupport("nodestream");
       
  2695         if (this._outputType !== "nodebuffer") {
       
  2696             // an object stream containing blob/arraybuffer/uint8array/string
       
  2697             // is strange and I don't know if it would be useful.
       
  2698             // I you find this comment and have a good usecase, please open a
       
  2699             // bug report !
       
  2700             throw new Error(this._outputType + " is not supported by this method");
       
  2701         }
       
  2702 
       
  2703         return new NodejsStreamOutputAdapter(this, {
       
  2704             objectMode : this._outputType !== "nodebuffer"
       
  2705         }, updateCb);
       
  2706     }
       
  2707 };
       
  2708 
       
  2709 
       
  2710 module.exports = StreamHelper;
       
  2711 
       
  2712 },{"../base64":1,"../external":6,"../nodejs/NodejsStreamOutputAdapter":13,"../support":30,"../utils":32,"./ConvertWorker":24,"./GenericWorker":28}],30:[function(require,module,exports){
       
  2713 'use strict';
       
  2714 
       
  2715 exports.base64 = true;
       
  2716 exports.array = true;
       
  2717 exports.string = true;
       
  2718 exports.arraybuffer = typeof ArrayBuffer !== "undefined" && typeof Uint8Array !== "undefined";
       
  2719 exports.nodebuffer = typeof Buffer !== "undefined";
       
  2720 // contains true if JSZip can read/generate Uint8Array, false otherwise.
       
  2721 exports.uint8array = typeof Uint8Array !== "undefined";
       
  2722 
       
  2723 if (typeof ArrayBuffer === "undefined") {
       
  2724     exports.blob = false;
       
  2725 }
       
  2726 else {
       
  2727     var buffer = new ArrayBuffer(0);
       
  2728     try {
       
  2729         exports.blob = new Blob([buffer], {
       
  2730             type: "application/zip"
       
  2731         }).size === 0;
       
  2732     }
       
  2733     catch (e) {
       
  2734         try {
       
  2735             var Builder = self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder;
       
  2736             var builder = new Builder();
       
  2737             builder.append(buffer);
       
  2738             exports.blob = builder.getBlob('application/zip').size === 0;
       
  2739         }
       
  2740         catch (e) {
       
  2741             exports.blob = false;
       
  2742         }
       
  2743     }
       
  2744 }
       
  2745 
       
  2746 try {
       
  2747     exports.nodestream = !!require('readable-stream').Readable;
       
  2748 } catch(e) {
       
  2749     exports.nodestream = false;
       
  2750 }
       
  2751 
       
  2752 },{"readable-stream":16}],31:[function(require,module,exports){
       
  2753 'use strict';
       
  2754 
       
  2755 var utils = require('./utils');
       
  2756 var support = require('./support');
       
  2757 var nodejsUtils = require('./nodejsUtils');
       
  2758 var GenericWorker = require('./stream/GenericWorker');
       
  2759 
       
  2760 /**
       
  2761  * The following functions come from pako, from pako/lib/utils/strings
       
  2762  * released under the MIT license, see pako https://github.com/nodeca/pako/
       
  2763  */
       
  2764 
       
  2765 // Table with utf8 lengths (calculated by first byte of sequence)
       
  2766 // Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,
       
  2767 // because max possible codepoint is 0x10ffff
       
  2768 var _utf8len = new Array(256);
       
  2769 for (var i=0; i<256; i++) {
       
  2770   _utf8len[i] = (i >= 252 ? 6 : i >= 248 ? 5 : i >= 240 ? 4 : i >= 224 ? 3 : i >= 192 ? 2 : 1);
       
  2771 }
       
  2772 _utf8len[254]=_utf8len[254]=1; // Invalid sequence start
       
  2773 
       
  2774 // convert string to array (typed, when possible)
       
  2775 var string2buf = function (str) {
       
  2776     var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;
       
  2777 
       
  2778     // count binary size
       
  2779     for (m_pos = 0; m_pos < str_len; m_pos++) {
       
  2780         c = str.charCodeAt(m_pos);
       
  2781         if ((c & 0xfc00) === 0xd800 && (m_pos+1 < str_len)) {
       
  2782             c2 = str.charCodeAt(m_pos+1);
       
  2783             if ((c2 & 0xfc00) === 0xdc00) {
       
  2784                 c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);
       
  2785                 m_pos++;
       
  2786             }
       
  2787         }
       
  2788         buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;
       
  2789     }
       
  2790 
       
  2791     // allocate buffer
       
  2792     if (support.uint8array) {
       
  2793         buf = new Uint8Array(buf_len);
       
  2794     } else {
       
  2795         buf = new Array(buf_len);
       
  2796     }
       
  2797 
       
  2798     // convert
       
  2799     for (i=0, m_pos = 0; i < buf_len; m_pos++) {
       
  2800         c = str.charCodeAt(m_pos);
       
  2801         if ((c & 0xfc00) === 0xd800 && (m_pos+1 < str_len)) {
       
  2802             c2 = str.charCodeAt(m_pos+1);
       
  2803             if ((c2 & 0xfc00) === 0xdc00) {
       
  2804                 c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);
       
  2805                 m_pos++;
       
  2806             }
       
  2807         }
       
  2808         if (c < 0x80) {
       
  2809             /* one byte */
       
  2810             buf[i++] = c;
       
  2811         } else if (c < 0x800) {
       
  2812             /* two bytes */
       
  2813             buf[i++] = 0xC0 | (c >>> 6);
       
  2814             buf[i++] = 0x80 | (c & 0x3f);
       
  2815         } else if (c < 0x10000) {
       
  2816             /* three bytes */
       
  2817             buf[i++] = 0xE0 | (c >>> 12);
       
  2818             buf[i++] = 0x80 | (c >>> 6 & 0x3f);
       
  2819             buf[i++] = 0x80 | (c & 0x3f);
       
  2820         } else {
       
  2821             /* four bytes */
       
  2822             buf[i++] = 0xf0 | (c >>> 18);
       
  2823             buf[i++] = 0x80 | (c >>> 12 & 0x3f);
       
  2824             buf[i++] = 0x80 | (c >>> 6 & 0x3f);
       
  2825             buf[i++] = 0x80 | (c & 0x3f);
       
  2826         }
       
  2827     }
       
  2828 
       
  2829     return buf;
       
  2830 };
       
  2831 
       
  2832 // Calculate max possible position in utf8 buffer,
       
  2833 // that will not break sequence. If that's not possible
       
  2834 // - (very small limits) return max size as is.
       
  2835 //
       
  2836 // buf[] - utf8 bytes array
       
  2837 // max   - length limit (mandatory);
       
  2838 var utf8border = function(buf, max) {
       
  2839     var pos;
       
  2840 
       
  2841     max = max || buf.length;
       
  2842     if (max > buf.length) { max = buf.length; }
       
  2843 
       
  2844     // go back from last position, until start of sequence found
       
  2845     pos = max-1;
       
  2846     while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }
       
  2847 
       
  2848     // Fuckup - very small and broken sequence,
       
  2849     // return max, because we should return something anyway.
       
  2850     if (pos < 0) { return max; }
       
  2851 
       
  2852     // If we came to start of buffer - that means vuffer is too small,
       
  2853     // return max too.
       
  2854     if (pos === 0) { return max; }
       
  2855 
       
  2856     return (pos + _utf8len[buf[pos]] > max) ? pos : max;
       
  2857 };
       
  2858 
       
  2859 // convert array to string
       
  2860 var buf2string = function (buf) {
       
  2861     var str, i, out, c, c_len;
       
  2862     var len = buf.length;
       
  2863 
       
  2864     // Reserve max possible length (2 words per char)
       
  2865     // NB: by unknown reasons, Array is significantly faster for
       
  2866     //     String.fromCharCode.apply than Uint16Array.
       
  2867     var utf16buf = new Array(len*2);
       
  2868 
       
  2869     for (out=0, i=0; i<len;) {
       
  2870         c = buf[i++];
       
  2871         // quick process ascii
       
  2872         if (c < 0x80) { utf16buf[out++] = c; continue; }
       
  2873 
       
  2874         c_len = _utf8len[c];
       
  2875         // skip 5 & 6 byte codes
       
  2876         if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len-1; continue; }
       
  2877 
       
  2878         // apply mask on first byte
       
  2879         c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;
       
  2880         // join the rest
       
  2881         while (c_len > 1 && i < len) {
       
  2882             c = (c << 6) | (buf[i++] & 0x3f);
       
  2883             c_len--;
       
  2884         }
       
  2885 
       
  2886         // terminated by end of string?
       
  2887         if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }
       
  2888 
       
  2889         if (c < 0x10000) {
       
  2890             utf16buf[out++] = c;
       
  2891         } else {
       
  2892             c -= 0x10000;
       
  2893             utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);
       
  2894             utf16buf[out++] = 0xdc00 | (c & 0x3ff);
       
  2895         }
       
  2896     }
       
  2897 
       
  2898     // shrinkBuf(utf16buf, out)
       
  2899     if (utf16buf.length !== out) {
       
  2900         if(utf16buf.subarray) {
       
  2901             utf16buf = utf16buf.subarray(0, out);
       
  2902         } else {
       
  2903             utf16buf.length = out;
       
  2904         }
       
  2905     }
       
  2906 
       
  2907     // return String.fromCharCode.apply(null, utf16buf);
       
  2908     return utils.applyFromCharCode(utf16buf);
       
  2909 };
       
  2910 
       
  2911 
       
  2912 // That's all for the pako functions.
       
  2913 
       
  2914 
       
  2915 /**
       
  2916  * Transform a javascript string into an array (typed if possible) of bytes,
       
  2917  * UTF-8 encoded.
       
  2918  * @param {String} str the string to encode
       
  2919  * @return {Array|Uint8Array|Buffer} the UTF-8 encoded string.
       
  2920  */
       
  2921 exports.utf8encode = function utf8encode(str) {
       
  2922     if (support.nodebuffer) {
       
  2923         return nodejsUtils.newBufferFrom(str, "utf-8");
       
  2924     }
       
  2925 
       
  2926     return string2buf(str);
       
  2927 };
       
  2928 
       
  2929 
       
  2930 /**
       
  2931  * Transform a bytes array (or a representation) representing an UTF-8 encoded
       
  2932  * string into a javascript string.
       
  2933  * @param {Array|Uint8Array|Buffer} buf the data de decode
       
  2934  * @return {String} the decoded string.
       
  2935  */
       
  2936 exports.utf8decode = function utf8decode(buf) {
       
  2937     if (support.nodebuffer) {
       
  2938         return utils.transformTo("nodebuffer", buf).toString("utf-8");
       
  2939     }
       
  2940 
       
  2941     buf = utils.transformTo(support.uint8array ? "uint8array" : "array", buf);
       
  2942 
       
  2943     return buf2string(buf);
       
  2944 };
       
  2945 
       
  2946 /**
       
  2947  * A worker to decode utf8 encoded binary chunks into string chunks.
       
  2948  * @constructor
       
  2949  */
       
  2950 function Utf8DecodeWorker() {
       
  2951     GenericWorker.call(this, "utf-8 decode");
       
  2952     // the last bytes if a chunk didn't end with a complete codepoint.
       
  2953     this.leftOver = null;
       
  2954 }
       
  2955 utils.inherits(Utf8DecodeWorker, GenericWorker);
       
  2956 
       
  2957 /**
       
  2958  * @see GenericWorker.processChunk
       
  2959  */
       
  2960 Utf8DecodeWorker.prototype.processChunk = function (chunk) {
       
  2961 
       
  2962     var data = utils.transformTo(support.uint8array ? "uint8array" : "array", chunk.data);
       
  2963 
       
  2964     // 1st step, re-use what's left of the previous chunk
       
  2965     if (this.leftOver && this.leftOver.length) {
       
  2966         if(support.uint8array) {
       
  2967             var previousData = data;
       
  2968             data = new Uint8Array(previousData.length + this.leftOver.length);
       
  2969             data.set(this.leftOver, 0);
       
  2970             data.set(previousData, this.leftOver.length);
       
  2971         } else {
       
  2972             data = this.leftOver.concat(data);
       
  2973         }
       
  2974         this.leftOver = null;
       
  2975     }
       
  2976 
       
  2977     var nextBoundary = utf8border(data);
       
  2978     var usableData = data;
       
  2979     if (nextBoundary !== data.length) {
       
  2980         if (support.uint8array) {
       
  2981             usableData = data.subarray(0, nextBoundary);
       
  2982             this.leftOver = data.subarray(nextBoundary, data.length);
       
  2983         } else {
       
  2984             usableData = data.slice(0, nextBoundary);
       
  2985             this.leftOver = data.slice(nextBoundary, data.length);
       
  2986         }
       
  2987     }
       
  2988 
       
  2989     this.push({
       
  2990         data : exports.utf8decode(usableData),
       
  2991         meta : chunk.meta
       
  2992     });
       
  2993 };
       
  2994 
       
  2995 /**
       
  2996  * @see GenericWorker.flush
       
  2997  */
       
  2998 Utf8DecodeWorker.prototype.flush = function () {
       
  2999     if(this.leftOver && this.leftOver.length) {
       
  3000         this.push({
       
  3001             data : exports.utf8decode(this.leftOver),
       
  3002             meta : {}
       
  3003         });
       
  3004         this.leftOver = null;
       
  3005     }
       
  3006 };
       
  3007 exports.Utf8DecodeWorker = Utf8DecodeWorker;
       
  3008 
       
  3009 /**
       
  3010  * A worker to endcode string chunks into utf8 encoded binary chunks.
       
  3011  * @constructor
       
  3012  */
       
  3013 function Utf8EncodeWorker() {
       
  3014     GenericWorker.call(this, "utf-8 encode");
       
  3015 }
       
  3016 utils.inherits(Utf8EncodeWorker, GenericWorker);
       
  3017 
       
  3018 /**
       
  3019  * @see GenericWorker.processChunk
       
  3020  */
       
  3021 Utf8EncodeWorker.prototype.processChunk = function (chunk) {
       
  3022     this.push({
       
  3023         data : exports.utf8encode(chunk.data),
       
  3024         meta : chunk.meta
       
  3025     });
       
  3026 };
       
  3027 exports.Utf8EncodeWorker = Utf8EncodeWorker;
       
  3028 
       
  3029 },{"./nodejsUtils":14,"./stream/GenericWorker":28,"./support":30,"./utils":32}],32:[function(require,module,exports){
       
  3030 'use strict';
       
  3031 
       
  3032 var support = require('./support');
       
  3033 var base64 = require('./base64');
       
  3034 var nodejsUtils = require('./nodejsUtils');
       
  3035 var setImmediate = require('core-js/library/fn/set-immediate');
       
  3036 var external = require("./external");
       
  3037 
       
  3038 
       
  3039 /**
       
  3040  * Convert a string that pass as a "binary string": it should represent a byte
       
  3041  * array but may have > 255 char codes. Be sure to take only the first byte
       
  3042  * and returns the byte array.
       
  3043  * @param {String} str the string to transform.
       
  3044  * @return {Array|Uint8Array} the string in a binary format.
       
  3045  */
       
  3046 function string2binary(str) {
       
  3047     var result = null;
       
  3048     if (support.uint8array) {
       
  3049       result = new Uint8Array(str.length);
       
  3050     } else {
       
  3051       result = new Array(str.length);
       
  3052     }
       
  3053     return stringToArrayLike(str, result);
       
  3054 }
       
  3055 
       
  3056 /**
       
  3057  * Create a new blob with the given content and the given type.
       
  3058  * @param {String|ArrayBuffer} part the content to put in the blob. DO NOT use
       
  3059  * an Uint8Array because the stock browser of android 4 won't accept it (it
       
  3060  * will be silently converted to a string, "[object Uint8Array]").
       
  3061  *
       
  3062  * Use only ONE part to build the blob to avoid a memory leak in IE11 / Edge:
       
  3063  * when a large amount of Array is used to create the Blob, the amount of
       
  3064  * memory consumed is nearly 100 times the original data amount.
       
  3065  *
       
  3066  * @param {String} type the mime type of the blob.
       
  3067  * @return {Blob} the created blob.
       
  3068  */
       
  3069 exports.newBlob = function(part, type) {
       
  3070     exports.checkSupport("blob");
       
  3071 
       
  3072     try {
       
  3073         // Blob constructor
       
  3074         return new Blob([part], {
       
  3075             type: type
       
  3076         });
       
  3077     }
       
  3078     catch (e) {
       
  3079 
       
  3080         try {
       
  3081             // deprecated, browser only, old way
       
  3082             var Builder = self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder;
       
  3083             var builder = new Builder();
       
  3084             builder.append(part);
       
  3085             return builder.getBlob(type);
       
  3086         }
       
  3087         catch (e) {
       
  3088 
       
  3089             // well, fuck ?!
       
  3090             throw new Error("Bug : can't construct the Blob.");
       
  3091         }
       
  3092     }
       
  3093 
       
  3094 
       
  3095 };
       
  3096 /**
       
  3097  * The identity function.
       
  3098  * @param {Object} input the input.
       
  3099  * @return {Object} the same input.
       
  3100  */
       
  3101 function identity(input) {
       
  3102     return input;
       
  3103 }
       
  3104 
       
  3105 /**
       
  3106  * Fill in an array with a string.
       
  3107  * @param {String} str the string to use.
       
  3108  * @param {Array|ArrayBuffer|Uint8Array|Buffer} array the array to fill in (will be mutated).
       
  3109  * @return {Array|ArrayBuffer|Uint8Array|Buffer} the updated array.
       
  3110  */
       
  3111 function stringToArrayLike(str, array) {
       
  3112     for (var i = 0; i < str.length; ++i) {
       
  3113         array[i] = str.charCodeAt(i) & 0xFF;
       
  3114     }
       
  3115     return array;
       
  3116 }
       
  3117 
       
  3118 /**
       
  3119  * An helper for the function arrayLikeToString.
       
  3120  * This contains static informations and functions that
       
  3121  * can be optimized by the browser JIT compiler.
       
  3122  */
       
  3123 var arrayToStringHelper = {
       
  3124     /**
       
  3125      * Transform an array of int into a string, chunk by chunk.
       
  3126      * See the performances notes on arrayLikeToString.
       
  3127      * @param {Array|ArrayBuffer|Uint8Array|Buffer} array the array to transform.
       
  3128      * @param {String} type the type of the array.
       
  3129      * @param {Integer} chunk the chunk size.
       
  3130      * @return {String} the resulting string.
       
  3131      * @throws Error if the chunk is too big for the stack.
       
  3132      */
       
  3133     stringifyByChunk: function(array, type, chunk) {
       
  3134         var result = [], k = 0, len = array.length;
       
  3135         // shortcut
       
  3136         if (len <= chunk) {
       
  3137             return String.fromCharCode.apply(null, array);
       
  3138         }
       
  3139         while (k < len) {
       
  3140             if (type === "array" || type === "nodebuffer") {
       
  3141                 result.push(String.fromCharCode.apply(null, array.slice(k, Math.min(k + chunk, len))));
       
  3142             }
       
  3143             else {
       
  3144                 result.push(String.fromCharCode.apply(null, array.subarray(k, Math.min(k + chunk, len))));
       
  3145             }
       
  3146             k += chunk;
       
  3147         }
       
  3148         return result.join("");
       
  3149     },
       
  3150     /**
       
  3151      * Call String.fromCharCode on every item in the array.
       
  3152      * This is the naive implementation, which generate A LOT of intermediate string.
       
  3153      * This should be used when everything else fail.
       
  3154      * @param {Array|ArrayBuffer|Uint8Array|Buffer} array the array to transform.
       
  3155      * @return {String} the result.
       
  3156      */
       
  3157     stringifyByChar: function(array){
       
  3158         var resultStr = "";
       
  3159         for(var i = 0; i < array.length; i++) {
       
  3160             resultStr += String.fromCharCode(array[i]);
       
  3161         }
       
  3162         return resultStr;
       
  3163     },
       
  3164     applyCanBeUsed : {
       
  3165         /**
       
  3166          * true if the browser accepts to use String.fromCharCode on Uint8Array
       
  3167          */
       
  3168         uint8array : (function () {
       
  3169             try {
       
  3170                 return support.uint8array && String.fromCharCode.apply(null, new Uint8Array(1)).length === 1;
       
  3171             } catch (e) {
       
  3172                 return false;
       
  3173             }
       
  3174         })(),
       
  3175         /**
       
  3176          * true if the browser accepts to use String.fromCharCode on nodejs Buffer.
       
  3177          */
       
  3178         nodebuffer : (function () {
       
  3179             try {
       
  3180                 return support.nodebuffer && String.fromCharCode.apply(null, nodejsUtils.allocBuffer(1)).length === 1;
       
  3181             } catch (e) {
       
  3182                 return false;
       
  3183             }
       
  3184         })()
       
  3185     }
       
  3186 };
       
  3187 
       
  3188 /**
       
  3189  * Transform an array-like object to a string.
       
  3190  * @param {Array|ArrayBuffer|Uint8Array|Buffer} array the array to transform.
       
  3191  * @return {String} the result.
       
  3192  */
       
  3193 function arrayLikeToString(array) {
       
  3194     // Performances notes :
       
  3195     // --------------------
       
  3196     // String.fromCharCode.apply(null, array) is the fastest, see
       
  3197     // see http://jsperf.com/converting-a-uint8array-to-a-string/2
       
  3198     // but the stack is limited (and we can get huge arrays !).
       
  3199     //
       
  3200     // result += String.fromCharCode(array[i]); generate too many strings !
       
  3201     //
       
  3202     // This code is inspired by http://jsperf.com/arraybuffer-to-string-apply-performance/2
       
  3203     // TODO : we now have workers that split the work. Do we still need that ?
       
  3204     var chunk = 65536,
       
  3205         type = exports.getTypeOf(array),
       
  3206         canUseApply = true;
       
  3207     if (type === "uint8array") {
       
  3208         canUseApply = arrayToStringHelper.applyCanBeUsed.uint8array;
       
  3209     } else if (type === "nodebuffer") {
       
  3210         canUseApply = arrayToStringHelper.applyCanBeUsed.nodebuffer;
       
  3211     }
       
  3212 
       
  3213     if (canUseApply) {
       
  3214         while (chunk > 1) {
       
  3215             try {
       
  3216                 return arrayToStringHelper.stringifyByChunk(array, type, chunk);
       
  3217             } catch (e) {
       
  3218                 chunk = Math.floor(chunk / 2);
       
  3219             }
       
  3220         }
       
  3221     }
       
  3222 
       
  3223     // no apply or chunk error : slow and painful algorithm
       
  3224     // default browser on android 4.*
       
  3225     return arrayToStringHelper.stringifyByChar(array);
       
  3226 }
       
  3227 
       
  3228 exports.applyFromCharCode = arrayLikeToString;
       
  3229 
       
  3230 
       
  3231 /**
       
  3232  * Copy the data from an array-like to an other array-like.
       
  3233  * @param {Array|ArrayBuffer|Uint8Array|Buffer} arrayFrom the origin array.
       
  3234  * @param {Array|ArrayBuffer|Uint8Array|Buffer} arrayTo the destination array which will be mutated.
       
  3235  * @return {Array|ArrayBuffer|Uint8Array|Buffer} the updated destination array.
       
  3236  */
       
  3237 function arrayLikeToArrayLike(arrayFrom, arrayTo) {
       
  3238     for (var i = 0; i < arrayFrom.length; i++) {
       
  3239         arrayTo[i] = arrayFrom[i];
       
  3240     }
       
  3241     return arrayTo;
       
  3242 }
       
  3243 
       
  3244 // a matrix containing functions to transform everything into everything.
       
  3245 var transform = {};
       
  3246 
       
  3247 // string to ?
       
  3248 transform["string"] = {
       
  3249     "string": identity,
       
  3250     "array": function(input) {
       
  3251         return stringToArrayLike(input, new Array(input.length));
       
  3252     },
       
  3253     "arraybuffer": function(input) {
       
  3254         return transform["string"]["uint8array"](input).buffer;
       
  3255     },
       
  3256     "uint8array": function(input) {
       
  3257         return stringToArrayLike(input, new Uint8Array(input.length));
       
  3258     },
       
  3259     "nodebuffer": function(input) {
       
  3260         return stringToArrayLike(input, nodejsUtils.allocBuffer(input.length));
       
  3261     }
       
  3262 };
       
  3263 
       
  3264 // array to ?
       
  3265 transform["array"] = {
       
  3266     "string": arrayLikeToString,
       
  3267     "array": identity,
       
  3268     "arraybuffer": function(input) {
       
  3269         return (new Uint8Array(input)).buffer;
       
  3270     },
       
  3271     "uint8array": function(input) {
       
  3272         return new Uint8Array(input);
       
  3273     },
       
  3274     "nodebuffer": function(input) {
       
  3275         return nodejsUtils.newBufferFrom(input);
       
  3276     }
       
  3277 };
       
  3278 
       
  3279 // arraybuffer to ?
       
  3280 transform["arraybuffer"] = {
       
  3281     "string": function(input) {
       
  3282         return arrayLikeToString(new Uint8Array(input));
       
  3283     },
       
  3284     "array": function(input) {
       
  3285         return arrayLikeToArrayLike(new Uint8Array(input), new Array(input.byteLength));
       
  3286     },
       
  3287     "arraybuffer": identity,
       
  3288     "uint8array": function(input) {
       
  3289         return new Uint8Array(input);
       
  3290     },
       
  3291     "nodebuffer": function(input) {
       
  3292         return nodejsUtils.newBufferFrom(new Uint8Array(input));
       
  3293     }
       
  3294 };
       
  3295 
       
  3296 // uint8array to ?
       
  3297 transform["uint8array"] = {
       
  3298     "string": arrayLikeToString,
       
  3299     "array": function(input) {
       
  3300         return arrayLikeToArrayLike(input, new Array(input.length));
       
  3301     },
       
  3302     "arraybuffer": function(input) {
       
  3303         return input.buffer;
       
  3304     },
       
  3305     "uint8array": identity,
       
  3306     "nodebuffer": function(input) {
       
  3307         return nodejsUtils.newBufferFrom(input);
       
  3308     }
       
  3309 };
       
  3310 
       
  3311 // nodebuffer to ?
       
  3312 transform["nodebuffer"] = {
       
  3313     "string": arrayLikeToString,
       
  3314     "array": function(input) {
       
  3315         return arrayLikeToArrayLike(input, new Array(input.length));
       
  3316     },
       
  3317     "arraybuffer": function(input) {
       
  3318         return transform["nodebuffer"]["uint8array"](input).buffer;
       
  3319     },
       
  3320     "uint8array": function(input) {
       
  3321         return arrayLikeToArrayLike(input, new Uint8Array(input.length));
       
  3322     },
       
  3323     "nodebuffer": identity
       
  3324 };
       
  3325 
       
  3326 /**
       
  3327  * Transform an input into any type.
       
  3328  * The supported output type are : string, array, uint8array, arraybuffer, nodebuffer.
       
  3329  * If no output type is specified, the unmodified input will be returned.
       
  3330  * @param {String} outputType the output type.
       
  3331  * @param {String|Array|ArrayBuffer|Uint8Array|Buffer} input the input to convert.
       
  3332  * @throws {Error} an Error if the browser doesn't support the requested output type.
       
  3333  */
       
  3334 exports.transformTo = function(outputType, input) {
       
  3335     if (!input) {
       
  3336         // undefined, null, etc
       
  3337         // an empty string won't harm.
       
  3338         input = "";
       
  3339     }
       
  3340     if (!outputType) {
       
  3341         return input;
       
  3342     }
       
  3343     exports.checkSupport(outputType);
       
  3344     var inputType = exports.getTypeOf(input);
       
  3345     var result = transform[inputType][outputType](input);
       
  3346     return result;
       
  3347 };
       
  3348 
       
  3349 /**
       
  3350  * Return the type of the input.
       
  3351  * The type will be in a format valid for JSZip.utils.transformTo : string, array, uint8array, arraybuffer.
       
  3352  * @param {Object} input the input to identify.
       
  3353  * @return {String} the (lowercase) type of the input.
       
  3354  */
       
  3355 exports.getTypeOf = function(input) {
       
  3356     if (typeof input === "string") {
       
  3357         return "string";
       
  3358     }
       
  3359     if (Object.prototype.toString.call(input) === "[object Array]") {
       
  3360         return "array";
       
  3361     }
       
  3362     if (support.nodebuffer && nodejsUtils.isBuffer(input)) {
       
  3363         return "nodebuffer";
       
  3364     }
       
  3365     if (support.uint8array && input instanceof Uint8Array) {
       
  3366         return "uint8array";
       
  3367     }
       
  3368     if (support.arraybuffer && input instanceof ArrayBuffer) {
       
  3369         return "arraybuffer";
       
  3370     }
       
  3371 };
       
  3372 
       
  3373 /**
       
  3374  * Throw an exception if the type is not supported.
       
  3375  * @param {String} type the type to check.
       
  3376  * @throws {Error} an Error if the browser doesn't support the requested type.
       
  3377  */
       
  3378 exports.checkSupport = function(type) {
       
  3379     var supported = support[type.toLowerCase()];
       
  3380     if (!supported) {
       
  3381         throw new Error(type + " is not supported by this platform");
       
  3382     }
       
  3383 };
       
  3384 
       
  3385 exports.MAX_VALUE_16BITS = 65535;
       
  3386 exports.MAX_VALUE_32BITS = -1; // well, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF" is parsed as -1
       
  3387 
       
  3388 /**
       
  3389  * Prettify a string read as binary.
       
  3390  * @param {string} str the string to prettify.
       
  3391  * @return {string} a pretty string.
       
  3392  */
       
  3393 exports.pretty = function(str) {
       
  3394     var res = '',
       
  3395         code, i;
       
  3396     for (i = 0; i < (str || "").length; i++) {
       
  3397         code = str.charCodeAt(i);
       
  3398         res += '\\x' + (code < 16 ? "0" : "") + code.toString(16).toUpperCase();
       
  3399     }
       
  3400     return res;
       
  3401 };
       
  3402 
       
  3403 /**
       
  3404  * Defer the call of a function.
       
  3405  * @param {Function} callback the function to call asynchronously.
       
  3406  * @param {Array} args the arguments to give to the callback.
       
  3407  */
       
  3408 exports.delay = function(callback, args, self) {
       
  3409     setImmediate(function () {
       
  3410         callback.apply(self || null, args || []);
       
  3411     });
       
  3412 };
       
  3413 
       
  3414 /**
       
  3415  * Extends a prototype with an other, without calling a constructor with
       
  3416  * side effects. Inspired by nodejs' `utils.inherits`
       
  3417  * @param {Function} ctor the constructor to augment
       
  3418  * @param {Function} superCtor the parent constructor to use
       
  3419  */
       
  3420 exports.inherits = function (ctor, superCtor) {
       
  3421     var Obj = function() {};
       
  3422     Obj.prototype = superCtor.prototype;
       
  3423     ctor.prototype = new Obj();
       
  3424 };
       
  3425 
       
  3426 /**
       
  3427  * Merge the objects passed as parameters into a new one.
       
  3428  * @private
       
  3429  * @param {...Object} var_args All objects to merge.
       
  3430  * @return {Object} a new object with the data of the others.
       
  3431  */
       
  3432 exports.extend = function() {
       
  3433     var result = {}, i, attr;
       
  3434     for (i = 0; i < arguments.length; i++) { // arguments is not enumerable in some browsers
       
  3435         for (attr in arguments[i]) {
       
  3436             if (arguments[i].hasOwnProperty(attr) && typeof result[attr] === "undefined") {
       
  3437                 result[attr] = arguments[i][attr];
       
  3438             }
       
  3439         }
       
  3440     }
       
  3441     return result;
       
  3442 };
       
  3443 
       
  3444 /**
       
  3445  * Transform arbitrary content into a Promise.
       
  3446  * @param {String} name a name for the content being processed.
       
  3447  * @param {Object} inputData the content to process.
       
  3448  * @param {Boolean} isBinary true if the content is not an unicode string
       
  3449  * @param {Boolean} isOptimizedBinaryString true if the string content only has one byte per character.
       
  3450  * @param {Boolean} isBase64 true if the string content is encoded with base64.
       
  3451  * @return {Promise} a promise in a format usable by JSZip.
       
  3452  */
       
  3453 exports.prepareContent = function(name, inputData, isBinary, isOptimizedBinaryString, isBase64) {
       
  3454 
       
  3455     // if inputData is already a promise, this flatten it.
       
  3456     var promise = external.Promise.resolve(inputData).then(function(data) {
       
  3457         
       
  3458         
       
  3459         var isBlob = support.blob && (data instanceof Blob || ['[object File]', '[object Blob]'].indexOf(Object.prototype.toString.call(data)) !== -1);
       
  3460 
       
  3461         if (isBlob && typeof FileReader !== "undefined") {
       
  3462             return new external.Promise(function (resolve, reject) {
       
  3463                 var reader = new FileReader();
       
  3464 
       
  3465                 reader.onload = function(e) {
       
  3466                     resolve(e.target.result);
       
  3467                 };
       
  3468                 reader.onerror = function(e) {
       
  3469                     reject(e.target.error);
       
  3470                 };
       
  3471                 reader.readAsArrayBuffer(data);
       
  3472             });
       
  3473         } else {
       
  3474             return data;
       
  3475         }
       
  3476     });
       
  3477 
       
  3478     return promise.then(function(data) {
       
  3479         var dataType = exports.getTypeOf(data);
       
  3480 
       
  3481         if (!dataType) {
       
  3482             return external.Promise.reject(
       
  3483                 new Error("Can't read the data of '" + name + "'. Is it " +
       
  3484                           "in a supported JavaScript type (String, Blob, ArrayBuffer, etc) ?")
       
  3485             );
       
  3486         }
       
  3487         // special case : it's way easier to work with Uint8Array than with ArrayBuffer
       
  3488         if (dataType === "arraybuffer") {
       
  3489             data = exports.transformTo("uint8array", data);
       
  3490         } else if (dataType === "string") {
       
  3491             if (isBase64) {
       
  3492                 data = base64.decode(data);
       
  3493             }
       
  3494             else if (isBinary) {
       
  3495                 // optimizedBinaryString === true means that the file has already been filtered with a 0xFF mask
       
  3496                 if (isOptimizedBinaryString !== true) {
       
  3497                     // this is a string, not in a base64 format.
       
  3498                     // Be sure that this is a correct "binary string"
       
  3499                     data = string2binary(data);
       
  3500                 }
       
  3501             }
       
  3502         }
       
  3503         return data;
       
  3504     });
       
  3505 };
       
  3506 
       
  3507 },{"./base64":1,"./external":6,"./nodejsUtils":14,"./support":30,"core-js/library/fn/set-immediate":36}],33:[function(require,module,exports){
       
  3508 'use strict';
       
  3509 var readerFor = require('./reader/readerFor');
       
  3510 var utils = require('./utils');
       
  3511 var sig = require('./signature');
       
  3512 var ZipEntry = require('./zipEntry');
       
  3513 var utf8 = require('./utf8');
       
  3514 var support = require('./support');
       
  3515 //  class ZipEntries {{{
       
  3516 /**
       
  3517  * All the entries in the zip file.
       
  3518  * @constructor
       
  3519  * @param {Object} loadOptions Options for loading the stream.
       
  3520  */
       
  3521 function ZipEntries(loadOptions) {
       
  3522     this.files = [];
       
  3523     this.loadOptions = loadOptions;
       
  3524 }
       
  3525 ZipEntries.prototype = {
       
  3526     /**
       
  3527      * Check that the reader is on the specified signature.
       
  3528      * @param {string} expectedSignature the expected signature.
       
  3529      * @throws {Error} if it is an other signature.
       
  3530      */
       
  3531     checkSignature: function(expectedSignature) {
       
  3532         if (!this.reader.readAndCheckSignature(expectedSignature)) {
       
  3533             this.reader.index -= 4;
       
  3534             var signature = this.reader.readString(4);
       
  3535             throw new Error("Corrupted zip or bug: unexpected signature " + "(" + utils.pretty(signature) + ", expected " + utils.pretty(expectedSignature) + ")");
       
  3536         }
       
  3537     },
       
  3538     /**
       
  3539      * Check if the given signature is at the given index.
       
  3540      * @param {number} askedIndex the index to check.
       
  3541      * @param {string} expectedSignature the signature to expect.
       
  3542      * @return {boolean} true if the signature is here, false otherwise.
       
  3543      */
       
  3544     isSignature: function(askedIndex, expectedSignature) {
       
  3545         var currentIndex = this.reader.index;
       
  3546         this.reader.setIndex(askedIndex);
       
  3547         var signature = this.reader.readString(4);
       
  3548         var result = signature === expectedSignature;
       
  3549         this.reader.setIndex(currentIndex);
       
  3550         return result;
       
  3551     },
       
  3552     /**
       
  3553      * Read the end of the central directory.
       
  3554      */
       
  3555     readBlockEndOfCentral: function() {
       
  3556         this.diskNumber = this.reader.readInt(2);
       
  3557         this.diskWithCentralDirStart = this.reader.readInt(2);
       
  3558         this.centralDirRecordsOnThisDisk = this.reader.readInt(2);
       
  3559         this.centralDirRecords = this.reader.readInt(2);
       
  3560         this.centralDirSize = this.reader.readInt(4);
       
  3561         this.centralDirOffset = this.reader.readInt(4);
       
  3562 
       
  3563         this.zipCommentLength = this.reader.readInt(2);
       
  3564         // warning : the encoding depends of the system locale
       
  3565         // On a linux machine with LANG=en_US.utf8, this field is utf8 encoded.
       
  3566         // On a windows machine, this field is encoded with the localized windows code page.
       
  3567         var zipComment = this.reader.readData(this.zipCommentLength);
       
  3568         var decodeParamType = support.uint8array ? "uint8array" : "array";
       
  3569         // To get consistent behavior with the generation part, we will assume that
       
  3570         // this is utf8 encoded unless specified otherwise.
       
  3571         var decodeContent = utils.transformTo(decodeParamType, zipComment);
       
  3572         this.zipComment = this.loadOptions.decodeFileName(decodeContent);
       
  3573     },
       
  3574     /**
       
  3575      * Read the end of the Zip 64 central directory.
       
  3576      * Not merged with the method readEndOfCentral :
       
  3577      * The end of central can coexist with its Zip64 brother,
       
  3578      * I don't want to read the wrong number of bytes !
       
  3579      */
       
  3580     readBlockZip64EndOfCentral: function() {
       
  3581         this.zip64EndOfCentralSize = this.reader.readInt(8);
       
  3582         this.reader.skip(4);
       
  3583         // this.versionMadeBy = this.reader.readString(2);
       
  3584         // this.versionNeeded = this.reader.readInt(2);
       
  3585         this.diskNumber = this.reader.readInt(4);
       
  3586         this.diskWithCentralDirStart = this.reader.readInt(4);
       
  3587         this.centralDirRecordsOnThisDisk = this.reader.readInt(8);
       
  3588         this.centralDirRecords = this.reader.readInt(8);
       
  3589         this.centralDirSize = this.reader.readInt(8);
       
  3590         this.centralDirOffset = this.reader.readInt(8);
       
  3591 
       
  3592         this.zip64ExtensibleData = {};
       
  3593         var extraDataSize = this.zip64EndOfCentralSize - 44,
       
  3594             index = 0,
       
  3595             extraFieldId,
       
  3596             extraFieldLength,
       
  3597             extraFieldValue;
       
  3598         while (index < extraDataSize) {
       
  3599             extraFieldId = this.reader.readInt(2);
       
  3600             extraFieldLength = this.reader.readInt(4);
       
  3601             extraFieldValue = this.reader.readData(extraFieldLength);
       
  3602             this.zip64ExtensibleData[extraFieldId] = {
       
  3603                 id: extraFieldId,
       
  3604                 length: extraFieldLength,
       
  3605                 value: extraFieldValue
       
  3606             };
       
  3607         }
       
  3608     },
       
  3609     /**
       
  3610      * Read the end of the Zip 64 central directory locator.
       
  3611      */
       
  3612     readBlockZip64EndOfCentralLocator: function() {
       
  3613         this.diskWithZip64CentralDirStart = this.reader.readInt(4);
       
  3614         this.relativeOffsetEndOfZip64CentralDir = this.reader.readInt(8);
       
  3615         this.disksCount = this.reader.readInt(4);
       
  3616         if (this.disksCount > 1) {
       
  3617             throw new Error("Multi-volumes zip are not supported");
       
  3618         }
       
  3619     },
       
  3620     /**
       
  3621      * Read the local files, based on the offset read in the central part.
       
  3622      */
       
  3623     readLocalFiles: function() {
       
  3624         var i, file;
       
  3625         for (i = 0; i < this.files.length; i++) {
       
  3626             file = this.files[i];
       
  3627             this.reader.setIndex(file.localHeaderOffset);
       
  3628             this.checkSignature(sig.LOCAL_FILE_HEADER);
       
  3629             file.readLocalPart(this.reader);
       
  3630             file.handleUTF8();
       
  3631             file.processAttributes();
       
  3632         }
       
  3633     },
       
  3634     /**
       
  3635      * Read the central directory.
       
  3636      */
       
  3637     readCentralDir: function() {
       
  3638         var file;
       
  3639 
       
  3640         this.reader.setIndex(this.centralDirOffset);
       
  3641         while (this.reader.readAndCheckSignature(sig.CENTRAL_FILE_HEADER)) {
       
  3642             file = new ZipEntry({
       
  3643                 zip64: this.zip64
       
  3644             }, this.loadOptions);
       
  3645             file.readCentralPart(this.reader);
       
  3646             this.files.push(file);
       
  3647         }
       
  3648 
       
  3649         if (this.centralDirRecords !== this.files.length) {
       
  3650             if (this.centralDirRecords !== 0 && this.files.length === 0) {
       
  3651                 // We expected some records but couldn't find ANY.
       
  3652                 // This is really suspicious, as if something went wrong.
       
  3653                 throw new Error("Corrupted zip or bug: expected " + this.centralDirRecords + " records in central dir, got " + this.files.length);
       
  3654             } else {
       
  3655                 // We found some records but not all.
       
  3656                 // Something is wrong but we got something for the user: no error here.
       
  3657                 // console.warn("expected", this.centralDirRecords, "records in central dir, got", this.files.length);
       
  3658             }
       
  3659         }
       
  3660     },
       
  3661     /**
       
  3662      * Read the end of central directory.
       
  3663      */
       
  3664     readEndOfCentral: function() {
       
  3665         var offset = this.reader.lastIndexOfSignature(sig.CENTRAL_DIRECTORY_END);
       
  3666         if (offset < 0) {
       
  3667             // Check if the content is a truncated zip or complete garbage.
       
  3668             // A "LOCAL_FILE_HEADER" is not required at the beginning (auto
       
  3669             // extractible zip for example) but it can give a good hint.
       
  3670             // If an ajax request was used without responseType, we will also
       
  3671             // get unreadable data.
       
  3672             var isGarbage = !this.isSignature(0, sig.LOCAL_FILE_HEADER);
       
  3673 
       
  3674             if (isGarbage) {
       
  3675                 throw new Error("Can't find end of central directory : is this a zip file ? " +
       
  3676                                 "If it is, see https://stuk.github.io/jszip/documentation/howto/read_zip.html");
       
  3677             } else {
       
  3678                 throw new Error("Corrupted zip: can't find end of central directory");
       
  3679             }
       
  3680 
       
  3681         }
       
  3682         this.reader.setIndex(offset);
       
  3683         var endOfCentralDirOffset = offset;
       
  3684         this.checkSignature(sig.CENTRAL_DIRECTORY_END);
       
  3685         this.readBlockEndOfCentral();
       
  3686 
       
  3687 
       
  3688         /* extract from the zip spec :
       
  3689             4)  If one of the fields in the end of central directory
       
  3690                 record is too small to hold required data, the field
       
  3691                 should be set to -1 (0xFFFF or 0xFFFFFFFF) and the
       
  3692                 ZIP64 format record should be created.
       
  3693             5)  The end of central directory record and the
       
  3694                 Zip64 end of central directory locator record must
       
  3695                 reside on the same disk when splitting or spanning
       
  3696                 an archive.
       
  3697          */
       
  3698         if (this.diskNumber === utils.MAX_VALUE_16BITS || this.diskWithCentralDirStart === utils.MAX_VALUE_16BITS || this.centralDirRecordsOnThisDisk === utils.MAX_VALUE_16BITS || this.centralDirRecords === utils.MAX_VALUE_16BITS || this.centralDirSize === utils.MAX_VALUE_32BITS || this.centralDirOffset === utils.MAX_VALUE_32BITS) {
       
  3699             this.zip64 = true;
       
  3700 
       
  3701             /*
       
  3702             Warning : the zip64 extension is supported, but ONLY if the 64bits integer read from
       
  3703             the zip file can fit into a 32bits integer. This cannot be solved : JavaScript represents
       
  3704             all numbers as 64-bit double precision IEEE 754 floating point numbers.
       
  3705             So, we have 53bits for integers and bitwise operations treat everything as 32bits.
       
  3706             see https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Operators/Bitwise_Operators
       
  3707             and http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-262.pdf section 8.5
       
  3708             */
       
  3709 
       
  3710             // should look for a zip64 EOCD locator
       
  3711             offset = this.reader.lastIndexOfSignature(sig.ZIP64_CENTRAL_DIRECTORY_LOCATOR);
       
  3712             if (offset < 0) {
       
  3713                 throw new Error("Corrupted zip: can't find the ZIP64 end of central directory locator");
       
  3714             }
       
  3715             this.reader.setIndex(offset);
       
  3716             this.checkSignature(sig.ZIP64_CENTRAL_DIRECTORY_LOCATOR);
       
  3717             this.readBlockZip64EndOfCentralLocator();
       
  3718 
       
  3719             // now the zip64 EOCD record
       
  3720             if (!this.isSignature(this.relativeOffsetEndOfZip64CentralDir, sig.ZIP64_CENTRAL_DIRECTORY_END)) {
       
  3721                 // console.warn("ZIP64 end of central directory not where expected.");
       
  3722                 this.relativeOffsetEndOfZip64CentralDir = this.reader.lastIndexOfSignature(sig.ZIP64_CENTRAL_DIRECTORY_END);
       
  3723                 if (this.relativeOffsetEndOfZip64CentralDir < 0) {
       
  3724                     throw new Error("Corrupted zip: can't find the ZIP64 end of central directory");
       
  3725                 }
       
  3726             }
       
  3727             this.reader.setIndex(this.relativeOffsetEndOfZip64CentralDir);
       
  3728             this.checkSignature(sig.ZIP64_CENTRAL_DIRECTORY_END);
       
  3729             this.readBlockZip64EndOfCentral();
       
  3730         }
       
  3731 
       
  3732         var expectedEndOfCentralDirOffset = this.centralDirOffset + this.centralDirSize;
       
  3733         if (this.zip64) {
       
  3734             expectedEndOfCentralDirOffset += 20; // end of central dir 64 locator
       
  3735             expectedEndOfCentralDirOffset += 12 /* should not include the leading 12 bytes */ + this.zip64EndOfCentralSize;
       
  3736         }
       
  3737 
       
  3738         var extraBytes = endOfCentralDirOffset - expectedEndOfCentralDirOffset;
       
  3739 
       
  3740         if (extraBytes > 0) {
       
  3741             // console.warn(extraBytes, "extra bytes at beginning or within zipfile");
       
  3742             if (this.isSignature(endOfCentralDirOffset, sig.CENTRAL_FILE_HEADER)) {
       
  3743                 // The offsets seem wrong, but we have something at the specified offset.
       
  3744                 // So… we keep it.
       
  3745             } else {
       
  3746                 // the offset is wrong, update the "zero" of the reader
       
  3747                 // this happens if data has been prepended (crx files for example)
       
  3748                 this.reader.zero = extraBytes;
       
  3749             }
       
  3750         } else if (extraBytes < 0) {
       
  3751             throw new Error("Corrupted zip: missing " + Math.abs(extraBytes) + " bytes.");
       
  3752         }
       
  3753     },
       
  3754     prepareReader: function(data) {
       
  3755         this.reader = readerFor(data);
       
  3756     },
       
  3757     /**
       
  3758      * Read a zip file and create ZipEntries.
       
  3759      * @param {String|ArrayBuffer|Uint8Array|Buffer} data the binary string representing a zip file.
       
  3760      */
       
  3761     load: function(data) {
       
  3762         this.prepareReader(data);
       
  3763         this.readEndOfCentral();
       
  3764         this.readCentralDir();
       
  3765         this.readLocalFiles();
       
  3766     }
       
  3767 };
       
  3768 // }}} end of ZipEntries
       
  3769 module.exports = ZipEntries;
       
  3770 
       
  3771 },{"./reader/readerFor":22,"./signature":23,"./support":30,"./utf8":31,"./utils":32,"./zipEntry":34}],34:[function(require,module,exports){
       
  3772 'use strict';
       
  3773 var readerFor = require('./reader/readerFor');
       
  3774 var utils = require('./utils');
       
  3775 var CompressedObject = require('./compressedObject');
       
  3776 var crc32fn = require('./crc32');
       
  3777 var utf8 = require('./utf8');
       
  3778 var compressions = require('./compressions');
       
  3779 var support = require('./support');
       
  3780 
       
  3781 var MADE_BY_DOS = 0x00;
       
  3782 var MADE_BY_UNIX = 0x03;
       
  3783 
       
  3784 /**
       
  3785  * Find a compression registered in JSZip.
       
  3786  * @param {string} compressionMethod the method magic to find.
       
  3787  * @return {Object|null} the JSZip compression object, null if none found.
       
  3788  */
       
  3789 var findCompression = function(compressionMethod) {
       
  3790     for (var method in compressions) {
       
  3791         if (!compressions.hasOwnProperty(method)) {
       
  3792             continue;
       
  3793         }
       
  3794         if (compressions[method].magic === compressionMethod) {
       
  3795             return compressions[method];
       
  3796         }
       
  3797     }
       
  3798     return null;
       
  3799 };
       
  3800 
       
  3801 // class ZipEntry {{{
       
  3802 /**
       
  3803  * An entry in the zip file.
       
  3804  * @constructor
       
  3805  * @param {Object} options Options of the current file.
       
  3806  * @param {Object} loadOptions Options for loading the stream.
       
  3807  */
       
  3808 function ZipEntry(options, loadOptions) {
       
  3809     this.options = options;
       
  3810     this.loadOptions = loadOptions;
       
  3811 }
       
  3812 ZipEntry.prototype = {
       
  3813     /**
       
  3814      * say if the file is encrypted.
       
  3815      * @return {boolean} true if the file is encrypted, false otherwise.
       
  3816      */
       
  3817     isEncrypted: function() {
       
  3818         // bit 1 is set
       
  3819         return (this.bitFlag & 0x0001) === 0x0001;
       
  3820     },
       
  3821     /**
       
  3822      * say if the file has utf-8 filename/comment.
       
  3823      * @return {boolean} true if the filename/comment is in utf-8, false otherwise.
       
  3824      */
       
  3825     useUTF8: function() {
       
  3826         // bit 11 is set
       
  3827         return (this.bitFlag & 0x0800) === 0x0800;
       
  3828     },
       
  3829     /**
       
  3830      * Read the local part of a zip file and add the info in this object.
       
  3831      * @param {DataReader} reader the reader to use.
       
  3832      */
       
  3833     readLocalPart: function(reader) {
       
  3834         var compression, localExtraFieldsLength;
       
  3835 
       
  3836         // we already know everything from the central dir !
       
  3837         // If the central dir data are false, we are doomed.
       
  3838         // On the bright side, the local part is scary  : zip64, data descriptors, both, etc.
       
  3839         // The less data we get here, the more reliable this should be.
       
  3840         // Let's skip the whole header and dash to the data !
       
  3841         reader.skip(22);
       
  3842         // in some zip created on windows, the filename stored in the central dir contains \ instead of /.
       
  3843         // Strangely, the filename here is OK.
       
  3844         // I would love to treat these zip files as corrupted (see http://www.info-zip.org/FAQ.html#backslashes
       
  3845         // or APPNOTE#4.4.17.1, "All slashes MUST be forward slashes '/'") but there are a lot of bad zip generators...
       
  3846         // Search "unzip mismatching "local" filename continuing with "central" filename version" on
       
  3847         // the internet.
       
  3848         //
       
  3849         // I think I see the logic here : the central directory is used to display
       
  3850         // content and the local directory is used to extract the files. Mixing / and \
       
  3851         // may be used to display \ to windows users and use / when extracting the files.
       
  3852         // Unfortunately, this lead also to some issues : http://seclists.org/fulldisclosure/2009/Sep/394
       
  3853         this.fileNameLength = reader.readInt(2);
       
  3854         localExtraFieldsLength = reader.readInt(2); // can't be sure this will be the same as the central dir
       
  3855         // the fileName is stored as binary data, the handleUTF8 method will take care of the encoding.
       
  3856         this.fileName = reader.readData(this.fileNameLength);
       
  3857         reader.skip(localExtraFieldsLength);
       
  3858 
       
  3859         if (this.compressedSize === -1 || this.uncompressedSize === -1) {
       
  3860             throw new Error("Bug or corrupted zip : didn't get enough informations from the central directory " + "(compressedSize === -1 || uncompressedSize === -1)");
       
  3861         }
       
  3862 
       
  3863         compression = findCompression(this.compressionMethod);
       
  3864         if (compression === null) { // no compression found
       
  3865             throw new Error("Corrupted zip : compression " + utils.pretty(this.compressionMethod) + " unknown (inner file : " + utils.transformTo("string", this.fileName) + ")");
       
  3866         }
       
  3867         this.decompressed = new CompressedObject(this.compressedSize, this.uncompressedSize, this.crc32, compression, reader.readData(this.compressedSize));
       
  3868     },
       
  3869 
       
  3870     /**
       
  3871      * Read the central part of a zip file and add the info in this object.
       
  3872      * @param {DataReader} reader the reader to use.
       
  3873      */
       
  3874     readCentralPart: function(reader) {
       
  3875         this.versionMadeBy = reader.readInt(2);
       
  3876         reader.skip(2);
       
  3877         // this.versionNeeded = reader.readInt(2);
       
  3878         this.bitFlag = reader.readInt(2);
       
  3879         this.compressionMethod = reader.readString(2);
       
  3880         this.date = reader.readDate();
       
  3881         this.crc32 = reader.readInt(4);
       
  3882         this.compressedSize = reader.readInt(4);
       
  3883         this.uncompressedSize = reader.readInt(4);
       
  3884         var fileNameLength = reader.readInt(2);
       
  3885         this.extraFieldsLength = reader.readInt(2);
       
  3886         this.fileCommentLength = reader.readInt(2);
       
  3887         this.diskNumberStart = reader.readInt(2);
       
  3888         this.internalFileAttributes = reader.readInt(2);
       
  3889         this.externalFileAttributes = reader.readInt(4);
       
  3890         this.localHeaderOffset = reader.readInt(4);
       
  3891 
       
  3892         if (this.isEncrypted()) {
       
  3893             throw new Error("Encrypted zip are not supported");
       
  3894         }
       
  3895 
       
  3896         // will be read in the local part, see the comments there
       
  3897         reader.skip(fileNameLength);
       
  3898         this.readExtraFields(reader);
       
  3899         this.parseZIP64ExtraField(reader);
       
  3900         this.fileComment = reader.readData(this.fileCommentLength);
       
  3901     },
       
  3902 
       
  3903     /**
       
  3904      * Parse the external file attributes and get the unix/dos permissions.
       
  3905      */
       
  3906     processAttributes: function () {
       
  3907         this.unixPermissions = null;
       
  3908         this.dosPermissions = null;
       
  3909         var madeBy = this.versionMadeBy >> 8;
       
  3910 
       
  3911         // Check if we have the DOS directory flag set.
       
  3912         // We look for it in the DOS and UNIX permissions
       
  3913         // but some unknown platform could set it as a compatibility flag.
       
  3914         this.dir = this.externalFileAttributes & 0x0010 ? true : false;
       
  3915 
       
  3916         if(madeBy === MADE_BY_DOS) {
       
  3917             // first 6 bits (0 to 5)
       
  3918             this.dosPermissions = this.externalFileAttributes & 0x3F;
       
  3919         }
       
  3920 
       
  3921         if(madeBy === MADE_BY_UNIX) {
       
  3922             this.unixPermissions = (this.externalFileAttributes >> 16) & 0xFFFF;
       
  3923             // the octal permissions are in (this.unixPermissions & 0x01FF).toString(8);
       
  3924         }
       
  3925 
       
  3926         // fail safe : if the name ends with a / it probably means a folder
       
  3927         if (!this.dir && this.fileNameStr.slice(-1) === '/') {
       
  3928             this.dir = true;
       
  3929         }
       
  3930     },
       
  3931 
       
  3932     /**
       
  3933      * Parse the ZIP64 extra field and merge the info in the current ZipEntry.
       
  3934      * @param {DataReader} reader the reader to use.
       
  3935      */
       
  3936     parseZIP64ExtraField: function(reader) {
       
  3937 
       
  3938         if (!this.extraFields[0x0001]) {
       
  3939             return;
       
  3940         }
       
  3941 
       
  3942         // should be something, preparing the extra reader
       
  3943         var extraReader = readerFor(this.extraFields[0x0001].value);
       
  3944 
       
  3945         // I really hope that these 64bits integer can fit in 32 bits integer, because js
       
  3946         // won't let us have more.
       
  3947         if (this.uncompressedSize === utils.MAX_VALUE_32BITS) {
       
  3948             this.uncompressedSize = extraReader.readInt(8);
       
  3949         }
       
  3950         if (this.compressedSize === utils.MAX_VALUE_32BITS) {
       
  3951             this.compressedSize = extraReader.readInt(8);
       
  3952         }
       
  3953         if (this.localHeaderOffset === utils.MAX_VALUE_32BITS) {
       
  3954             this.localHeaderOffset = extraReader.readInt(8);
       
  3955         }
       
  3956         if (this.diskNumberStart === utils.MAX_VALUE_32BITS) {
       
  3957             this.diskNumberStart = extraReader.readInt(4);
       
  3958         }
       
  3959     },
       
  3960     /**
       
  3961      * Read the central part of a zip file and add the info in this object.
       
  3962      * @param {DataReader} reader the reader to use.
       
  3963      */
       
  3964     readExtraFields: function(reader) {
       
  3965         var end = reader.index + this.extraFieldsLength,
       
  3966             extraFieldId,
       
  3967             extraFieldLength,
       
  3968             extraFieldValue;
       
  3969 
       
  3970         if (!this.extraFields) {
       
  3971             this.extraFields = {};
       
  3972         }
       
  3973 
       
  3974         while (reader.index < end) {
       
  3975             extraFieldId = reader.readInt(2);
       
  3976             extraFieldLength = reader.readInt(2);
       
  3977             extraFieldValue = reader.readData(extraFieldLength);
       
  3978 
       
  3979             this.extraFields[extraFieldId] = {
       
  3980                 id: extraFieldId,
       
  3981                 length: extraFieldLength,
       
  3982                 value: extraFieldValue
       
  3983             };
       
  3984         }
       
  3985     },
       
  3986     /**
       
  3987      * Apply an UTF8 transformation if needed.
       
  3988      */
       
  3989     handleUTF8: function() {
       
  3990         var decodeParamType = support.uint8array ? "uint8array" : "array";
       
  3991         if (this.useUTF8()) {
       
  3992             this.fileNameStr = utf8.utf8decode(this.fileName);
       
  3993             this.fileCommentStr = utf8.utf8decode(this.fileComment);
       
  3994         } else {
       
  3995             var upath = this.findExtraFieldUnicodePath();
       
  3996             if (upath !== null) {
       
  3997                 this.fileNameStr = upath;
       
  3998             } else {
       
  3999                 // ASCII text or unsupported code page
       
  4000                 var fileNameByteArray =  utils.transformTo(decodeParamType, this.fileName);
       
  4001                 this.fileNameStr = this.loadOptions.decodeFileName(fileNameByteArray);
       
  4002             }
       
  4003 
       
  4004             var ucomment = this.findExtraFieldUnicodeComment();
       
  4005             if (ucomment !== null) {
       
  4006                 this.fileCommentStr = ucomment;
       
  4007             } else {
       
  4008                 // ASCII text or unsupported code page
       
  4009                 var commentByteArray =  utils.transformTo(decodeParamType, this.fileComment);
       
  4010                 this.fileCommentStr = this.loadOptions.decodeFileName(commentByteArray);
       
  4011             }
       
  4012         }
       
  4013     },
       
  4014 
       
  4015     /**
       
  4016      * Find the unicode path declared in the extra field, if any.
       
  4017      * @return {String} the unicode path, null otherwise.
       
  4018      */
       
  4019     findExtraFieldUnicodePath: function() {
       
  4020         var upathField = this.extraFields[0x7075];
       
  4021         if (upathField) {
       
  4022             var extraReader = readerFor(upathField.value);
       
  4023 
       
  4024             // wrong version
       
  4025             if (extraReader.readInt(1) !== 1) {
       
  4026                 return null;
       
  4027             }
       
  4028 
       
  4029             // the crc of the filename changed, this field is out of date.
       
  4030             if (crc32fn(this.fileName) !== extraReader.readInt(4)) {
       
  4031                 return null;
       
  4032             }
       
  4033 
       
  4034             return utf8.utf8decode(extraReader.readData(upathField.length - 5));
       
  4035         }
       
  4036         return null;
       
  4037     },
       
  4038 
       
  4039     /**
       
  4040      * Find the unicode comment declared in the extra field, if any.
       
  4041      * @return {String} the unicode comment, null otherwise.
       
  4042      */
       
  4043     findExtraFieldUnicodeComment: function() {
       
  4044         var ucommentField = this.extraFields[0x6375];
       
  4045         if (ucommentField) {
       
  4046             var extraReader = readerFor(ucommentField.value);
       
  4047 
       
  4048             // wrong version
       
  4049             if (extraReader.readInt(1) !== 1) {
       
  4050                 return null;
       
  4051             }
       
  4052 
       
  4053             // the crc of the comment changed, this field is out of date.
       
  4054             if (crc32fn(this.fileComment) !== extraReader.readInt(4)) {
       
  4055                 return null;
       
  4056             }
       
  4057 
       
  4058             return utf8.utf8decode(extraReader.readData(ucommentField.length - 5));
       
  4059         }
       
  4060         return null;
       
  4061     }
       
  4062 };
       
  4063 module.exports = ZipEntry;
       
  4064 
       
  4065 },{"./compressedObject":2,"./compressions":3,"./crc32":4,"./reader/readerFor":22,"./support":30,"./utf8":31,"./utils":32}],35:[function(require,module,exports){
       
  4066 'use strict';
       
  4067 
       
  4068 var StreamHelper = require('./stream/StreamHelper');
       
  4069 var DataWorker = require('./stream/DataWorker');
       
  4070 var utf8 = require('./utf8');
       
  4071 var CompressedObject = require('./compressedObject');
       
  4072 var GenericWorker = require('./stream/GenericWorker');
       
  4073 
       
  4074 /**
       
  4075  * A simple object representing a file in the zip file.
       
  4076  * @constructor
       
  4077  * @param {string} name the name of the file
       
  4078  * @param {String|ArrayBuffer|Uint8Array|Buffer} data the data
       
  4079  * @param {Object} options the options of the file
       
  4080  */
       
  4081 var ZipObject = function(name, data, options) {
       
  4082     this.name = name;
       
  4083     this.dir = options.dir;
       
  4084     this.date = options.date;
       
  4085     this.comment = options.comment;
       
  4086     this.unixPermissions = options.unixPermissions;
       
  4087     this.dosPermissions = options.dosPermissions;
       
  4088 
       
  4089     this._data = data;
       
  4090     this._dataBinary = options.binary;
       
  4091     // keep only the compression
       
  4092     this.options = {
       
  4093         compression : options.compression,
       
  4094         compressionOptions : options.compressionOptions
       
  4095     };
       
  4096 };
       
  4097 
       
  4098 ZipObject.prototype = {
       
  4099     /**
       
  4100      * Create an internal stream for the content of this object.
       
  4101      * @param {String} type the type of each chunk.
       
  4102      * @return StreamHelper the stream.
       
  4103      */
       
  4104     internalStream: function (type) {
       
  4105         var result = null, outputType = "string";
       
  4106         try {
       
  4107             if (!type) {
       
  4108                 throw new Error("No output type specified.");
       
  4109             }
       
  4110             outputType = type.toLowerCase();
       
  4111             var askUnicodeString = outputType === "string" || outputType === "text";
       
  4112             if (outputType === "binarystring" || outputType === "text") {
       
  4113                 outputType = "string";
       
  4114             }
       
  4115             result = this._decompressWorker();
       
  4116 
       
  4117             var isUnicodeString = !this._dataBinary;
       
  4118 
       
  4119             if (isUnicodeString && !askUnicodeString) {
       
  4120                 result = result.pipe(new utf8.Utf8EncodeWorker());
       
  4121             }
       
  4122             if (!isUnicodeString && askUnicodeString) {
       
  4123                 result = result.pipe(new utf8.Utf8DecodeWorker());
       
  4124             }
       
  4125         } catch (e) {
       
  4126             result = new GenericWorker("error");
       
  4127             result.error(e);
       
  4128         }
       
  4129 
       
  4130         return new StreamHelper(result, outputType, "");
       
  4131     },
       
  4132 
       
  4133     /**
       
  4134      * Prepare the content in the asked type.
       
  4135      * @param {String} type the type of the result.
       
  4136      * @param {Function} onUpdate a function to call on each internal update.
       
  4137      * @return Promise the promise of the result.
       
  4138      */
       
  4139     async: function (type, onUpdate) {
       
  4140         return this.internalStream(type).accumulate(onUpdate);
       
  4141     },
       
  4142 
       
  4143     /**
       
  4144      * Prepare the content as a nodejs stream.
       
  4145      * @param {String} type the type of each chunk.
       
  4146      * @param {Function} onUpdate a function to call on each internal update.
       
  4147      * @return Stream the stream.
       
  4148      */
       
  4149     nodeStream: function (type, onUpdate) {
       
  4150         return this.internalStream(type || "nodebuffer").toNodejsStream(onUpdate);
       
  4151     },
       
  4152 
       
  4153     /**
       
  4154      * Return a worker for the compressed content.
       
  4155      * @private
       
  4156      * @param {Object} compression the compression object to use.
       
  4157      * @param {Object} compressionOptions the options to use when compressing.
       
  4158      * @return Worker the worker.
       
  4159      */
       
  4160     _compressWorker: function (compression, compressionOptions) {
       
  4161         if (
       
  4162             this._data instanceof CompressedObject &&
       
  4163             this._data.compression.magic === compression.magic
       
  4164         ) {
       
  4165             return this._data.getCompressedWorker();
       
  4166         } else {
       
  4167             var result = this._decompressWorker();
       
  4168             if(!this._dataBinary) {
       
  4169                 result = result.pipe(new utf8.Utf8EncodeWorker());
       
  4170             }
       
  4171             return CompressedObject.createWorkerFrom(result, compression, compressionOptions);
       
  4172         }
       
  4173     },
       
  4174     /**
       
  4175      * Return a worker for the decompressed content.
       
  4176      * @private
       
  4177      * @return Worker the worker.
       
  4178      */
       
  4179     _decompressWorker : function () {
       
  4180         if (this._data instanceof CompressedObject) {
       
  4181             return this._data.getContentWorker();
       
  4182         } else if (this._data instanceof GenericWorker) {
       
  4183             return this._data;
       
  4184         } else {
       
  4185             return new DataWorker(this._data);
       
  4186         }
       
  4187     }
       
  4188 };
       
  4189 
       
  4190 var removedMethods = ["asText", "asBinary", "asNodeBuffer", "asUint8Array", "asArrayBuffer"];
       
  4191 var removedFn = function () {
       
  4192     throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
       
  4193 };
       
  4194 
       
  4195 for(var i = 0; i < removedMethods.length; i++) {
       
  4196     ZipObject.prototype[removedMethods[i]] = removedFn;
       
  4197 }
       
  4198 module.exports = ZipObject;
       
  4199 
       
  4200 },{"./compressedObject":2,"./stream/DataWorker":27,"./stream/GenericWorker":28,"./stream/StreamHelper":29,"./utf8":31}],36:[function(require,module,exports){
       
  4201 require('../modules/web.immediate');
       
  4202 module.exports = require('../modules/_core').setImmediate;
       
  4203 },{"../modules/_core":40,"../modules/web.immediate":56}],37:[function(require,module,exports){
       
  4204 module.exports = function(it){
       
  4205   if(typeof it != 'function')throw TypeError(it + ' is not a function!');
       
  4206   return it;
       
  4207 };
       
  4208 },{}],38:[function(require,module,exports){
       
  4209 var isObject = require('./_is-object');
       
  4210 module.exports = function(it){
       
  4211   if(!isObject(it))throw TypeError(it + ' is not an object!');
       
  4212   return it;
       
  4213 };
       
  4214 },{"./_is-object":51}],39:[function(require,module,exports){
       
  4215 var toString = {}.toString;
       
  4216 
       
  4217 module.exports = function(it){
       
  4218   return toString.call(it).slice(8, -1);
       
  4219 };
       
  4220 },{}],40:[function(require,module,exports){
       
  4221 var core = module.exports = {version: '2.3.0'};
       
  4222 if(typeof __e == 'number')__e = core; // eslint-disable-line no-undef
       
  4223 },{}],41:[function(require,module,exports){
       
  4224 // optional / simple context binding
       
  4225 var aFunction = require('./_a-function');
       
  4226 module.exports = function(fn, that, length){
       
  4227   aFunction(fn);
       
  4228   if(that === undefined)return fn;
       
  4229   switch(length){
       
  4230     case 1: return function(a){
       
  4231       return fn.call(that, a);
       
  4232     };
       
  4233     case 2: return function(a, b){
       
  4234       return fn.call(that, a, b);
       
  4235     };
       
  4236     case 3: return function(a, b, c){
       
  4237       return fn.call(that, a, b, c);
       
  4238     };
       
  4239   }
       
  4240   return function(/* ...args */){
       
  4241     return fn.apply(that, arguments);
       
  4242   };
       
  4243 };
       
  4244 },{"./_a-function":37}],42:[function(require,module,exports){
       
  4245 // Thank's IE8 for his funny defineProperty
       
  4246 module.exports = !require('./_fails')(function(){
       
  4247   return Object.defineProperty({}, 'a', {get: function(){ return 7; }}).a != 7;
       
  4248 });
       
  4249 },{"./_fails":45}],43:[function(require,module,exports){
       
  4250 var isObject = require('./_is-object')
       
  4251   , document = require('./_global').document
       
  4252   // in old IE typeof document.createElement is 'object'
       
  4253   , is = isObject(document) && isObject(document.createElement);
       
  4254 module.exports = function(it){
       
  4255   return is ? document.createElement(it) : {};
       
  4256 };
       
  4257 },{"./_global":46,"./_is-object":51}],44:[function(require,module,exports){
       
  4258 var global    = require('./_global')
       
  4259   , core      = require('./_core')
       
  4260   , ctx       = require('./_ctx')
       
  4261   , hide      = require('./_hide')
       
  4262   , PROTOTYPE = 'prototype';
       
  4263 
       
  4264 var $export = function(type, name, source){
       
  4265   var IS_FORCED = type & $export.F
       
  4266     , IS_GLOBAL = type & $export.G
       
  4267     , IS_STATIC = type & $export.S
       
  4268     , IS_PROTO  = type & $export.P
       
  4269     , IS_BIND   = type & $export.B
       
  4270     , IS_WRAP   = type & $export.W
       
  4271     , exports   = IS_GLOBAL ? core : core[name] || (core[name] = {})
       
  4272     , expProto  = exports[PROTOTYPE]
       
  4273     , target    = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE]
       
  4274     , key, own, out;
       
  4275   if(IS_GLOBAL)source = name;
       
  4276   for(key in source){
       
  4277     // contains in native
       
  4278     own = !IS_FORCED && target && target[key] !== undefined;
       
  4279     if(own && key in exports)continue;
       
  4280     // export native or passed
       
  4281     out = own ? target[key] : source[key];
       
  4282     // prevent global pollution for namespaces
       
  4283     exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]
       
  4284     // bind timers to global for call from export context
       
  4285     : IS_BIND && own ? ctx(out, global)
       
  4286     // wrap global constructors for prevent change them in library
       
  4287     : IS_WRAP && target[key] == out ? (function(C){
       
  4288       var F = function(a, b, c){
       
  4289         if(this instanceof C){
       
  4290           switch(arguments.length){
       
  4291             case 0: return new C;
       
  4292             case 1: return new C(a);
       
  4293             case 2: return new C(a, b);
       
  4294           } return new C(a, b, c);
       
  4295         } return C.apply(this, arguments);
       
  4296       };
       
  4297       F[PROTOTYPE] = C[PROTOTYPE];
       
  4298       return F;
       
  4299     // make static versions for prototype methods
       
  4300     })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;
       
  4301     // export proto methods to core.%CONSTRUCTOR%.methods.%NAME%
       
  4302     if(IS_PROTO){
       
  4303       (exports.virtual || (exports.virtual = {}))[key] = out;
       
  4304       // export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%
       
  4305       if(type & $export.R && expProto && !expProto[key])hide(expProto, key, out);
       
  4306     }
       
  4307   }
       
  4308 };
       
  4309 // type bitmap
       
  4310 $export.F = 1;   // forced
       
  4311 $export.G = 2;   // global
       
  4312 $export.S = 4;   // static
       
  4313 $export.P = 8;   // proto
       
  4314 $export.B = 16;  // bind
       
  4315 $export.W = 32;  // wrap
       
  4316 $export.U = 64;  // safe
       
  4317 $export.R = 128; // real proto method for `library` 
       
  4318 module.exports = $export;
       
  4319 },{"./_core":40,"./_ctx":41,"./_global":46,"./_hide":47}],45:[function(require,module,exports){
       
  4320 module.exports = function(exec){
       
  4321   try {
       
  4322     return !!exec();
       
  4323   } catch(e){
       
  4324     return true;
       
  4325   }
       
  4326 };
       
  4327 },{}],46:[function(require,module,exports){
       
  4328 // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
       
  4329 var global = module.exports = typeof window != 'undefined' && window.Math == Math
       
  4330   ? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();
       
  4331 if(typeof __g == 'number')__g = global; // eslint-disable-line no-undef
       
  4332 },{}],47:[function(require,module,exports){
       
  4333 var dP         = require('./_object-dp')
       
  4334   , createDesc = require('./_property-desc');
       
  4335 module.exports = require('./_descriptors') ? function(object, key, value){
       
  4336   return dP.f(object, key, createDesc(1, value));
       
  4337 } : function(object, key, value){
       
  4338   object[key] = value;
       
  4339   return object;
       
  4340 };
       
  4341 },{"./_descriptors":42,"./_object-dp":52,"./_property-desc":53}],48:[function(require,module,exports){
       
  4342 module.exports = require('./_global').document && document.documentElement;
       
  4343 },{"./_global":46}],49:[function(require,module,exports){
       
  4344 module.exports = !require('./_descriptors') && !require('./_fails')(function(){
       
  4345   return Object.defineProperty(require('./_dom-create')('div'), 'a', {get: function(){ return 7; }}).a != 7;
       
  4346 });
       
  4347 },{"./_descriptors":42,"./_dom-create":43,"./_fails":45}],50:[function(require,module,exports){
       
  4348 // fast apply, http://jsperf.lnkit.com/fast-apply/5
       
  4349 module.exports = function(fn, args, that){
       
  4350   var un = that === undefined;
       
  4351   switch(args.length){
       
  4352     case 0: return un ? fn()
       
  4353                       : fn.call(that);
       
  4354     case 1: return un ? fn(args[0])
       
  4355                       : fn.call(that, args[0]);
       
  4356     case 2: return un ? fn(args[0], args[1])
       
  4357                       : fn.call(that, args[0], args[1]);
       
  4358     case 3: return un ? fn(args[0], args[1], args[2])
       
  4359                       : fn.call(that, args[0], args[1], args[2]);
       
  4360     case 4: return un ? fn(args[0], args[1], args[2], args[3])
       
  4361                       : fn.call(that, args[0], args[1], args[2], args[3]);
       
  4362   } return              fn.apply(that, args);
       
  4363 };
       
  4364 },{}],51:[function(require,module,exports){
       
  4365 module.exports = function(it){
       
  4366   return typeof it === 'object' ? it !== null : typeof it === 'function';
       
  4367 };
       
  4368 },{}],52:[function(require,module,exports){
       
  4369 var anObject       = require('./_an-object')
       
  4370   , IE8_DOM_DEFINE = require('./_ie8-dom-define')
       
  4371   , toPrimitive    = require('./_to-primitive')
       
  4372   , dP             = Object.defineProperty;
       
  4373 
       
  4374 exports.f = require('./_descriptors') ? Object.defineProperty : function defineProperty(O, P, Attributes){
       
  4375   anObject(O);
       
  4376   P = toPrimitive(P, true);
       
  4377   anObject(Attributes);
       
  4378   if(IE8_DOM_DEFINE)try {
       
  4379     return dP(O, P, Attributes);
       
  4380   } catch(e){ /* empty */ }
       
  4381   if('get' in Attributes || 'set' in Attributes)throw TypeError('Accessors not supported!');
       
  4382   if('value' in Attributes)O[P] = Attributes.value;
       
  4383   return O;
       
  4384 };
       
  4385 },{"./_an-object":38,"./_descriptors":42,"./_ie8-dom-define":49,"./_to-primitive":55}],53:[function(require,module,exports){
       
  4386 module.exports = function(bitmap, value){
       
  4387   return {
       
  4388     enumerable  : !(bitmap & 1),
       
  4389     configurable: !(bitmap & 2),
       
  4390     writable    : !(bitmap & 4),
       
  4391     value       : value
       
  4392   };
       
  4393 };
       
  4394 },{}],54:[function(require,module,exports){
       
  4395 var ctx                = require('./_ctx')
       
  4396   , invoke             = require('./_invoke')
       
  4397   , html               = require('./_html')
       
  4398   , cel                = require('./_dom-create')
       
  4399   , global             = require('./_global')
       
  4400   , process            = global.process
       
  4401   , setTask            = global.setImmediate
       
  4402   , clearTask          = global.clearImmediate
       
  4403   , MessageChannel     = global.MessageChannel
       
  4404   , counter            = 0
       
  4405   , queue              = {}
       
  4406   , ONREADYSTATECHANGE = 'onreadystatechange'
       
  4407   , defer, channel, port;
       
  4408 var run = function(){
       
  4409   var id = +this;
       
  4410   if(queue.hasOwnProperty(id)){
       
  4411     var fn = queue[id];
       
  4412     delete queue[id];
       
  4413     fn();
       
  4414   }
       
  4415 };
       
  4416 var listener = function(event){
       
  4417   run.call(event.data);
       
  4418 };
       
  4419 // Node.js 0.9+ & IE10+ has setImmediate, otherwise:
       
  4420 if(!setTask || !clearTask){
       
  4421   setTask = function setImmediate(fn){
       
  4422     var args = [], i = 1;
       
  4423     while(arguments.length > i)args.push(arguments[i++]);
       
  4424     queue[++counter] = function(){
       
  4425       invoke(typeof fn == 'function' ? fn : Function(fn), args);
       
  4426     };
       
  4427     defer(counter);
       
  4428     return counter;
       
  4429   };
       
  4430   clearTask = function clearImmediate(id){
       
  4431     delete queue[id];
       
  4432   };
       
  4433   // Node.js 0.8-
       
  4434   if(require('./_cof')(process) == 'process'){
       
  4435     defer = function(id){
       
  4436       process.nextTick(ctx(run, id, 1));
       
  4437     };
       
  4438   // Browsers with MessageChannel, includes WebWorkers
       
  4439   } else if(MessageChannel){
       
  4440     channel = new MessageChannel;
       
  4441     port    = channel.port2;
       
  4442     channel.port1.onmessage = listener;
       
  4443     defer = ctx(port.postMessage, port, 1);
       
  4444   // Browsers with postMessage, skip WebWorkers
       
  4445   // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'
       
  4446   } else if(global.addEventListener && typeof postMessage == 'function' && !global.importScripts){
       
  4447     defer = function(id){
       
  4448       global.postMessage(id + '', '*');
       
  4449     };
       
  4450     global.addEventListener('message', listener, false);
       
  4451   // IE8-
       
  4452   } else if(ONREADYSTATECHANGE in cel('script')){
       
  4453     defer = function(id){
       
  4454       html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function(){
       
  4455         html.removeChild(this);
       
  4456         run.call(id);
       
  4457       };
       
  4458     };
       
  4459   // Rest old browsers
       
  4460   } else {
       
  4461     defer = function(id){
       
  4462       setTimeout(ctx(run, id, 1), 0);
       
  4463     };
       
  4464   }
       
  4465 }
       
  4466 module.exports = {
       
  4467   set:   setTask,
       
  4468   clear: clearTask
       
  4469 };
       
  4470 },{"./_cof":39,"./_ctx":41,"./_dom-create":43,"./_global":46,"./_html":48,"./_invoke":50}],55:[function(require,module,exports){
       
  4471 // 7.1.1 ToPrimitive(input [, PreferredType])
       
  4472 var isObject = require('./_is-object');
       
  4473 // instead of the ES6 spec version, we didn't implement @@toPrimitive case
       
  4474 // and the second argument - flag - preferred type is a string
       
  4475 module.exports = function(it, S){
       
  4476   if(!isObject(it))return it;
       
  4477   var fn, val;
       
  4478   if(S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it)))return val;
       
  4479   if(typeof (fn = it.valueOf) == 'function' && !isObject(val = fn.call(it)))return val;
       
  4480   if(!S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it)))return val;
       
  4481   throw TypeError("Can't convert object to primitive value");
       
  4482 };
       
  4483 },{"./_is-object":51}],56:[function(require,module,exports){
       
  4484 var $export = require('./_export')
       
  4485   , $task   = require('./_task');
       
  4486 $export($export.G + $export.B, {
       
  4487   setImmediate:   $task.set,
       
  4488   clearImmediate: $task.clear
       
  4489 });
       
  4490 },{"./_export":44,"./_task":54}],57:[function(require,module,exports){
       
  4491 (function (global){
       
  4492 'use strict';
       
  4493 var Mutation = global.MutationObserver || global.WebKitMutationObserver;
       
  4494 
       
  4495 var scheduleDrain;
       
  4496 
       
  4497 {
       
  4498   if (Mutation) {
       
  4499     var called = 0;
       
  4500     var observer = new Mutation(nextTick);
       
  4501     var element = global.document.createTextNode('');
       
  4502     observer.observe(element, {
       
  4503       characterData: true
       
  4504     });
       
  4505     scheduleDrain = function () {
       
  4506       element.data = (called = ++called % 2);
       
  4507     };
       
  4508   } else if (!global.setImmediate && typeof global.MessageChannel !== 'undefined') {
       
  4509     var channel = new global.MessageChannel();
       
  4510     channel.port1.onmessage = nextTick;
       
  4511     scheduleDrain = function () {
       
  4512       channel.port2.postMessage(0);
       
  4513     };
       
  4514   } else if ('document' in global && 'onreadystatechange' in global.document.createElement('script')) {
       
  4515     scheduleDrain = function () {
       
  4516 
       
  4517       // Create a <script> element; its readystatechange event will be fired asynchronously once it is inserted
       
  4518       // into the document. Do so, thus queuing up the task. Remember to clean up once it's been called.
       
  4519       var scriptEl = global.document.createElement('script');
       
  4520       scriptEl.onreadystatechange = function () {
       
  4521         nextTick();
       
  4522 
       
  4523         scriptEl.onreadystatechange = null;
       
  4524         scriptEl.parentNode.removeChild(scriptEl);
       
  4525         scriptEl = null;
       
  4526       };
       
  4527       global.document.documentElement.appendChild(scriptEl);
       
  4528     };
       
  4529   } else {
       
  4530     scheduleDrain = function () {
       
  4531       setTimeout(nextTick, 0);
       
  4532     };
       
  4533   }
       
  4534 }
       
  4535 
       
  4536 var draining;
       
  4537 var queue = [];
       
  4538 //named nextTick for less confusing stack traces
       
  4539 function nextTick() {
       
  4540   draining = true;
       
  4541   var i, oldQueue;
       
  4542   var len = queue.length;
       
  4543   while (len) {
       
  4544     oldQueue = queue;
       
  4545     queue = [];
       
  4546     i = -1;
       
  4547     while (++i < len) {
       
  4548       oldQueue[i]();
       
  4549     }
       
  4550     len = queue.length;
       
  4551   }
       
  4552   draining = false;
       
  4553 }
       
  4554 
       
  4555 module.exports = immediate;
       
  4556 function immediate(task) {
       
  4557   if (queue.push(task) === 1 && !draining) {
       
  4558     scheduleDrain();
       
  4559   }
       
  4560 }
       
  4561 
       
  4562 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
       
  4563 },{}],58:[function(require,module,exports){
       
  4564 'use strict';
       
  4565 var immediate = require('immediate');
       
  4566 
       
  4567 /* istanbul ignore next */
       
  4568 function INTERNAL() {}
       
  4569 
       
  4570 var handlers = {};
       
  4571 
       
  4572 var REJECTED = ['REJECTED'];
       
  4573 var FULFILLED = ['FULFILLED'];
       
  4574 var PENDING = ['PENDING'];
       
  4575 
       
  4576 module.exports = Promise;
       
  4577 
       
  4578 function Promise(resolver) {
       
  4579   if (typeof resolver !== 'function') {
       
  4580     throw new TypeError('resolver must be a function');
       
  4581   }
       
  4582   this.state = PENDING;
       
  4583   this.queue = [];
       
  4584   this.outcome = void 0;
       
  4585   if (resolver !== INTERNAL) {
       
  4586     safelyResolveThenable(this, resolver);
       
  4587   }
       
  4588 }
       
  4589 
       
  4590 Promise.prototype["catch"] = function (onRejected) {
       
  4591   return this.then(null, onRejected);
       
  4592 };
       
  4593 Promise.prototype.then = function (onFulfilled, onRejected) {
       
  4594   if (typeof onFulfilled !== 'function' && this.state === FULFILLED ||
       
  4595     typeof onRejected !== 'function' && this.state === REJECTED) {
       
  4596     return this;
       
  4597   }
       
  4598   var promise = new this.constructor(INTERNAL);
       
  4599   if (this.state !== PENDING) {
       
  4600     var resolver = this.state === FULFILLED ? onFulfilled : onRejected;
       
  4601     unwrap(promise, resolver, this.outcome);
       
  4602   } else {
       
  4603     this.queue.push(new QueueItem(promise, onFulfilled, onRejected));
       
  4604   }
       
  4605 
       
  4606   return promise;
       
  4607 };
       
  4608 function QueueItem(promise, onFulfilled, onRejected) {
       
  4609   this.promise = promise;
       
  4610   if (typeof onFulfilled === 'function') {
       
  4611     this.onFulfilled = onFulfilled;
       
  4612     this.callFulfilled = this.otherCallFulfilled;
       
  4613   }
       
  4614   if (typeof onRejected === 'function') {
       
  4615     this.onRejected = onRejected;
       
  4616     this.callRejected = this.otherCallRejected;
       
  4617   }
       
  4618 }
       
  4619 QueueItem.prototype.callFulfilled = function (value) {
       
  4620   handlers.resolve(this.promise, value);
       
  4621 };
       
  4622 QueueItem.prototype.otherCallFulfilled = function (value) {
       
  4623   unwrap(this.promise, this.onFulfilled, value);
       
  4624 };
       
  4625 QueueItem.prototype.callRejected = function (value) {
       
  4626   handlers.reject(this.promise, value);
       
  4627 };
       
  4628 QueueItem.prototype.otherCallRejected = function (value) {
       
  4629   unwrap(this.promise, this.onRejected, value);
       
  4630 };
       
  4631 
       
  4632 function unwrap(promise, func, value) {
       
  4633   immediate(function () {
       
  4634     var returnValue;
       
  4635     try {
       
  4636       returnValue = func(value);
       
  4637     } catch (e) {
       
  4638       return handlers.reject(promise, e);
       
  4639     }
       
  4640     if (returnValue === promise) {
       
  4641       handlers.reject(promise, new TypeError('Cannot resolve promise with itself'));
       
  4642     } else {
       
  4643       handlers.resolve(promise, returnValue);
       
  4644     }
       
  4645   });
       
  4646 }
       
  4647 
       
  4648 handlers.resolve = function (self, value) {
       
  4649   var result = tryCatch(getThen, value);
       
  4650   if (result.status === 'error') {
       
  4651     return handlers.reject(self, result.value);
       
  4652   }
       
  4653   var thenable = result.value;
       
  4654 
       
  4655   if (thenable) {
       
  4656     safelyResolveThenable(self, thenable);
       
  4657   } else {
       
  4658     self.state = FULFILLED;
       
  4659     self.outcome = value;
       
  4660     var i = -1;
       
  4661     var len = self.queue.length;
       
  4662     while (++i < len) {
       
  4663       self.queue[i].callFulfilled(value);
       
  4664     }
       
  4665   }
       
  4666   return self;
       
  4667 };
       
  4668 handlers.reject = function (self, error) {
       
  4669   self.state = REJECTED;
       
  4670   self.outcome = error;
       
  4671   var i = -1;
       
  4672   var len = self.queue.length;
       
  4673   while (++i < len) {
       
  4674     self.queue[i].callRejected(error);
       
  4675   }
       
  4676   return self;
       
  4677 };
       
  4678 
       
  4679 function getThen(obj) {
       
  4680   // Make sure we only access the accessor once as required by the spec
       
  4681   var then = obj && obj.then;
       
  4682   if (obj && (typeof obj === 'object' || typeof obj === 'function') && typeof then === 'function') {
       
  4683     return function appyThen() {
       
  4684       then.apply(obj, arguments);
       
  4685     };
       
  4686   }
       
  4687 }
       
  4688 
       
  4689 function safelyResolveThenable(self, thenable) {
       
  4690   // Either fulfill, reject or reject with error
       
  4691   var called = false;
       
  4692   function onError(value) {
       
  4693     if (called) {
       
  4694       return;
       
  4695     }
       
  4696     called = true;
       
  4697     handlers.reject(self, value);
       
  4698   }
       
  4699 
       
  4700   function onSuccess(value) {
       
  4701     if (called) {
       
  4702       return;
       
  4703     }
       
  4704     called = true;
       
  4705     handlers.resolve(self, value);
       
  4706   }
       
  4707 
       
  4708   function tryToUnwrap() {
       
  4709     thenable(onSuccess, onError);
       
  4710   }
       
  4711 
       
  4712   var result = tryCatch(tryToUnwrap);
       
  4713   if (result.status === 'error') {
       
  4714     onError(result.value);
       
  4715   }
       
  4716 }
       
  4717 
       
  4718 function tryCatch(func, value) {
       
  4719   var out = {};
       
  4720   try {
       
  4721     out.value = func(value);
       
  4722     out.status = 'success';
       
  4723   } catch (e) {
       
  4724     out.status = 'error';
       
  4725     out.value = e;
       
  4726   }
       
  4727   return out;
       
  4728 }
       
  4729 
       
  4730 Promise.resolve = resolve;
       
  4731 function resolve(value) {
       
  4732   if (value instanceof this) {
       
  4733     return value;
       
  4734   }
       
  4735   return handlers.resolve(new this(INTERNAL), value);
       
  4736 }
       
  4737 
       
  4738 Promise.reject = reject;
       
  4739 function reject(reason) {
       
  4740   var promise = new this(INTERNAL);
       
  4741   return handlers.reject(promise, reason);
       
  4742 }
       
  4743 
       
  4744 Promise.all = all;
       
  4745 function all(iterable) {
       
  4746   var self = this;
       
  4747   if (Object.prototype.toString.call(iterable) !== '[object Array]') {
       
  4748     return this.reject(new TypeError('must be an array'));
       
  4749   }
       
  4750 
       
  4751   var len = iterable.length;
       
  4752   var called = false;
       
  4753   if (!len) {
       
  4754     return this.resolve([]);
       
  4755   }
       
  4756 
       
  4757   var values = new Array(len);
       
  4758   var resolved = 0;
       
  4759   var i = -1;
       
  4760   var promise = new this(INTERNAL);
       
  4761 
       
  4762   while (++i < len) {
       
  4763     allResolver(iterable[i], i);
       
  4764   }
       
  4765   return promise;
       
  4766   function allResolver(value, i) {
       
  4767     self.resolve(value).then(resolveFromAll, function (error) {
       
  4768       if (!called) {
       
  4769         called = true;
       
  4770         handlers.reject(promise, error);
       
  4771       }
       
  4772     });
       
  4773     function resolveFromAll(outValue) {
       
  4774       values[i] = outValue;
       
  4775       if (++resolved === len && !called) {
       
  4776         called = true;
       
  4777         handlers.resolve(promise, values);
       
  4778       }
       
  4779     }
       
  4780   }
       
  4781 }
       
  4782 
       
  4783 Promise.race = race;
       
  4784 function race(iterable) {
       
  4785   var self = this;
       
  4786   if (Object.prototype.toString.call(iterable) !== '[object Array]') {
       
  4787     return this.reject(new TypeError('must be an array'));
       
  4788   }
       
  4789 
       
  4790   var len = iterable.length;
       
  4791   var called = false;
       
  4792   if (!len) {
       
  4793     return this.resolve([]);
       
  4794   }
       
  4795 
       
  4796   var i = -1;
       
  4797   var promise = new this(INTERNAL);
       
  4798 
       
  4799   while (++i < len) {
       
  4800     resolver(iterable[i]);
       
  4801   }
       
  4802   return promise;
       
  4803   function resolver(value) {
       
  4804     self.resolve(value).then(function (response) {
       
  4805       if (!called) {
       
  4806         called = true;
       
  4807         handlers.resolve(promise, response);
       
  4808       }
       
  4809     }, function (error) {
       
  4810       if (!called) {
       
  4811         called = true;
       
  4812         handlers.reject(promise, error);
       
  4813       }
       
  4814     });
       
  4815   }
       
  4816 }
       
  4817 
       
  4818 },{"immediate":57}],59:[function(require,module,exports){
       
  4819 // Top level file is just a mixin of submodules & constants
       
  4820 'use strict';
       
  4821 
       
  4822 var assign    = require('./lib/utils/common').assign;
       
  4823 
       
  4824 var deflate   = require('./lib/deflate');
       
  4825 var inflate   = require('./lib/inflate');
       
  4826 var constants = require('./lib/zlib/constants');
       
  4827 
       
  4828 var pako = {};
       
  4829 
       
  4830 assign(pako, deflate, inflate, constants);
       
  4831 
       
  4832 module.exports = pako;
       
  4833 
       
  4834 },{"./lib/deflate":60,"./lib/inflate":61,"./lib/utils/common":62,"./lib/zlib/constants":65}],60:[function(require,module,exports){
       
  4835 'use strict';
       
  4836 
       
  4837 
       
  4838 var zlib_deflate = require('./zlib/deflate');
       
  4839 var utils        = require('./utils/common');
       
  4840 var strings      = require('./utils/strings');
       
  4841 var msg          = require('./zlib/messages');
       
  4842 var ZStream      = require('./zlib/zstream');
       
  4843 
       
  4844 var toString = Object.prototype.toString;
       
  4845 
       
  4846 /* Public constants ==========================================================*/
       
  4847 /* ===========================================================================*/
       
  4848 
       
  4849 var Z_NO_FLUSH      = 0;
       
  4850 var Z_FINISH        = 4;
       
  4851 
       
  4852 var Z_OK            = 0;
       
  4853 var Z_STREAM_END    = 1;
       
  4854 var Z_SYNC_FLUSH    = 2;
       
  4855 
       
  4856 var Z_DEFAULT_COMPRESSION = -1;
       
  4857 
       
  4858 var Z_DEFAULT_STRATEGY    = 0;
       
  4859 
       
  4860 var Z_DEFLATED  = 8;
       
  4861 
       
  4862 /* ===========================================================================*/
       
  4863 
       
  4864 
       
  4865 /**
       
  4866  * class Deflate
       
  4867  *
       
  4868  * Generic JS-style wrapper for zlib calls. If you don't need
       
  4869  * streaming behaviour - use more simple functions: [[deflate]],
       
  4870  * [[deflateRaw]] and [[gzip]].
       
  4871  **/
       
  4872 
       
  4873 /* internal
       
  4874  * Deflate.chunks -> Array
       
  4875  *
       
  4876  * Chunks of output data, if [[Deflate#onData]] not overriden.
       
  4877  **/
       
  4878 
       
  4879 /**
       
  4880  * Deflate.result -> Uint8Array|Array
       
  4881  *
       
  4882  * Compressed result, generated by default [[Deflate#onData]]
       
  4883  * and [[Deflate#onEnd]] handlers. Filled after you push last chunk
       
  4884  * (call [[Deflate#push]] with `Z_FINISH` / `true` param)  or if you
       
  4885  * push a chunk with explicit flush (call [[Deflate#push]] with
       
  4886  * `Z_SYNC_FLUSH` param).
       
  4887  **/
       
  4888 
       
  4889 /**
       
  4890  * Deflate.err -> Number
       
  4891  *
       
  4892  * Error code after deflate finished. 0 (Z_OK) on success.
       
  4893  * You will not need it in real life, because deflate errors
       
  4894  * are possible only on wrong options or bad `onData` / `onEnd`
       
  4895  * custom handlers.
       
  4896  **/
       
  4897 
       
  4898 /**
       
  4899  * Deflate.msg -> String
       
  4900  *
       
  4901  * Error message, if [[Deflate.err]] != 0
       
  4902  **/
       
  4903 
       
  4904 
       
  4905 /**
       
  4906  * new Deflate(options)
       
  4907  * - options (Object): zlib deflate options.
       
  4908  *
       
  4909  * Creates new deflator instance with specified params. Throws exception
       
  4910  * on bad params. Supported options:
       
  4911  *
       
  4912  * - `level`
       
  4913  * - `windowBits`
       
  4914  * - `memLevel`
       
  4915  * - `strategy`
       
  4916  * - `dictionary`
       
  4917  *
       
  4918  * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)
       
  4919  * for more information on these.
       
  4920  *
       
  4921  * Additional options, for internal needs:
       
  4922  *
       
  4923  * - `chunkSize` - size of generated data chunks (16K by default)
       
  4924  * - `raw` (Boolean) - do raw deflate
       
  4925  * - `gzip` (Boolean) - create gzip wrapper
       
  4926  * - `to` (String) - if equal to 'string', then result will be "binary string"
       
  4927  *    (each char code [0..255])
       
  4928  * - `header` (Object) - custom header for gzip
       
  4929  *   - `text` (Boolean) - true if compressed data believed to be text
       
  4930  *   - `time` (Number) - modification time, unix timestamp
       
  4931  *   - `os` (Number) - operation system code
       
  4932  *   - `extra` (Array) - array of bytes with extra data (max 65536)
       
  4933  *   - `name` (String) - file name (binary string)
       
  4934  *   - `comment` (String) - comment (binary string)
       
  4935  *   - `hcrc` (Boolean) - true if header crc should be added
       
  4936  *
       
  4937  * ##### Example:
       
  4938  *
       
  4939  * ```javascript
       
  4940  * var pako = require('pako')
       
  4941  *   , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])
       
  4942  *   , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);
       
  4943  *
       
  4944  * var deflate = new pako.Deflate({ level: 3});
       
  4945  *
       
  4946  * deflate.push(chunk1, false);
       
  4947  * deflate.push(chunk2, true);  // true -> last chunk
       
  4948  *
       
  4949  * if (deflate.err) { throw new Error(deflate.err); }
       
  4950  *
       
  4951  * console.log(deflate.result);
       
  4952  * ```
       
  4953  **/
       
  4954 function Deflate(options) {
       
  4955   if (!(this instanceof Deflate)) return new Deflate(options);
       
  4956 
       
  4957   this.options = utils.assign({
       
  4958     level: Z_DEFAULT_COMPRESSION,
       
  4959     method: Z_DEFLATED,
       
  4960     chunkSize: 16384,
       
  4961     windowBits: 15,
       
  4962     memLevel: 8,
       
  4963     strategy: Z_DEFAULT_STRATEGY,
       
  4964     to: ''
       
  4965   }, options || {});
       
  4966 
       
  4967   var opt = this.options;
       
  4968 
       
  4969   if (opt.raw && (opt.windowBits > 0)) {
       
  4970     opt.windowBits = -opt.windowBits;
       
  4971   }
       
  4972 
       
  4973   else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {
       
  4974     opt.windowBits += 16;
       
  4975   }
       
  4976 
       
  4977   this.err    = 0;      // error code, if happens (0 = Z_OK)
       
  4978   this.msg    = '';     // error message
       
  4979   this.ended  = false;  // used to avoid multiple onEnd() calls
       
  4980   this.chunks = [];     // chunks of compressed data
       
  4981 
       
  4982   this.strm = new ZStream();
       
  4983   this.strm.avail_out = 0;
       
  4984 
       
  4985   var status = zlib_deflate.deflateInit2(
       
  4986     this.strm,
       
  4987     opt.level,
       
  4988     opt.method,
       
  4989     opt.windowBits,
       
  4990     opt.memLevel,
       
  4991     opt.strategy
       
  4992   );
       
  4993 
       
  4994   if (status !== Z_OK) {
       
  4995     throw new Error(msg[status]);
       
  4996   }
       
  4997 
       
  4998   if (opt.header) {
       
  4999     zlib_deflate.deflateSetHeader(this.strm, opt.header);
       
  5000   }
       
  5001 
       
  5002   if (opt.dictionary) {
       
  5003     var dict;
       
  5004     // Convert data if needed
       
  5005     if (typeof opt.dictionary === 'string') {
       
  5006       // If we need to compress text, change encoding to utf8.
       
  5007       dict = strings.string2buf(opt.dictionary);
       
  5008     } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {
       
  5009       dict = new Uint8Array(opt.dictionary);
       
  5010     } else {
       
  5011       dict = opt.dictionary;
       
  5012     }
       
  5013 
       
  5014     status = zlib_deflate.deflateSetDictionary(this.strm, dict);
       
  5015 
       
  5016     if (status !== Z_OK) {
       
  5017       throw new Error(msg[status]);
       
  5018     }
       
  5019 
       
  5020     this._dict_set = true;
       
  5021   }
       
  5022 }
       
  5023 
       
  5024 /**
       
  5025  * Deflate#push(data[, mode]) -> Boolean
       
  5026  * - data (Uint8Array|Array|ArrayBuffer|String): input data. Strings will be
       
  5027  *   converted to utf8 byte sequence.
       
  5028  * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.
       
  5029  *   See constants. Skipped or `false` means Z_NO_FLUSH, `true` meansh Z_FINISH.
       
  5030  *
       
  5031  * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with
       
  5032  * new compressed chunks. Returns `true` on success. The last data block must have
       
  5033  * mode Z_FINISH (or `true`). That will flush internal pending buffers and call
       
  5034  * [[Deflate#onEnd]]. For interim explicit flushes (without ending the stream) you
       
  5035  * can use mode Z_SYNC_FLUSH, keeping the compression context.
       
  5036  *
       
  5037  * On fail call [[Deflate#onEnd]] with error code and return false.
       
  5038  *
       
  5039  * We strongly recommend to use `Uint8Array` on input for best speed (output
       
  5040  * array format is detected automatically). Also, don't skip last param and always
       
  5041  * use the same type in your code (boolean or number). That will improve JS speed.
       
  5042  *
       
  5043  * For regular `Array`-s make sure all elements are [0..255].
       
  5044  *
       
  5045  * ##### Example
       
  5046  *
       
  5047  * ```javascript
       
  5048  * push(chunk, false); // push one of data chunks
       
  5049  * ...
       
  5050  * push(chunk, true);  // push last chunk
       
  5051  * ```
       
  5052  **/
       
  5053 Deflate.prototype.push = function (data, mode) {
       
  5054   var strm = this.strm;
       
  5055   var chunkSize = this.options.chunkSize;
       
  5056   var status, _mode;
       
  5057 
       
  5058   if (this.ended) { return false; }
       
  5059 
       
  5060   _mode = (mode === ~~mode) ? mode : ((mode === true) ? Z_FINISH : Z_NO_FLUSH);
       
  5061 
       
  5062   // Convert data if needed
       
  5063   if (typeof data === 'string') {
       
  5064     // If we need to compress text, change encoding to utf8.
       
  5065     strm.input = strings.string2buf(data);
       
  5066   } else if (toString.call(data) === '[object ArrayBuffer]') {
       
  5067     strm.input = new Uint8Array(data);
       
  5068   } else {
       
  5069     strm.input = data;
       
  5070   }
       
  5071 
       
  5072   strm.next_in = 0;
       
  5073   strm.avail_in = strm.input.length;
       
  5074 
       
  5075   do {
       
  5076     if (strm.avail_out === 0) {
       
  5077       strm.output = new utils.Buf8(chunkSize);
       
  5078       strm.next_out = 0;
       
  5079       strm.avail_out = chunkSize;
       
  5080     }
       
  5081     status = zlib_deflate.deflate(strm, _mode);    /* no bad return value */
       
  5082 
       
  5083     if (status !== Z_STREAM_END && status !== Z_OK) {
       
  5084       this.onEnd(status);
       
  5085       this.ended = true;
       
  5086       return false;
       
  5087     }
       
  5088     if (strm.avail_out === 0 || (strm.avail_in === 0 && (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH))) {
       
  5089       if (this.options.to === 'string') {
       
  5090         this.onData(strings.buf2binstring(utils.shrinkBuf(strm.output, strm.next_out)));
       
  5091       } else {
       
  5092         this.onData(utils.shrinkBuf(strm.output, strm.next_out));
       
  5093       }
       
  5094     }
       
  5095   } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== Z_STREAM_END);
       
  5096 
       
  5097   // Finalize on the last chunk.
       
  5098   if (_mode === Z_FINISH) {
       
  5099     status = zlib_deflate.deflateEnd(this.strm);
       
  5100     this.onEnd(status);
       
  5101     this.ended = true;
       
  5102     return status === Z_OK;
       
  5103   }
       
  5104 
       
  5105   // callback interim results if Z_SYNC_FLUSH.
       
  5106   if (_mode === Z_SYNC_FLUSH) {
       
  5107     this.onEnd(Z_OK);
       
  5108     strm.avail_out = 0;
       
  5109     return true;
       
  5110   }
       
  5111 
       
  5112   return true;
       
  5113 };
       
  5114 
       
  5115 
       
  5116 /**
       
  5117  * Deflate#onData(chunk) -> Void
       
  5118  * - chunk (Uint8Array|Array|String): ouput data. Type of array depends
       
  5119  *   on js engine support. When string output requested, each chunk
       
  5120  *   will be string.
       
  5121  *
       
  5122  * By default, stores data blocks in `chunks[]` property and glue
       
  5123  * those in `onEnd`. Override this handler, if you need another behaviour.
       
  5124  **/
       
  5125 Deflate.prototype.onData = function (chunk) {
       
  5126   this.chunks.push(chunk);
       
  5127 };
       
  5128 
       
  5129 
       
  5130 /**
       
  5131  * Deflate#onEnd(status) -> Void
       
  5132  * - status (Number): deflate status. 0 (Z_OK) on success,
       
  5133  *   other if not.
       
  5134  *
       
  5135  * Called once after you tell deflate that the input stream is
       
  5136  * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)
       
  5137  * or if an error happened. By default - join collected chunks,
       
  5138  * free memory and fill `results` / `err` properties.
       
  5139  **/
       
  5140 Deflate.prototype.onEnd = function (status) {
       
  5141   // On success - join
       
  5142   if (status === Z_OK) {
       
  5143     if (this.options.to === 'string') {
       
  5144       this.result = this.chunks.join('');
       
  5145     } else {
       
  5146       this.result = utils.flattenChunks(this.chunks);
       
  5147     }
       
  5148   }
       
  5149   this.chunks = [];
       
  5150   this.err = status;
       
  5151   this.msg = this.strm.msg;
       
  5152 };
       
  5153 
       
  5154 
       
  5155 /**
       
  5156  * deflate(data[, options]) -> Uint8Array|Array|String
       
  5157  * - data (Uint8Array|Array|String): input data to compress.
       
  5158  * - options (Object): zlib deflate options.
       
  5159  *
       
  5160  * Compress `data` with deflate algorithm and `options`.
       
  5161  *
       
  5162  * Supported options are:
       
  5163  *
       
  5164  * - level
       
  5165  * - windowBits
       
  5166  * - memLevel
       
  5167  * - strategy
       
  5168  * - dictionary
       
  5169  *
       
  5170  * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)
       
  5171  * for more information on these.
       
  5172  *
       
  5173  * Sugar (options):
       
  5174  *
       
  5175  * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify
       
  5176  *   negative windowBits implicitly.
       
  5177  * - `to` (String) - if equal to 'string', then result will be "binary string"
       
  5178  *    (each char code [0..255])
       
  5179  *
       
  5180  * ##### Example:
       
  5181  *
       
  5182  * ```javascript
       
  5183  * var pako = require('pako')
       
  5184  *   , data = Uint8Array([1,2,3,4,5,6,7,8,9]);
       
  5185  *
       
  5186  * console.log(pako.deflate(data));
       
  5187  * ```
       
  5188  **/
       
  5189 function deflate(input, options) {
       
  5190   var deflator = new Deflate(options);
       
  5191 
       
  5192   deflator.push(input, true);
       
  5193 
       
  5194   // That will never happens, if you don't cheat with options :)
       
  5195   if (deflator.err) { throw deflator.msg || msg[deflator.err]; }
       
  5196 
       
  5197   return deflator.result;
       
  5198 }
       
  5199 
       
  5200 
       
  5201 /**
       
  5202  * deflateRaw(data[, options]) -> Uint8Array|Array|String
       
  5203  * - data (Uint8Array|Array|String): input data to compress.
       
  5204  * - options (Object): zlib deflate options.
       
  5205  *
       
  5206  * The same as [[deflate]], but creates raw data, without wrapper
       
  5207  * (header and adler32 crc).
       
  5208  **/
       
  5209 function deflateRaw(input, options) {
       
  5210   options = options || {};
       
  5211   options.raw = true;
       
  5212   return deflate(input, options);
       
  5213 }
       
  5214 
       
  5215 
       
  5216 /**
       
  5217  * gzip(data[, options]) -> Uint8Array|Array|String
       
  5218  * - data (Uint8Array|Array|String): input data to compress.
       
  5219  * - options (Object): zlib deflate options.
       
  5220  *
       
  5221  * The same as [[deflate]], but create gzip wrapper instead of
       
  5222  * deflate one.
       
  5223  **/
       
  5224 function gzip(input, options) {
       
  5225   options = options || {};
       
  5226   options.gzip = true;
       
  5227   return deflate(input, options);
       
  5228 }
       
  5229 
       
  5230 
       
  5231 exports.Deflate = Deflate;
       
  5232 exports.deflate = deflate;
       
  5233 exports.deflateRaw = deflateRaw;
       
  5234 exports.gzip = gzip;
       
  5235 
       
  5236 },{"./utils/common":62,"./utils/strings":63,"./zlib/deflate":67,"./zlib/messages":72,"./zlib/zstream":74}],61:[function(require,module,exports){
       
  5237 'use strict';
       
  5238 
       
  5239 
       
  5240 var zlib_inflate = require('./zlib/inflate');
       
  5241 var utils        = require('./utils/common');
       
  5242 var strings      = require('./utils/strings');
       
  5243 var c            = require('./zlib/constants');
       
  5244 var msg          = require('./zlib/messages');
       
  5245 var ZStream      = require('./zlib/zstream');
       
  5246 var GZheader     = require('./zlib/gzheader');
       
  5247 
       
  5248 var toString = Object.prototype.toString;
       
  5249 
       
  5250 /**
       
  5251  * class Inflate
       
  5252  *
       
  5253  * Generic JS-style wrapper for zlib calls. If you don't need
       
  5254  * streaming behaviour - use more simple functions: [[inflate]]
       
  5255  * and [[inflateRaw]].
       
  5256  **/
       
  5257 
       
  5258 /* internal
       
  5259  * inflate.chunks -> Array
       
  5260  *
       
  5261  * Chunks of output data, if [[Inflate#onData]] not overriden.
       
  5262  **/
       
  5263 
       
  5264 /**
       
  5265  * Inflate.result -> Uint8Array|Array|String
       
  5266  *
       
  5267  * Uncompressed result, generated by default [[Inflate#onData]]
       
  5268  * and [[Inflate#onEnd]] handlers. Filled after you push last chunk
       
  5269  * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you
       
  5270  * push a chunk with explicit flush (call [[Inflate#push]] with
       
  5271  * `Z_SYNC_FLUSH` param).
       
  5272  **/
       
  5273 
       
  5274 /**
       
  5275  * Inflate.err -> Number
       
  5276  *
       
  5277  * Error code after inflate finished. 0 (Z_OK) on success.
       
  5278  * Should be checked if broken data possible.
       
  5279  **/
       
  5280 
       
  5281 /**
       
  5282  * Inflate.msg -> String
       
  5283  *
       
  5284  * Error message, if [[Inflate.err]] != 0
       
  5285  **/
       
  5286 
       
  5287 
       
  5288 /**
       
  5289  * new Inflate(options)
       
  5290  * - options (Object): zlib inflate options.
       
  5291  *
       
  5292  * Creates new inflator instance with specified params. Throws exception
       
  5293  * on bad params. Supported options:
       
  5294  *
       
  5295  * - `windowBits`
       
  5296  * - `dictionary`
       
  5297  *
       
  5298  * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)
       
  5299  * for more information on these.
       
  5300  *
       
  5301  * Additional options, for internal needs:
       
  5302  *
       
  5303  * - `chunkSize` - size of generated data chunks (16K by default)
       
  5304  * - `raw` (Boolean) - do raw inflate
       
  5305  * - `to` (String) - if equal to 'string', then result will be converted
       
  5306  *   from utf8 to utf16 (javascript) string. When string output requested,
       
  5307  *   chunk length can differ from `chunkSize`, depending on content.
       
  5308  *
       
  5309  * By default, when no options set, autodetect deflate/gzip data format via
       
  5310  * wrapper header.
       
  5311  *
       
  5312  * ##### Example:
       
  5313  *
       
  5314  * ```javascript
       
  5315  * var pako = require('pako')
       
  5316  *   , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])
       
  5317  *   , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);
       
  5318  *
       
  5319  * var inflate = new pako.Inflate({ level: 3});
       
  5320  *
       
  5321  * inflate.push(chunk1, false);
       
  5322  * inflate.push(chunk2, true);  // true -> last chunk
       
  5323  *
       
  5324  * if (inflate.err) { throw new Error(inflate.err); }
       
  5325  *
       
  5326  * console.log(inflate.result);
       
  5327  * ```
       
  5328  **/
       
  5329 function Inflate(options) {
       
  5330   if (!(this instanceof Inflate)) return new Inflate(options);
       
  5331 
       
  5332   this.options = utils.assign({
       
  5333     chunkSize: 16384,
       
  5334     windowBits: 0,
       
  5335     to: ''
       
  5336   }, options || {});
       
  5337 
       
  5338   var opt = this.options;
       
  5339 
       
  5340   // Force window size for `raw` data, if not set directly,
       
  5341   // because we have no header for autodetect.
       
  5342   if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {
       
  5343     opt.windowBits = -opt.windowBits;
       
  5344     if (opt.windowBits === 0) { opt.windowBits = -15; }
       
  5345   }
       
  5346 
       
  5347   // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate
       
  5348   if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&
       
  5349       !(options && options.windowBits)) {
       
  5350     opt.windowBits += 32;
       
  5351   }
       
  5352 
       
  5353   // Gzip header has no info about windows size, we can do autodetect only
       
  5354   // for deflate. So, if window size not set, force it to max when gzip possible
       
  5355   if ((opt.windowBits > 15) && (opt.windowBits < 48)) {
       
  5356     // bit 3 (16) -> gzipped data
       
  5357     // bit 4 (32) -> autodetect gzip/deflate
       
  5358     if ((opt.windowBits & 15) === 0) {
       
  5359       opt.windowBits |= 15;
       
  5360     }
       
  5361   }
       
  5362 
       
  5363   this.err    = 0;      // error code, if happens (0 = Z_OK)
       
  5364   this.msg    = '';     // error message
       
  5365   this.ended  = false;  // used to avoid multiple onEnd() calls
       
  5366   this.chunks = [];     // chunks of compressed data
       
  5367 
       
  5368   this.strm   = new ZStream();
       
  5369   this.strm.avail_out = 0;
       
  5370 
       
  5371   var status  = zlib_inflate.inflateInit2(
       
  5372     this.strm,
       
  5373     opt.windowBits
       
  5374   );
       
  5375 
       
  5376   if (status !== c.Z_OK) {
       
  5377     throw new Error(msg[status]);
       
  5378   }
       
  5379 
       
  5380   this.header = new GZheader();
       
  5381 
       
  5382   zlib_inflate.inflateGetHeader(this.strm, this.header);
       
  5383 }
       
  5384 
       
  5385 /**
       
  5386  * Inflate#push(data[, mode]) -> Boolean
       
  5387  * - data (Uint8Array|Array|ArrayBuffer|String): input data
       
  5388  * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.
       
  5389  *   See constants. Skipped or `false` means Z_NO_FLUSH, `true` meansh Z_FINISH.
       
  5390  *
       
  5391  * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with
       
  5392  * new output chunks. Returns `true` on success. The last data block must have
       
  5393  * mode Z_FINISH (or `true`). That will flush internal pending buffers and call
       
  5394  * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you
       
  5395  * can use mode Z_SYNC_FLUSH, keeping the decompression context.
       
  5396  *
       
  5397  * On fail call [[Inflate#onEnd]] with error code and return false.
       
  5398  *
       
  5399  * We strongly recommend to use `Uint8Array` on input for best speed (output
       
  5400  * format is detected automatically). Also, don't skip last param and always
       
  5401  * use the same type in your code (boolean or number). That will improve JS speed.
       
  5402  *
       
  5403  * For regular `Array`-s make sure all elements are [0..255].
       
  5404  *
       
  5405  * ##### Example
       
  5406  *
       
  5407  * ```javascript
       
  5408  * push(chunk, false); // push one of data chunks
       
  5409  * ...
       
  5410  * push(chunk, true);  // push last chunk
       
  5411  * ```
       
  5412  **/
       
  5413 Inflate.prototype.push = function (data, mode) {
       
  5414   var strm = this.strm;
       
  5415   var chunkSize = this.options.chunkSize;
       
  5416   var dictionary = this.options.dictionary;
       
  5417   var status, _mode;
       
  5418   var next_out_utf8, tail, utf8str;
       
  5419   var dict;
       
  5420 
       
  5421   // Flag to properly process Z_BUF_ERROR on testing inflate call
       
  5422   // when we check that all output data was flushed.
       
  5423   var allowBufError = false;
       
  5424 
       
  5425   if (this.ended) { return false; }
       
  5426   _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);
       
  5427 
       
  5428   // Convert data if needed
       
  5429   if (typeof data === 'string') {
       
  5430     // Only binary strings can be decompressed on practice
       
  5431     strm.input = strings.binstring2buf(data);
       
  5432   } else if (toString.call(data) === '[object ArrayBuffer]') {
       
  5433     strm.input = new Uint8Array(data);
       
  5434   } else {
       
  5435     strm.input = data;
       
  5436   }
       
  5437 
       
  5438   strm.next_in = 0;
       
  5439   strm.avail_in = strm.input.length;
       
  5440 
       
  5441   do {
       
  5442     if (strm.avail_out === 0) {
       
  5443       strm.output = new utils.Buf8(chunkSize);
       
  5444       strm.next_out = 0;
       
  5445       strm.avail_out = chunkSize;
       
  5446     }
       
  5447 
       
  5448     status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH);    /* no bad return value */
       
  5449 
       
  5450     if (status === c.Z_NEED_DICT && dictionary) {
       
  5451       // Convert data if needed
       
  5452       if (typeof dictionary === 'string') {
       
  5453         dict = strings.string2buf(dictionary);
       
  5454       } else if (toString.call(dictionary) === '[object ArrayBuffer]') {
       
  5455         dict = new Uint8Array(dictionary);
       
  5456       } else {
       
  5457         dict = dictionary;
       
  5458       }
       
  5459 
       
  5460       status = zlib_inflate.inflateSetDictionary(this.strm, dict);
       
  5461 
       
  5462     }
       
  5463 
       
  5464     if (status === c.Z_BUF_ERROR && allowBufError === true) {
       
  5465       status = c.Z_OK;
       
  5466       allowBufError = false;
       
  5467     }
       
  5468 
       
  5469     if (status !== c.Z_STREAM_END && status !== c.Z_OK) {
       
  5470       this.onEnd(status);
       
  5471       this.ended = true;
       
  5472       return false;
       
  5473     }
       
  5474 
       
  5475     if (strm.next_out) {
       
  5476       if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {
       
  5477 
       
  5478         if (this.options.to === 'string') {
       
  5479 
       
  5480           next_out_utf8 = strings.utf8border(strm.output, strm.next_out);
       
  5481 
       
  5482           tail = strm.next_out - next_out_utf8;
       
  5483           utf8str = strings.buf2string(strm.output, next_out_utf8);
       
  5484 
       
  5485           // move tail
       
  5486           strm.next_out = tail;
       
  5487           strm.avail_out = chunkSize - tail;
       
  5488           if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }
       
  5489 
       
  5490           this.onData(utf8str);
       
  5491 
       
  5492         } else {
       
  5493           this.onData(utils.shrinkBuf(strm.output, strm.next_out));
       
  5494         }
       
  5495       }
       
  5496     }
       
  5497 
       
  5498     // When no more input data, we should check that internal inflate buffers
       
  5499     // are flushed. The only way to do it when avail_out = 0 - run one more
       
  5500     // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.
       
  5501     // Here we set flag to process this error properly.
       
  5502     //
       
  5503     // NOTE. Deflate does not return error in this case and does not needs such
       
  5504     // logic.
       
  5505     if (strm.avail_in === 0 && strm.avail_out === 0) {
       
  5506       allowBufError = true;
       
  5507     }
       
  5508 
       
  5509   } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);
       
  5510 
       
  5511   if (status === c.Z_STREAM_END) {
       
  5512     _mode = c.Z_FINISH;
       
  5513   }
       
  5514 
       
  5515   // Finalize on the last chunk.
       
  5516   if (_mode === c.Z_FINISH) {
       
  5517     status = zlib_inflate.inflateEnd(this.strm);
       
  5518     this.onEnd(status);
       
  5519     this.ended = true;
       
  5520     return status === c.Z_OK;
       
  5521   }
       
  5522 
       
  5523   // callback interim results if Z_SYNC_FLUSH.
       
  5524   if (_mode === c.Z_SYNC_FLUSH) {
       
  5525     this.onEnd(c.Z_OK);
       
  5526     strm.avail_out = 0;
       
  5527     return true;
       
  5528   }
       
  5529 
       
  5530   return true;
       
  5531 };
       
  5532 
       
  5533 
       
  5534 /**
       
  5535  * Inflate#onData(chunk) -> Void
       
  5536  * - chunk (Uint8Array|Array|String): ouput data. Type of array depends
       
  5537  *   on js engine support. When string output requested, each chunk
       
  5538  *   will be string.
       
  5539  *
       
  5540  * By default, stores data blocks in `chunks[]` property and glue
       
  5541  * those in `onEnd`. Override this handler, if you need another behaviour.
       
  5542  **/
       
  5543 Inflate.prototype.onData = function (chunk) {
       
  5544   this.chunks.push(chunk);
       
  5545 };
       
  5546 
       
  5547 
       
  5548 /**
       
  5549  * Inflate#onEnd(status) -> Void
       
  5550  * - status (Number): inflate status. 0 (Z_OK) on success,
       
  5551  *   other if not.
       
  5552  *
       
  5553  * Called either after you tell inflate that the input stream is
       
  5554  * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)
       
  5555  * or if an error happened. By default - join collected chunks,
       
  5556  * free memory and fill `results` / `err` properties.
       
  5557  **/
       
  5558 Inflate.prototype.onEnd = function (status) {
       
  5559   // On success - join
       
  5560   if (status === c.Z_OK) {
       
  5561     if (this.options.to === 'string') {
       
  5562       // Glue & convert here, until we teach pako to send
       
  5563       // utf8 alligned strings to onData
       
  5564       this.result = this.chunks.join('');
       
  5565     } else {
       
  5566       this.result = utils.flattenChunks(this.chunks);
       
  5567     }
       
  5568   }
       
  5569   this.chunks = [];
       
  5570   this.err = status;
       
  5571   this.msg = this.strm.msg;
       
  5572 };
       
  5573 
       
  5574 
       
  5575 /**
       
  5576  * inflate(data[, options]) -> Uint8Array|Array|String
       
  5577  * - data (Uint8Array|Array|String): input data to decompress.
       
  5578  * - options (Object): zlib inflate options.
       
  5579  *
       
  5580  * Decompress `data` with inflate/ungzip and `options`. Autodetect
       
  5581  * format via wrapper header by default. That's why we don't provide
       
  5582  * separate `ungzip` method.
       
  5583  *
       
  5584  * Supported options are:
       
  5585  *
       
  5586  * - windowBits
       
  5587  *
       
  5588  * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)
       
  5589  * for more information.
       
  5590  *
       
  5591  * Sugar (options):
       
  5592  *
       
  5593  * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify
       
  5594  *   negative windowBits implicitly.
       
  5595  * - `to` (String) - if equal to 'string', then result will be converted
       
  5596  *   from utf8 to utf16 (javascript) string. When string output requested,
       
  5597  *   chunk length can differ from `chunkSize`, depending on content.
       
  5598  *
       
  5599  *
       
  5600  * ##### Example:
       
  5601  *
       
  5602  * ```javascript
       
  5603  * var pako = require('pako')
       
  5604  *   , input = pako.deflate([1,2,3,4,5,6,7,8,9])
       
  5605  *   , output;
       
  5606  *
       
  5607  * try {
       
  5608  *   output = pako.inflate(input);
       
  5609  * } catch (err)
       
  5610  *   console.log(err);
       
  5611  * }
       
  5612  * ```
       
  5613  **/
       
  5614 function inflate(input, options) {
       
  5615   var inflator = new Inflate(options);
       
  5616 
       
  5617   inflator.push(input, true);
       
  5618 
       
  5619   // That will never happens, if you don't cheat with options :)
       
  5620   if (inflator.err) { throw inflator.msg || msg[inflator.err]; }
       
  5621 
       
  5622   return inflator.result;
       
  5623 }
       
  5624 
       
  5625 
       
  5626 /**
       
  5627  * inflateRaw(data[, options]) -> Uint8Array|Array|String
       
  5628  * - data (Uint8Array|Array|String): input data to decompress.
       
  5629  * - options (Object): zlib inflate options.
       
  5630  *
       
  5631  * The same as [[inflate]], but creates raw data, without wrapper
       
  5632  * (header and adler32 crc).
       
  5633  **/
       
  5634 function inflateRaw(input, options) {
       
  5635   options = options || {};
       
  5636   options.raw = true;
       
  5637   return inflate(input, options);
       
  5638 }
       
  5639 
       
  5640 
       
  5641 /**
       
  5642  * ungzip(data[, options]) -> Uint8Array|Array|String
       
  5643  * - data (Uint8Array|Array|String): input data to decompress.
       
  5644  * - options (Object): zlib inflate options.
       
  5645  *
       
  5646  * Just shortcut to [[inflate]], because it autodetects format
       
  5647  * by header.content. Done for convenience.
       
  5648  **/
       
  5649 
       
  5650 
       
  5651 exports.Inflate = Inflate;
       
  5652 exports.inflate = inflate;
       
  5653 exports.inflateRaw = inflateRaw;
       
  5654 exports.ungzip  = inflate;
       
  5655 
       
  5656 },{"./utils/common":62,"./utils/strings":63,"./zlib/constants":65,"./zlib/gzheader":68,"./zlib/inflate":70,"./zlib/messages":72,"./zlib/zstream":74}],62:[function(require,module,exports){
       
  5657 'use strict';
       
  5658 
       
  5659 
       
  5660 var TYPED_OK =  (typeof Uint8Array !== 'undefined') &&
       
  5661                 (typeof Uint16Array !== 'undefined') &&
       
  5662                 (typeof Int32Array !== 'undefined');
       
  5663 
       
  5664 
       
  5665 exports.assign = function (obj /*from1, from2, from3, ...*/) {
       
  5666   var sources = Array.prototype.slice.call(arguments, 1);
       
  5667   while (sources.length) {
       
  5668     var source = sources.shift();
       
  5669     if (!source) { continue; }
       
  5670 
       
  5671     if (typeof source !== 'object') {
       
  5672       throw new TypeError(source + 'must be non-object');
       
  5673     }
       
  5674 
       
  5675     for (var p in source) {
       
  5676       if (source.hasOwnProperty(p)) {
       
  5677         obj[p] = source[p];
       
  5678       }
       
  5679     }
       
  5680   }
       
  5681 
       
  5682   return obj;
       
  5683 };
       
  5684 
       
  5685 
       
  5686 // reduce buffer size, avoiding mem copy
       
  5687 exports.shrinkBuf = function (buf, size) {
       
  5688   if (buf.length === size) { return buf; }
       
  5689   if (buf.subarray) { return buf.subarray(0, size); }
       
  5690   buf.length = size;
       
  5691   return buf;
       
  5692 };
       
  5693 
       
  5694 
       
  5695 var fnTyped = {
       
  5696   arraySet: function (dest, src, src_offs, len, dest_offs) {
       
  5697     if (src.subarray && dest.subarray) {
       
  5698       dest.set(src.subarray(src_offs, src_offs + len), dest_offs);
       
  5699       return;
       
  5700     }
       
  5701     // Fallback to ordinary array
       
  5702     for (var i = 0; i < len; i++) {
       
  5703       dest[dest_offs + i] = src[src_offs + i];
       
  5704     }
       
  5705   },
       
  5706   // Join array of chunks to single array.
       
  5707   flattenChunks: function (chunks) {
       
  5708     var i, l, len, pos, chunk, result;
       
  5709 
       
  5710     // calculate data length
       
  5711     len = 0;
       
  5712     for (i = 0, l = chunks.length; i < l; i++) {
       
  5713       len += chunks[i].length;
       
  5714     }
       
  5715 
       
  5716     // join chunks
       
  5717     result = new Uint8Array(len);
       
  5718     pos = 0;
       
  5719     for (i = 0, l = chunks.length; i < l; i++) {
       
  5720       chunk = chunks[i];
       
  5721       result.set(chunk, pos);
       
  5722       pos += chunk.length;
       
  5723     }
       
  5724 
       
  5725     return result;
       
  5726   }
       
  5727 };
       
  5728 
       
  5729 var fnUntyped = {
       
  5730   arraySet: function (dest, src, src_offs, len, dest_offs) {
       
  5731     for (var i = 0; i < len; i++) {
       
  5732       dest[dest_offs + i] = src[src_offs + i];
       
  5733     }
       
  5734   },
       
  5735   // Join array of chunks to single array.
       
  5736   flattenChunks: function (chunks) {
       
  5737     return [].concat.apply([], chunks);
       
  5738   }
       
  5739 };
       
  5740 
       
  5741 
       
  5742 // Enable/Disable typed arrays use, for testing
       
  5743 //
       
  5744 exports.setTyped = function (on) {
       
  5745   if (on) {
       
  5746     exports.Buf8  = Uint8Array;
       
  5747     exports.Buf16 = Uint16Array;
       
  5748     exports.Buf32 = Int32Array;
       
  5749     exports.assign(exports, fnTyped);
       
  5750   } else {
       
  5751     exports.Buf8  = Array;
       
  5752     exports.Buf16 = Array;
       
  5753     exports.Buf32 = Array;
       
  5754     exports.assign(exports, fnUntyped);
       
  5755   }
       
  5756 };
       
  5757 
       
  5758 exports.setTyped(TYPED_OK);
       
  5759 
       
  5760 },{}],63:[function(require,module,exports){
       
  5761 // String encode/decode helpers
       
  5762 'use strict';
       
  5763 
       
  5764 
       
  5765 var utils = require('./common');
       
  5766 
       
  5767 
       
  5768 // Quick check if we can use fast array to bin string conversion
       
  5769 //
       
  5770 // - apply(Array) can fail on Android 2.2
       
  5771 // - apply(Uint8Array) can fail on iOS 5.1 Safary
       
  5772 //
       
  5773 var STR_APPLY_OK = true;
       
  5774 var STR_APPLY_UIA_OK = true;
       
  5775 
       
  5776 try { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }
       
  5777 try { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }
       
  5778 
       
  5779 
       
  5780 // Table with utf8 lengths (calculated by first byte of sequence)
       
  5781 // Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,
       
  5782 // because max possible codepoint is 0x10ffff
       
  5783 var _utf8len = new utils.Buf8(256);
       
  5784 for (var q = 0; q < 256; q++) {
       
  5785   _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);
       
  5786 }
       
  5787 _utf8len[254] = _utf8len[254] = 1; // Invalid sequence start
       
  5788 
       
  5789 
       
  5790 // convert string to array (typed, when possible)
       
  5791 exports.string2buf = function (str) {
       
  5792   var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;
       
  5793 
       
  5794   // count binary size
       
  5795   for (m_pos = 0; m_pos < str_len; m_pos++) {
       
  5796     c = str.charCodeAt(m_pos);
       
  5797     if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {
       
  5798       c2 = str.charCodeAt(m_pos + 1);
       
  5799       if ((c2 & 0xfc00) === 0xdc00) {
       
  5800         c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);
       
  5801         m_pos++;
       
  5802       }
       
  5803     }
       
  5804     buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;
       
  5805   }
       
  5806 
       
  5807   // allocate buffer
       
  5808   buf = new utils.Buf8(buf_len);
       
  5809 
       
  5810   // convert
       
  5811   for (i = 0, m_pos = 0; i < buf_len; m_pos++) {
       
  5812     c = str.charCodeAt(m_pos);
       
  5813     if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {
       
  5814       c2 = str.charCodeAt(m_pos + 1);
       
  5815       if ((c2 & 0xfc00) === 0xdc00) {
       
  5816         c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);
       
  5817         m_pos++;
       
  5818       }
       
  5819     }
       
  5820     if (c < 0x80) {
       
  5821       /* one byte */
       
  5822       buf[i++] = c;
       
  5823     } else if (c < 0x800) {
       
  5824       /* two bytes */
       
  5825       buf[i++] = 0xC0 | (c >>> 6);
       
  5826       buf[i++] = 0x80 | (c & 0x3f);
       
  5827     } else if (c < 0x10000) {
       
  5828       /* three bytes */
       
  5829       buf[i++] = 0xE0 | (c >>> 12);
       
  5830       buf[i++] = 0x80 | (c >>> 6 & 0x3f);
       
  5831       buf[i++] = 0x80 | (c & 0x3f);
       
  5832     } else {
       
  5833       /* four bytes */
       
  5834       buf[i++] = 0xf0 | (c >>> 18);
       
  5835       buf[i++] = 0x80 | (c >>> 12 & 0x3f);
       
  5836       buf[i++] = 0x80 | (c >>> 6 & 0x3f);
       
  5837       buf[i++] = 0x80 | (c & 0x3f);
       
  5838     }
       
  5839   }
       
  5840 
       
  5841   return buf;
       
  5842 };
       
  5843 
       
  5844 // Helper (used in 2 places)
       
  5845 function buf2binstring(buf, len) {
       
  5846   // use fallback for big arrays to avoid stack overflow
       
  5847   if (len < 65537) {
       
  5848     if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {
       
  5849       return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));
       
  5850     }
       
  5851   }
       
  5852 
       
  5853   var result = '';
       
  5854   for (var i = 0; i < len; i++) {
       
  5855     result += String.fromCharCode(buf[i]);
       
  5856   }
       
  5857   return result;
       
  5858 }
       
  5859 
       
  5860 
       
  5861 // Convert byte array to binary string
       
  5862 exports.buf2binstring = function (buf) {
       
  5863   return buf2binstring(buf, buf.length);
       
  5864 };
       
  5865 
       
  5866 
       
  5867 // Convert binary string (typed, when possible)
       
  5868 exports.binstring2buf = function (str) {
       
  5869   var buf = new utils.Buf8(str.length);
       
  5870   for (var i = 0, len = buf.length; i < len; i++) {
       
  5871     buf[i] = str.charCodeAt(i);
       
  5872   }
       
  5873   return buf;
       
  5874 };
       
  5875 
       
  5876 
       
  5877 // convert array to string
       
  5878 exports.buf2string = function (buf, max) {
       
  5879   var i, out, c, c_len;
       
  5880   var len = max || buf.length;
       
  5881 
       
  5882   // Reserve max possible length (2 words per char)
       
  5883   // NB: by unknown reasons, Array is significantly faster for
       
  5884   //     String.fromCharCode.apply than Uint16Array.
       
  5885   var utf16buf = new Array(len * 2);
       
  5886 
       
  5887   for (out = 0, i = 0; i < len;) {
       
  5888     c = buf[i++];
       
  5889     // quick process ascii
       
  5890     if (c < 0x80) { utf16buf[out++] = c; continue; }
       
  5891 
       
  5892     c_len = _utf8len[c];
       
  5893     // skip 5 & 6 byte codes
       
  5894     if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }
       
  5895 
       
  5896     // apply mask on first byte
       
  5897     c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;
       
  5898     // join the rest
       
  5899     while (c_len > 1 && i < len) {
       
  5900       c = (c << 6) | (buf[i++] & 0x3f);
       
  5901       c_len--;
       
  5902     }
       
  5903 
       
  5904     // terminated by end of string?
       
  5905     if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }
       
  5906 
       
  5907     if (c < 0x10000) {
       
  5908       utf16buf[out++] = c;
       
  5909     } else {
       
  5910       c -= 0x10000;
       
  5911       utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);
       
  5912       utf16buf[out++] = 0xdc00 | (c & 0x3ff);
       
  5913     }
       
  5914   }
       
  5915 
       
  5916   return buf2binstring(utf16buf, out);
       
  5917 };
       
  5918 
       
  5919 
       
  5920 // Calculate max possible position in utf8 buffer,
       
  5921 // that will not break sequence. If that's not possible
       
  5922 // - (very small limits) return max size as is.
       
  5923 //
       
  5924 // buf[] - utf8 bytes array
       
  5925 // max   - length limit (mandatory);
       
  5926 exports.utf8border = function (buf, max) {
       
  5927   var pos;
       
  5928 
       
  5929   max = max || buf.length;
       
  5930   if (max > buf.length) { max = buf.length; }
       
  5931 
       
  5932   // go back from last position, until start of sequence found
       
  5933   pos = max - 1;
       
  5934   while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }
       
  5935 
       
  5936   // Fuckup - very small and broken sequence,
       
  5937   // return max, because we should return something anyway.
       
  5938   if (pos < 0) { return max; }
       
  5939 
       
  5940   // If we came to start of buffer - that means vuffer is too small,
       
  5941   // return max too.
       
  5942   if (pos === 0) { return max; }
       
  5943 
       
  5944   return (pos + _utf8len[buf[pos]] > max) ? pos : max;
       
  5945 };
       
  5946 
       
  5947 },{"./common":62}],64:[function(require,module,exports){
       
  5948 'use strict';
       
  5949 
       
  5950 // Note: adler32 takes 12% for level 0 and 2% for level 6.
       
  5951 // It doesn't worth to make additional optimizationa as in original.
       
  5952 // Small size is preferable.
       
  5953 
       
  5954 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  5955 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  5956 //
       
  5957 // This software is provided 'as-is', without any express or implied
       
  5958 // warranty. In no event will the authors be held liable for any damages
       
  5959 // arising from the use of this software.
       
  5960 //
       
  5961 // Permission is granted to anyone to use this software for any purpose,
       
  5962 // including commercial applications, and to alter it and redistribute it
       
  5963 // freely, subject to the following restrictions:
       
  5964 //
       
  5965 // 1. The origin of this software must not be misrepresented; you must not
       
  5966 //   claim that you wrote the original software. If you use this software
       
  5967 //   in a product, an acknowledgment in the product documentation would be
       
  5968 //   appreciated but is not required.
       
  5969 // 2. Altered source versions must be plainly marked as such, and must not be
       
  5970 //   misrepresented as being the original software.
       
  5971 // 3. This notice may not be removed or altered from any source distribution.
       
  5972 
       
  5973 function adler32(adler, buf, len, pos) {
       
  5974   var s1 = (adler & 0xffff) |0,
       
  5975       s2 = ((adler >>> 16) & 0xffff) |0,
       
  5976       n = 0;
       
  5977 
       
  5978   while (len !== 0) {
       
  5979     // Set limit ~ twice less than 5552, to keep
       
  5980     // s2 in 31-bits, because we force signed ints.
       
  5981     // in other case %= will fail.
       
  5982     n = len > 2000 ? 2000 : len;
       
  5983     len -= n;
       
  5984 
       
  5985     do {
       
  5986       s1 = (s1 + buf[pos++]) |0;
       
  5987       s2 = (s2 + s1) |0;
       
  5988     } while (--n);
       
  5989 
       
  5990     s1 %= 65521;
       
  5991     s2 %= 65521;
       
  5992   }
       
  5993 
       
  5994   return (s1 | (s2 << 16)) |0;
       
  5995 }
       
  5996 
       
  5997 
       
  5998 module.exports = adler32;
       
  5999 
       
  6000 },{}],65:[function(require,module,exports){
       
  6001 'use strict';
       
  6002 
       
  6003 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  6004 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  6005 //
       
  6006 // This software is provided 'as-is', without any express or implied
       
  6007 // warranty. In no event will the authors be held liable for any damages
       
  6008 // arising from the use of this software.
       
  6009 //
       
  6010 // Permission is granted to anyone to use this software for any purpose,
       
  6011 // including commercial applications, and to alter it and redistribute it
       
  6012 // freely, subject to the following restrictions:
       
  6013 //
       
  6014 // 1. The origin of this software must not be misrepresented; you must not
       
  6015 //   claim that you wrote the original software. If you use this software
       
  6016 //   in a product, an acknowledgment in the product documentation would be
       
  6017 //   appreciated but is not required.
       
  6018 // 2. Altered source versions must be plainly marked as such, and must not be
       
  6019 //   misrepresented as being the original software.
       
  6020 // 3. This notice may not be removed or altered from any source distribution.
       
  6021 
       
  6022 module.exports = {
       
  6023 
       
  6024   /* Allowed flush values; see deflate() and inflate() below for details */
       
  6025   Z_NO_FLUSH:         0,
       
  6026   Z_PARTIAL_FLUSH:    1,
       
  6027   Z_SYNC_FLUSH:       2,
       
  6028   Z_FULL_FLUSH:       3,
       
  6029   Z_FINISH:           4,
       
  6030   Z_BLOCK:            5,
       
  6031   Z_TREES:            6,
       
  6032 
       
  6033   /* Return codes for the compression/decompression functions. Negative values
       
  6034   * are errors, positive values are used for special but normal events.
       
  6035   */
       
  6036   Z_OK:               0,
       
  6037   Z_STREAM_END:       1,
       
  6038   Z_NEED_DICT:        2,
       
  6039   Z_ERRNO:           -1,
       
  6040   Z_STREAM_ERROR:    -2,
       
  6041   Z_DATA_ERROR:      -3,
       
  6042   //Z_MEM_ERROR:     -4,
       
  6043   Z_BUF_ERROR:       -5,
       
  6044   //Z_VERSION_ERROR: -6,
       
  6045 
       
  6046   /* compression levels */
       
  6047   Z_NO_COMPRESSION:         0,
       
  6048   Z_BEST_SPEED:             1,
       
  6049   Z_BEST_COMPRESSION:       9,
       
  6050   Z_DEFAULT_COMPRESSION:   -1,
       
  6051 
       
  6052 
       
  6053   Z_FILTERED:               1,
       
  6054   Z_HUFFMAN_ONLY:           2,
       
  6055   Z_RLE:                    3,
       
  6056   Z_FIXED:                  4,
       
  6057   Z_DEFAULT_STRATEGY:       0,
       
  6058 
       
  6059   /* Possible values of the data_type field (though see inflate()) */
       
  6060   Z_BINARY:                 0,
       
  6061   Z_TEXT:                   1,
       
  6062   //Z_ASCII:                1, // = Z_TEXT (deprecated)
       
  6063   Z_UNKNOWN:                2,
       
  6064 
       
  6065   /* The deflate compression method */
       
  6066   Z_DEFLATED:               8
       
  6067   //Z_NULL:                 null // Use -1 or null inline, depending on var type
       
  6068 };
       
  6069 
       
  6070 },{}],66:[function(require,module,exports){
       
  6071 'use strict';
       
  6072 
       
  6073 // Note: we can't get significant speed boost here.
       
  6074 // So write code to minimize size - no pregenerated tables
       
  6075 // and array tools dependencies.
       
  6076 
       
  6077 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  6078 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  6079 //
       
  6080 // This software is provided 'as-is', without any express or implied
       
  6081 // warranty. In no event will the authors be held liable for any damages
       
  6082 // arising from the use of this software.
       
  6083 //
       
  6084 // Permission is granted to anyone to use this software for any purpose,
       
  6085 // including commercial applications, and to alter it and redistribute it
       
  6086 // freely, subject to the following restrictions:
       
  6087 //
       
  6088 // 1. The origin of this software must not be misrepresented; you must not
       
  6089 //   claim that you wrote the original software. If you use this software
       
  6090 //   in a product, an acknowledgment in the product documentation would be
       
  6091 //   appreciated but is not required.
       
  6092 // 2. Altered source versions must be plainly marked as such, and must not be
       
  6093 //   misrepresented as being the original software.
       
  6094 // 3. This notice may not be removed or altered from any source distribution.
       
  6095 
       
  6096 // Use ordinary array, since untyped makes no boost here
       
  6097 function makeTable() {
       
  6098   var c, table = [];
       
  6099 
       
  6100   for (var n = 0; n < 256; n++) {
       
  6101     c = n;
       
  6102     for (var k = 0; k < 8; k++) {
       
  6103       c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));
       
  6104     }
       
  6105     table[n] = c;
       
  6106   }
       
  6107 
       
  6108   return table;
       
  6109 }
       
  6110 
       
  6111 // Create table on load. Just 255 signed longs. Not a problem.
       
  6112 var crcTable = makeTable();
       
  6113 
       
  6114 
       
  6115 function crc32(crc, buf, len, pos) {
       
  6116   var t = crcTable,
       
  6117       end = pos + len;
       
  6118 
       
  6119   crc ^= -1;
       
  6120 
       
  6121   for (var i = pos; i < end; i++) {
       
  6122     crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];
       
  6123   }
       
  6124 
       
  6125   return (crc ^ (-1)); // >>> 0;
       
  6126 }
       
  6127 
       
  6128 
       
  6129 module.exports = crc32;
       
  6130 
       
  6131 },{}],67:[function(require,module,exports){
       
  6132 'use strict';
       
  6133 
       
  6134 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  6135 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  6136 //
       
  6137 // This software is provided 'as-is', without any express or implied
       
  6138 // warranty. In no event will the authors be held liable for any damages
       
  6139 // arising from the use of this software.
       
  6140 //
       
  6141 // Permission is granted to anyone to use this software for any purpose,
       
  6142 // including commercial applications, and to alter it and redistribute it
       
  6143 // freely, subject to the following restrictions:
       
  6144 //
       
  6145 // 1. The origin of this software must not be misrepresented; you must not
       
  6146 //   claim that you wrote the original software. If you use this software
       
  6147 //   in a product, an acknowledgment in the product documentation would be
       
  6148 //   appreciated but is not required.
       
  6149 // 2. Altered source versions must be plainly marked as such, and must not be
       
  6150 //   misrepresented as being the original software.
       
  6151 // 3. This notice may not be removed or altered from any source distribution.
       
  6152 
       
  6153 var utils   = require('../utils/common');
       
  6154 var trees   = require('./trees');
       
  6155 var adler32 = require('./adler32');
       
  6156 var crc32   = require('./crc32');
       
  6157 var msg     = require('./messages');
       
  6158 
       
  6159 /* Public constants ==========================================================*/
       
  6160 /* ===========================================================================*/
       
  6161 
       
  6162 
       
  6163 /* Allowed flush values; see deflate() and inflate() below for details */
       
  6164 var Z_NO_FLUSH      = 0;
       
  6165 var Z_PARTIAL_FLUSH = 1;
       
  6166 //var Z_SYNC_FLUSH    = 2;
       
  6167 var Z_FULL_FLUSH    = 3;
       
  6168 var Z_FINISH        = 4;
       
  6169 var Z_BLOCK         = 5;
       
  6170 //var Z_TREES         = 6;
       
  6171 
       
  6172 
       
  6173 /* Return codes for the compression/decompression functions. Negative values
       
  6174  * are errors, positive values are used for special but normal events.
       
  6175  */
       
  6176 var Z_OK            = 0;
       
  6177 var Z_STREAM_END    = 1;
       
  6178 //var Z_NEED_DICT     = 2;
       
  6179 //var Z_ERRNO         = -1;
       
  6180 var Z_STREAM_ERROR  = -2;
       
  6181 var Z_DATA_ERROR    = -3;
       
  6182 //var Z_MEM_ERROR     = -4;
       
  6183 var Z_BUF_ERROR     = -5;
       
  6184 //var Z_VERSION_ERROR = -6;
       
  6185 
       
  6186 
       
  6187 /* compression levels */
       
  6188 //var Z_NO_COMPRESSION      = 0;
       
  6189 //var Z_BEST_SPEED          = 1;
       
  6190 //var Z_BEST_COMPRESSION    = 9;
       
  6191 var Z_DEFAULT_COMPRESSION = -1;
       
  6192 
       
  6193 
       
  6194 var Z_FILTERED            = 1;
       
  6195 var Z_HUFFMAN_ONLY        = 2;
       
  6196 var Z_RLE                 = 3;
       
  6197 var Z_FIXED               = 4;
       
  6198 var Z_DEFAULT_STRATEGY    = 0;
       
  6199 
       
  6200 /* Possible values of the data_type field (though see inflate()) */
       
  6201 //var Z_BINARY              = 0;
       
  6202 //var Z_TEXT                = 1;
       
  6203 //var Z_ASCII               = 1; // = Z_TEXT
       
  6204 var Z_UNKNOWN             = 2;
       
  6205 
       
  6206 
       
  6207 /* The deflate compression method */
       
  6208 var Z_DEFLATED  = 8;
       
  6209 
       
  6210 /*============================================================================*/
       
  6211 
       
  6212 
       
  6213 var MAX_MEM_LEVEL = 9;
       
  6214 /* Maximum value for memLevel in deflateInit2 */
       
  6215 var MAX_WBITS = 15;
       
  6216 /* 32K LZ77 window */
       
  6217 var DEF_MEM_LEVEL = 8;
       
  6218 
       
  6219 
       
  6220 var LENGTH_CODES  = 29;
       
  6221 /* number of length codes, not counting the special END_BLOCK code */
       
  6222 var LITERALS      = 256;
       
  6223 /* number of literal bytes 0..255 */
       
  6224 var L_CODES       = LITERALS + 1 + LENGTH_CODES;
       
  6225 /* number of Literal or Length codes, including the END_BLOCK code */
       
  6226 var D_CODES       = 30;
       
  6227 /* number of distance codes */
       
  6228 var BL_CODES      = 19;
       
  6229 /* number of codes used to transfer the bit lengths */
       
  6230 var HEAP_SIZE     = 2 * L_CODES + 1;
       
  6231 /* maximum heap size */
       
  6232 var MAX_BITS  = 15;
       
  6233 /* All codes must not exceed MAX_BITS bits */
       
  6234 
       
  6235 var MIN_MATCH = 3;
       
  6236 var MAX_MATCH = 258;
       
  6237 var MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);
       
  6238 
       
  6239 var PRESET_DICT = 0x20;
       
  6240 
       
  6241 var INIT_STATE = 42;
       
  6242 var EXTRA_STATE = 69;
       
  6243 var NAME_STATE = 73;
       
  6244 var COMMENT_STATE = 91;
       
  6245 var HCRC_STATE = 103;
       
  6246 var BUSY_STATE = 113;
       
  6247 var FINISH_STATE = 666;
       
  6248 
       
  6249 var BS_NEED_MORE      = 1; /* block not completed, need more input or more output */
       
  6250 var BS_BLOCK_DONE     = 2; /* block flush performed */
       
  6251 var BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */
       
  6252 var BS_FINISH_DONE    = 4; /* finish done, accept no more input or output */
       
  6253 
       
  6254 var OS_CODE = 0x03; // Unix :) . Don't detect, use this default.
       
  6255 
       
  6256 function err(strm, errorCode) {
       
  6257   strm.msg = msg[errorCode];
       
  6258   return errorCode;
       
  6259 }
       
  6260 
       
  6261 function rank(f) {
       
  6262   return ((f) << 1) - ((f) > 4 ? 9 : 0);
       
  6263 }
       
  6264 
       
  6265 function zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }
       
  6266 
       
  6267 
       
  6268 /* =========================================================================
       
  6269  * Flush as much pending output as possible. All deflate() output goes
       
  6270  * through this function so some applications may wish to modify it
       
  6271  * to avoid allocating a large strm->output buffer and copying into it.
       
  6272  * (See also read_buf()).
       
  6273  */
       
  6274 function flush_pending(strm) {
       
  6275   var s = strm.state;
       
  6276 
       
  6277   //_tr_flush_bits(s);
       
  6278   var len = s.pending;
       
  6279   if (len > strm.avail_out) {
       
  6280     len = strm.avail_out;
       
  6281   }
       
  6282   if (len === 0) { return; }
       
  6283 
       
  6284   utils.arraySet(strm.output, s.pending_buf, s.pending_out, len, strm.next_out);
       
  6285   strm.next_out += len;
       
  6286   s.pending_out += len;
       
  6287   strm.total_out += len;
       
  6288   strm.avail_out -= len;
       
  6289   s.pending -= len;
       
  6290   if (s.pending === 0) {
       
  6291     s.pending_out = 0;
       
  6292   }
       
  6293 }
       
  6294 
       
  6295 
       
  6296 function flush_block_only(s, last) {
       
  6297   trees._tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);
       
  6298   s.block_start = s.strstart;
       
  6299   flush_pending(s.strm);
       
  6300 }
       
  6301 
       
  6302 
       
  6303 function put_byte(s, b) {
       
  6304   s.pending_buf[s.pending++] = b;
       
  6305 }
       
  6306 
       
  6307 
       
  6308 /* =========================================================================
       
  6309  * Put a short in the pending buffer. The 16-bit value is put in MSB order.
       
  6310  * IN assertion: the stream state is correct and there is enough room in
       
  6311  * pending_buf.
       
  6312  */
       
  6313 function putShortMSB(s, b) {
       
  6314 //  put_byte(s, (Byte)(b >> 8));
       
  6315 //  put_byte(s, (Byte)(b & 0xff));
       
  6316   s.pending_buf[s.pending++] = (b >>> 8) & 0xff;
       
  6317   s.pending_buf[s.pending++] = b & 0xff;
       
  6318 }
       
  6319 
       
  6320 
       
  6321 /* ===========================================================================
       
  6322  * Read a new buffer from the current input stream, update the adler32
       
  6323  * and total number of bytes read.  All deflate() input goes through
       
  6324  * this function so some applications may wish to modify it to avoid
       
  6325  * allocating a large strm->input buffer and copying from it.
       
  6326  * (See also flush_pending()).
       
  6327  */
       
  6328 function read_buf(strm, buf, start, size) {
       
  6329   var len = strm.avail_in;
       
  6330 
       
  6331   if (len > size) { len = size; }
       
  6332   if (len === 0) { return 0; }
       
  6333 
       
  6334   strm.avail_in -= len;
       
  6335 
       
  6336   // zmemcpy(buf, strm->next_in, len);
       
  6337   utils.arraySet(buf, strm.input, strm.next_in, len, start);
       
  6338   if (strm.state.wrap === 1) {
       
  6339     strm.adler = adler32(strm.adler, buf, len, start);
       
  6340   }
       
  6341 
       
  6342   else if (strm.state.wrap === 2) {
       
  6343     strm.adler = crc32(strm.adler, buf, len, start);
       
  6344   }
       
  6345 
       
  6346   strm.next_in += len;
       
  6347   strm.total_in += len;
       
  6348 
       
  6349   return len;
       
  6350 }
       
  6351 
       
  6352 
       
  6353 /* ===========================================================================
       
  6354  * Set match_start to the longest match starting at the given string and
       
  6355  * return its length. Matches shorter or equal to prev_length are discarded,
       
  6356  * in which case the result is equal to prev_length and match_start is
       
  6357  * garbage.
       
  6358  * IN assertions: cur_match is the head of the hash chain for the current
       
  6359  *   string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1
       
  6360  * OUT assertion: the match length is not greater than s->lookahead.
       
  6361  */
       
  6362 function longest_match(s, cur_match) {
       
  6363   var chain_length = s.max_chain_length;      /* max hash chain length */
       
  6364   var scan = s.strstart; /* current string */
       
  6365   var match;                       /* matched string */
       
  6366   var len;                           /* length of current match */
       
  6367   var best_len = s.prev_length;              /* best match length so far */
       
  6368   var nice_match = s.nice_match;             /* stop if match long enough */
       
  6369   var limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?
       
  6370       s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;
       
  6371 
       
  6372   var _win = s.window; // shortcut
       
  6373 
       
  6374   var wmask = s.w_mask;
       
  6375   var prev  = s.prev;
       
  6376 
       
  6377   /* Stop when cur_match becomes <= limit. To simplify the code,
       
  6378    * we prevent matches with the string of window index 0.
       
  6379    */
       
  6380 
       
  6381   var strend = s.strstart + MAX_MATCH;
       
  6382   var scan_end1  = _win[scan + best_len - 1];
       
  6383   var scan_end   = _win[scan + best_len];
       
  6384 
       
  6385   /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.
       
  6386    * It is easy to get rid of this optimization if necessary.
       
  6387    */
       
  6388   // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever");
       
  6389 
       
  6390   /* Do not waste too much time if we already have a good match: */
       
  6391   if (s.prev_length >= s.good_match) {
       
  6392     chain_length >>= 2;
       
  6393   }
       
  6394   /* Do not look for matches beyond the end of the input. This is necessary
       
  6395    * to make deflate deterministic.
       
  6396    */
       
  6397   if (nice_match > s.lookahead) { nice_match = s.lookahead; }
       
  6398 
       
  6399   // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead");
       
  6400 
       
  6401   do {
       
  6402     // Assert(cur_match < s->strstart, "no future");
       
  6403     match = cur_match;
       
  6404 
       
  6405     /* Skip to next match if the match length cannot increase
       
  6406      * or if the match length is less than 2.  Note that the checks below
       
  6407      * for insufficient lookahead only occur occasionally for performance
       
  6408      * reasons.  Therefore uninitialized memory will be accessed, and
       
  6409      * conditional jumps will be made that depend on those values.
       
  6410      * However the length of the match is limited to the lookahead, so
       
  6411      * the output of deflate is not affected by the uninitialized values.
       
  6412      */
       
  6413 
       
  6414     if (_win[match + best_len]     !== scan_end  ||
       
  6415         _win[match + best_len - 1] !== scan_end1 ||
       
  6416         _win[match]                !== _win[scan] ||
       
  6417         _win[++match]              !== _win[scan + 1]) {
       
  6418       continue;
       
  6419     }
       
  6420 
       
  6421     /* The check at best_len-1 can be removed because it will be made
       
  6422      * again later. (This heuristic is not always a win.)
       
  6423      * It is not necessary to compare scan[2] and match[2] since they
       
  6424      * are always equal when the other bytes match, given that
       
  6425      * the hash keys are equal and that HASH_BITS >= 8.
       
  6426      */
       
  6427     scan += 2;
       
  6428     match++;
       
  6429     // Assert(*scan == *match, "match[2]?");
       
  6430 
       
  6431     /* We check for insufficient lookahead only every 8th comparison;
       
  6432      * the 256th check will be made at strstart+258.
       
  6433      */
       
  6434     do {
       
  6435       /*jshint noempty:false*/
       
  6436     } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&
       
  6437              _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&
       
  6438              _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&
       
  6439              _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&
       
  6440              scan < strend);
       
  6441 
       
  6442     // Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan");
       
  6443 
       
  6444     len = MAX_MATCH - (strend - scan);
       
  6445     scan = strend - MAX_MATCH;
       
  6446 
       
  6447     if (len > best_len) {
       
  6448       s.match_start = cur_match;
       
  6449       best_len = len;
       
  6450       if (len >= nice_match) {
       
  6451         break;
       
  6452       }
       
  6453       scan_end1  = _win[scan + best_len - 1];
       
  6454       scan_end   = _win[scan + best_len];
       
  6455     }
       
  6456   } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);
       
  6457 
       
  6458   if (best_len <= s.lookahead) {
       
  6459     return best_len;
       
  6460   }
       
  6461   return s.lookahead;
       
  6462 }
       
  6463 
       
  6464 
       
  6465 /* ===========================================================================
       
  6466  * Fill the window when the lookahead becomes insufficient.
       
  6467  * Updates strstart and lookahead.
       
  6468  *
       
  6469  * IN assertion: lookahead < MIN_LOOKAHEAD
       
  6470  * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD
       
  6471  *    At least one byte has been read, or avail_in == 0; reads are
       
  6472  *    performed for at least two bytes (required for the zip translate_eol
       
  6473  *    option -- not supported here).
       
  6474  */
       
  6475 function fill_window(s) {
       
  6476   var _w_size = s.w_size;
       
  6477   var p, n, m, more, str;
       
  6478 
       
  6479   //Assert(s->lookahead < MIN_LOOKAHEAD, "already enough lookahead");
       
  6480 
       
  6481   do {
       
  6482     more = s.window_size - s.lookahead - s.strstart;
       
  6483 
       
  6484     // JS ints have 32 bit, block below not needed
       
  6485     /* Deal with !@#$% 64K limit: */
       
  6486     //if (sizeof(int) <= 2) {
       
  6487     //    if (more == 0 && s->strstart == 0 && s->lookahead == 0) {
       
  6488     //        more = wsize;
       
  6489     //
       
  6490     //  } else if (more == (unsigned)(-1)) {
       
  6491     //        /* Very unlikely, but possible on 16 bit machine if
       
  6492     //         * strstart == 0 && lookahead == 1 (input done a byte at time)
       
  6493     //         */
       
  6494     //        more--;
       
  6495     //    }
       
  6496     //}
       
  6497 
       
  6498 
       
  6499     /* If the window is almost full and there is insufficient lookahead,
       
  6500      * move the upper half to the lower one to make room in the upper half.
       
  6501      */
       
  6502     if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {
       
  6503 
       
  6504       utils.arraySet(s.window, s.window, _w_size, _w_size, 0);
       
  6505       s.match_start -= _w_size;
       
  6506       s.strstart -= _w_size;
       
  6507       /* we now have strstart >= MAX_DIST */
       
  6508       s.block_start -= _w_size;
       
  6509 
       
  6510       /* Slide the hash table (could be avoided with 32 bit values
       
  6511        at the expense of memory usage). We slide even when level == 0
       
  6512        to keep the hash table consistent if we switch back to level > 0
       
  6513        later. (Using level 0 permanently is not an optimal usage of
       
  6514        zlib, so we don't care about this pathological case.)
       
  6515        */
       
  6516 
       
  6517       n = s.hash_size;
       
  6518       p = n;
       
  6519       do {
       
  6520         m = s.head[--p];
       
  6521         s.head[p] = (m >= _w_size ? m - _w_size : 0);
       
  6522       } while (--n);
       
  6523 
       
  6524       n = _w_size;
       
  6525       p = n;
       
  6526       do {
       
  6527         m = s.prev[--p];
       
  6528         s.prev[p] = (m >= _w_size ? m - _w_size : 0);
       
  6529         /* If n is not on any hash chain, prev[n] is garbage but
       
  6530          * its value will never be used.
       
  6531          */
       
  6532       } while (--n);
       
  6533 
       
  6534       more += _w_size;
       
  6535     }
       
  6536     if (s.strm.avail_in === 0) {
       
  6537       break;
       
  6538     }
       
  6539 
       
  6540     /* If there was no sliding:
       
  6541      *    strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&
       
  6542      *    more == window_size - lookahead - strstart
       
  6543      * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)
       
  6544      * => more >= window_size - 2*WSIZE + 2
       
  6545      * In the BIG_MEM or MMAP case (not yet supported),
       
  6546      *   window_size == input_size + MIN_LOOKAHEAD  &&
       
  6547      *   strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.
       
  6548      * Otherwise, window_size == 2*WSIZE so more >= 2.
       
  6549      * If there was sliding, more >= WSIZE. So in all cases, more >= 2.
       
  6550      */
       
  6551     //Assert(more >= 2, "more < 2");
       
  6552     n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);
       
  6553     s.lookahead += n;
       
  6554 
       
  6555     /* Initialize the hash value now that we have some input: */
       
  6556     if (s.lookahead + s.insert >= MIN_MATCH) {
       
  6557       str = s.strstart - s.insert;
       
  6558       s.ins_h = s.window[str];
       
  6559 
       
  6560       /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */
       
  6561       s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + 1]) & s.hash_mask;
       
  6562 //#if MIN_MATCH != 3
       
  6563 //        Call update_hash() MIN_MATCH-3 more times
       
  6564 //#endif
       
  6565       while (s.insert) {
       
  6566         /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */
       
  6567         s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;
       
  6568 
       
  6569         s.prev[str & s.w_mask] = s.head[s.ins_h];
       
  6570         s.head[s.ins_h] = str;
       
  6571         str++;
       
  6572         s.insert--;
       
  6573         if (s.lookahead + s.insert < MIN_MATCH) {
       
  6574           break;
       
  6575         }
       
  6576       }
       
  6577     }
       
  6578     /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,
       
  6579      * but this is not important since only literal bytes will be emitted.
       
  6580      */
       
  6581 
       
  6582   } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);
       
  6583 
       
  6584   /* If the WIN_INIT bytes after the end of the current data have never been
       
  6585    * written, then zero those bytes in order to avoid memory check reports of
       
  6586    * the use of uninitialized (or uninitialised as Julian writes) bytes by
       
  6587    * the longest match routines.  Update the high water mark for the next
       
  6588    * time through here.  WIN_INIT is set to MAX_MATCH since the longest match
       
  6589    * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.
       
  6590    */
       
  6591 //  if (s.high_water < s.window_size) {
       
  6592 //    var curr = s.strstart + s.lookahead;
       
  6593 //    var init = 0;
       
  6594 //
       
  6595 //    if (s.high_water < curr) {
       
  6596 //      /* Previous high water mark below current data -- zero WIN_INIT
       
  6597 //       * bytes or up to end of window, whichever is less.
       
  6598 //       */
       
  6599 //      init = s.window_size - curr;
       
  6600 //      if (init > WIN_INIT)
       
  6601 //        init = WIN_INIT;
       
  6602 //      zmemzero(s->window + curr, (unsigned)init);
       
  6603 //      s->high_water = curr + init;
       
  6604 //    }
       
  6605 //    else if (s->high_water < (ulg)curr + WIN_INIT) {
       
  6606 //      /* High water mark at or above current data, but below current data
       
  6607 //       * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up
       
  6608 //       * to end of window, whichever is less.
       
  6609 //       */
       
  6610 //      init = (ulg)curr + WIN_INIT - s->high_water;
       
  6611 //      if (init > s->window_size - s->high_water)
       
  6612 //        init = s->window_size - s->high_water;
       
  6613 //      zmemzero(s->window + s->high_water, (unsigned)init);
       
  6614 //      s->high_water += init;
       
  6615 //    }
       
  6616 //  }
       
  6617 //
       
  6618 //  Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,
       
  6619 //    "not enough room for search");
       
  6620 }
       
  6621 
       
  6622 /* ===========================================================================
       
  6623  * Copy without compression as much as possible from the input stream, return
       
  6624  * the current block state.
       
  6625  * This function does not insert new strings in the dictionary since
       
  6626  * uncompressible data is probably not useful. This function is used
       
  6627  * only for the level=0 compression option.
       
  6628  * NOTE: this function should be optimized to avoid extra copying from
       
  6629  * window to pending_buf.
       
  6630  */
       
  6631 function deflate_stored(s, flush) {
       
  6632   /* Stored blocks are limited to 0xffff bytes, pending_buf is limited
       
  6633    * to pending_buf_size, and each stored block has a 5 byte header:
       
  6634    */
       
  6635   var max_block_size = 0xffff;
       
  6636 
       
  6637   if (max_block_size > s.pending_buf_size - 5) {
       
  6638     max_block_size = s.pending_buf_size - 5;
       
  6639   }
       
  6640 
       
  6641   /* Copy as much as possible from input to output: */
       
  6642   for (;;) {
       
  6643     /* Fill the window as much as possible: */
       
  6644     if (s.lookahead <= 1) {
       
  6645 
       
  6646       //Assert(s->strstart < s->w_size+MAX_DIST(s) ||
       
  6647       //  s->block_start >= (long)s->w_size, "slide too late");
       
  6648 //      if (!(s.strstart < s.w_size + (s.w_size - MIN_LOOKAHEAD) ||
       
  6649 //        s.block_start >= s.w_size)) {
       
  6650 //        throw  new Error("slide too late");
       
  6651 //      }
       
  6652 
       
  6653       fill_window(s);
       
  6654       if (s.lookahead === 0 && flush === Z_NO_FLUSH) {
       
  6655         return BS_NEED_MORE;
       
  6656       }
       
  6657 
       
  6658       if (s.lookahead === 0) {
       
  6659         break;
       
  6660       }
       
  6661       /* flush the current block */
       
  6662     }
       
  6663     //Assert(s->block_start >= 0L, "block gone");
       
  6664 //    if (s.block_start < 0) throw new Error("block gone");
       
  6665 
       
  6666     s.strstart += s.lookahead;
       
  6667     s.lookahead = 0;
       
  6668 
       
  6669     /* Emit a stored block if pending_buf will be full: */
       
  6670     var max_start = s.block_start + max_block_size;
       
  6671 
       
  6672     if (s.strstart === 0 || s.strstart >= max_start) {
       
  6673       /* strstart == 0 is possible when wraparound on 16-bit machine */
       
  6674       s.lookahead = s.strstart - max_start;
       
  6675       s.strstart = max_start;
       
  6676       /*** FLUSH_BLOCK(s, 0); ***/
       
  6677       flush_block_only(s, false);
       
  6678       if (s.strm.avail_out === 0) {
       
  6679         return BS_NEED_MORE;
       
  6680       }
       
  6681       /***/
       
  6682 
       
  6683 
       
  6684     }
       
  6685     /* Flush if we may have to slide, otherwise block_start may become
       
  6686      * negative and the data will be gone:
       
  6687      */
       
  6688     if (s.strstart - s.block_start >= (s.w_size - MIN_LOOKAHEAD)) {
       
  6689       /*** FLUSH_BLOCK(s, 0); ***/
       
  6690       flush_block_only(s, false);
       
  6691       if (s.strm.avail_out === 0) {
       
  6692         return BS_NEED_MORE;
       
  6693       }
       
  6694       /***/
       
  6695     }
       
  6696   }
       
  6697 
       
  6698   s.insert = 0;
       
  6699 
       
  6700   if (flush === Z_FINISH) {
       
  6701     /*** FLUSH_BLOCK(s, 1); ***/
       
  6702     flush_block_only(s, true);
       
  6703     if (s.strm.avail_out === 0) {
       
  6704       return BS_FINISH_STARTED;
       
  6705     }
       
  6706     /***/
       
  6707     return BS_FINISH_DONE;
       
  6708   }
       
  6709 
       
  6710   if (s.strstart > s.block_start) {
       
  6711     /*** FLUSH_BLOCK(s, 0); ***/
       
  6712     flush_block_only(s, false);
       
  6713     if (s.strm.avail_out === 0) {
       
  6714       return BS_NEED_MORE;
       
  6715     }
       
  6716     /***/
       
  6717   }
       
  6718 
       
  6719   return BS_NEED_MORE;
       
  6720 }
       
  6721 
       
  6722 /* ===========================================================================
       
  6723  * Compress as much as possible from the input stream, return the current
       
  6724  * block state.
       
  6725  * This function does not perform lazy evaluation of matches and inserts
       
  6726  * new strings in the dictionary only for unmatched strings or for short
       
  6727  * matches. It is used only for the fast compression options.
       
  6728  */
       
  6729 function deflate_fast(s, flush) {
       
  6730   var hash_head;        /* head of the hash chain */
       
  6731   var bflush;           /* set if current block must be flushed */
       
  6732 
       
  6733   for (;;) {
       
  6734     /* Make sure that we always have enough lookahead, except
       
  6735      * at the end of the input file. We need MAX_MATCH bytes
       
  6736      * for the next match, plus MIN_MATCH bytes to insert the
       
  6737      * string following the next match.
       
  6738      */
       
  6739     if (s.lookahead < MIN_LOOKAHEAD) {
       
  6740       fill_window(s);
       
  6741       if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {
       
  6742         return BS_NEED_MORE;
       
  6743       }
       
  6744       if (s.lookahead === 0) {
       
  6745         break; /* flush the current block */
       
  6746       }
       
  6747     }
       
  6748 
       
  6749     /* Insert the string window[strstart .. strstart+2] in the
       
  6750      * dictionary, and set hash_head to the head of the hash chain:
       
  6751      */
       
  6752     hash_head = 0/*NIL*/;
       
  6753     if (s.lookahead >= MIN_MATCH) {
       
  6754       /*** INSERT_STRING(s, s.strstart, hash_head); ***/
       
  6755       s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;
       
  6756       hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
       
  6757       s.head[s.ins_h] = s.strstart;
       
  6758       /***/
       
  6759     }
       
  6760 
       
  6761     /* Find the longest match, discarding those <= prev_length.
       
  6762      * At this point we have always match_length < MIN_MATCH
       
  6763      */
       
  6764     if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {
       
  6765       /* To simplify the code, we prevent matches with the string
       
  6766        * of window index 0 (in particular we have to avoid a match
       
  6767        * of the string with itself at the start of the input file).
       
  6768        */
       
  6769       s.match_length = longest_match(s, hash_head);
       
  6770       /* longest_match() sets match_start */
       
  6771     }
       
  6772     if (s.match_length >= MIN_MATCH) {
       
  6773       // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only
       
  6774 
       
  6775       /*** _tr_tally_dist(s, s.strstart - s.match_start,
       
  6776                      s.match_length - MIN_MATCH, bflush); ***/
       
  6777       bflush = trees._tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);
       
  6778 
       
  6779       s.lookahead -= s.match_length;
       
  6780 
       
  6781       /* Insert new strings in the hash table only if the match length
       
  6782        * is not too large. This saves time but degrades compression.
       
  6783        */
       
  6784       if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {
       
  6785         s.match_length--; /* string at strstart already in table */
       
  6786         do {
       
  6787           s.strstart++;
       
  6788           /*** INSERT_STRING(s, s.strstart, hash_head); ***/
       
  6789           s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;
       
  6790           hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
       
  6791           s.head[s.ins_h] = s.strstart;
       
  6792           /***/
       
  6793           /* strstart never exceeds WSIZE-MAX_MATCH, so there are
       
  6794            * always MIN_MATCH bytes ahead.
       
  6795            */
       
  6796         } while (--s.match_length !== 0);
       
  6797         s.strstart++;
       
  6798       } else
       
  6799       {
       
  6800         s.strstart += s.match_length;
       
  6801         s.match_length = 0;
       
  6802         s.ins_h = s.window[s.strstart];
       
  6803         /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */
       
  6804         s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + 1]) & s.hash_mask;
       
  6805 
       
  6806 //#if MIN_MATCH != 3
       
  6807 //                Call UPDATE_HASH() MIN_MATCH-3 more times
       
  6808 //#endif
       
  6809         /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not
       
  6810          * matter since it will be recomputed at next deflate call.
       
  6811          */
       
  6812       }
       
  6813     } else {
       
  6814       /* No match, output a literal byte */
       
  6815       //Tracevv((stderr,"%c", s.window[s.strstart]));
       
  6816       /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/
       
  6817       bflush = trees._tr_tally(s, 0, s.window[s.strstart]);
       
  6818 
       
  6819       s.lookahead--;
       
  6820       s.strstart++;
       
  6821     }
       
  6822     if (bflush) {
       
  6823       /*** FLUSH_BLOCK(s, 0); ***/
       
  6824       flush_block_only(s, false);
       
  6825       if (s.strm.avail_out === 0) {
       
  6826         return BS_NEED_MORE;
       
  6827       }
       
  6828       /***/
       
  6829     }
       
  6830   }
       
  6831   s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);
       
  6832   if (flush === Z_FINISH) {
       
  6833     /*** FLUSH_BLOCK(s, 1); ***/
       
  6834     flush_block_only(s, true);
       
  6835     if (s.strm.avail_out === 0) {
       
  6836       return BS_FINISH_STARTED;
       
  6837     }
       
  6838     /***/
       
  6839     return BS_FINISH_DONE;
       
  6840   }
       
  6841   if (s.last_lit) {
       
  6842     /*** FLUSH_BLOCK(s, 0); ***/
       
  6843     flush_block_only(s, false);
       
  6844     if (s.strm.avail_out === 0) {
       
  6845       return BS_NEED_MORE;
       
  6846     }
       
  6847     /***/
       
  6848   }
       
  6849   return BS_BLOCK_DONE;
       
  6850 }
       
  6851 
       
  6852 /* ===========================================================================
       
  6853  * Same as above, but achieves better compression. We use a lazy
       
  6854  * evaluation for matches: a match is finally adopted only if there is
       
  6855  * no better match at the next window position.
       
  6856  */
       
  6857 function deflate_slow(s, flush) {
       
  6858   var hash_head;          /* head of hash chain */
       
  6859   var bflush;              /* set if current block must be flushed */
       
  6860 
       
  6861   var max_insert;
       
  6862 
       
  6863   /* Process the input block. */
       
  6864   for (;;) {
       
  6865     /* Make sure that we always have enough lookahead, except
       
  6866      * at the end of the input file. We need MAX_MATCH bytes
       
  6867      * for the next match, plus MIN_MATCH bytes to insert the
       
  6868      * string following the next match.
       
  6869      */
       
  6870     if (s.lookahead < MIN_LOOKAHEAD) {
       
  6871       fill_window(s);
       
  6872       if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {
       
  6873         return BS_NEED_MORE;
       
  6874       }
       
  6875       if (s.lookahead === 0) { break; } /* flush the current block */
       
  6876     }
       
  6877 
       
  6878     /* Insert the string window[strstart .. strstart+2] in the
       
  6879      * dictionary, and set hash_head to the head of the hash chain:
       
  6880      */
       
  6881     hash_head = 0/*NIL*/;
       
  6882     if (s.lookahead >= MIN_MATCH) {
       
  6883       /*** INSERT_STRING(s, s.strstart, hash_head); ***/
       
  6884       s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;
       
  6885       hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
       
  6886       s.head[s.ins_h] = s.strstart;
       
  6887       /***/
       
  6888     }
       
  6889 
       
  6890     /* Find the longest match, discarding those <= prev_length.
       
  6891      */
       
  6892     s.prev_length = s.match_length;
       
  6893     s.prev_match = s.match_start;
       
  6894     s.match_length = MIN_MATCH - 1;
       
  6895 
       
  6896     if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&
       
  6897         s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {
       
  6898       /* To simplify the code, we prevent matches with the string
       
  6899        * of window index 0 (in particular we have to avoid a match
       
  6900        * of the string with itself at the start of the input file).
       
  6901        */
       
  6902       s.match_length = longest_match(s, hash_head);
       
  6903       /* longest_match() sets match_start */
       
  6904 
       
  6905       if (s.match_length <= 5 &&
       
  6906          (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {
       
  6907 
       
  6908         /* If prev_match is also MIN_MATCH, match_start is garbage
       
  6909          * but we will ignore the current match anyway.
       
  6910          */
       
  6911         s.match_length = MIN_MATCH - 1;
       
  6912       }
       
  6913     }
       
  6914     /* If there was a match at the previous step and the current
       
  6915      * match is not better, output the previous match:
       
  6916      */
       
  6917     if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {
       
  6918       max_insert = s.strstart + s.lookahead - MIN_MATCH;
       
  6919       /* Do not insert strings in hash table beyond this. */
       
  6920 
       
  6921       //check_match(s, s.strstart-1, s.prev_match, s.prev_length);
       
  6922 
       
  6923       /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,
       
  6924                      s.prev_length - MIN_MATCH, bflush);***/
       
  6925       bflush = trees._tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);
       
  6926       /* Insert in hash table all strings up to the end of the match.
       
  6927        * strstart-1 and strstart are already inserted. If there is not
       
  6928        * enough lookahead, the last two strings are not inserted in
       
  6929        * the hash table.
       
  6930        */
       
  6931       s.lookahead -= s.prev_length - 1;
       
  6932       s.prev_length -= 2;
       
  6933       do {
       
  6934         if (++s.strstart <= max_insert) {
       
  6935           /*** INSERT_STRING(s, s.strstart, hash_head); ***/
       
  6936           s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;
       
  6937           hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
       
  6938           s.head[s.ins_h] = s.strstart;
       
  6939           /***/
       
  6940         }
       
  6941       } while (--s.prev_length !== 0);
       
  6942       s.match_available = 0;
       
  6943       s.match_length = MIN_MATCH - 1;
       
  6944       s.strstart++;
       
  6945 
       
  6946       if (bflush) {
       
  6947         /*** FLUSH_BLOCK(s, 0); ***/
       
  6948         flush_block_only(s, false);
       
  6949         if (s.strm.avail_out === 0) {
       
  6950           return BS_NEED_MORE;
       
  6951         }
       
  6952         /***/
       
  6953       }
       
  6954 
       
  6955     } else if (s.match_available) {
       
  6956       /* If there was no match at the previous position, output a
       
  6957        * single literal. If there was a match but the current match
       
  6958        * is longer, truncate the previous match to a single literal.
       
  6959        */
       
  6960       //Tracevv((stderr,"%c", s->window[s->strstart-1]));
       
  6961       /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/
       
  6962       bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);
       
  6963 
       
  6964       if (bflush) {
       
  6965         /*** FLUSH_BLOCK_ONLY(s, 0) ***/
       
  6966         flush_block_only(s, false);
       
  6967         /***/
       
  6968       }
       
  6969       s.strstart++;
       
  6970       s.lookahead--;
       
  6971       if (s.strm.avail_out === 0) {
       
  6972         return BS_NEED_MORE;
       
  6973       }
       
  6974     } else {
       
  6975       /* There is no previous match to compare with, wait for
       
  6976        * the next step to decide.
       
  6977        */
       
  6978       s.match_available = 1;
       
  6979       s.strstart++;
       
  6980       s.lookahead--;
       
  6981     }
       
  6982   }
       
  6983   //Assert (flush != Z_NO_FLUSH, "no flush?");
       
  6984   if (s.match_available) {
       
  6985     //Tracevv((stderr,"%c", s->window[s->strstart-1]));
       
  6986     /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/
       
  6987     bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);
       
  6988 
       
  6989     s.match_available = 0;
       
  6990   }
       
  6991   s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;
       
  6992   if (flush === Z_FINISH) {
       
  6993     /*** FLUSH_BLOCK(s, 1); ***/
       
  6994     flush_block_only(s, true);
       
  6995     if (s.strm.avail_out === 0) {
       
  6996       return BS_FINISH_STARTED;
       
  6997     }
       
  6998     /***/
       
  6999     return BS_FINISH_DONE;
       
  7000   }
       
  7001   if (s.last_lit) {
       
  7002     /*** FLUSH_BLOCK(s, 0); ***/
       
  7003     flush_block_only(s, false);
       
  7004     if (s.strm.avail_out === 0) {
       
  7005       return BS_NEED_MORE;
       
  7006     }
       
  7007     /***/
       
  7008   }
       
  7009 
       
  7010   return BS_BLOCK_DONE;
       
  7011 }
       
  7012 
       
  7013 
       
  7014 /* ===========================================================================
       
  7015  * For Z_RLE, simply look for runs of bytes, generate matches only of distance
       
  7016  * one.  Do not maintain a hash table.  (It will be regenerated if this run of
       
  7017  * deflate switches away from Z_RLE.)
       
  7018  */
       
  7019 function deflate_rle(s, flush) {
       
  7020   var bflush;            /* set if current block must be flushed */
       
  7021   var prev;              /* byte at distance one to match */
       
  7022   var scan, strend;      /* scan goes up to strend for length of run */
       
  7023 
       
  7024   var _win = s.window;
       
  7025 
       
  7026   for (;;) {
       
  7027     /* Make sure that we always have enough lookahead, except
       
  7028      * at the end of the input file. We need MAX_MATCH bytes
       
  7029      * for the longest run, plus one for the unrolled loop.
       
  7030      */
       
  7031     if (s.lookahead <= MAX_MATCH) {
       
  7032       fill_window(s);
       
  7033       if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH) {
       
  7034         return BS_NEED_MORE;
       
  7035       }
       
  7036       if (s.lookahead === 0) { break; } /* flush the current block */
       
  7037     }
       
  7038 
       
  7039     /* See how many times the previous byte repeats */
       
  7040     s.match_length = 0;
       
  7041     if (s.lookahead >= MIN_MATCH && s.strstart > 0) {
       
  7042       scan = s.strstart - 1;
       
  7043       prev = _win[scan];
       
  7044       if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {
       
  7045         strend = s.strstart + MAX_MATCH;
       
  7046         do {
       
  7047           /*jshint noempty:false*/
       
  7048         } while (prev === _win[++scan] && prev === _win[++scan] &&
       
  7049                  prev === _win[++scan] && prev === _win[++scan] &&
       
  7050                  prev === _win[++scan] && prev === _win[++scan] &&
       
  7051                  prev === _win[++scan] && prev === _win[++scan] &&
       
  7052                  scan < strend);
       
  7053         s.match_length = MAX_MATCH - (strend - scan);
       
  7054         if (s.match_length > s.lookahead) {
       
  7055           s.match_length = s.lookahead;
       
  7056         }
       
  7057       }
       
  7058       //Assert(scan <= s->window+(uInt)(s->window_size-1), "wild scan");
       
  7059     }
       
  7060 
       
  7061     /* Emit match if have run of MIN_MATCH or longer, else emit literal */
       
  7062     if (s.match_length >= MIN_MATCH) {
       
  7063       //check_match(s, s.strstart, s.strstart - 1, s.match_length);
       
  7064 
       
  7065       /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/
       
  7066       bflush = trees._tr_tally(s, 1, s.match_length - MIN_MATCH);
       
  7067 
       
  7068       s.lookahead -= s.match_length;
       
  7069       s.strstart += s.match_length;
       
  7070       s.match_length = 0;
       
  7071     } else {
       
  7072       /* No match, output a literal byte */
       
  7073       //Tracevv((stderr,"%c", s->window[s->strstart]));
       
  7074       /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/
       
  7075       bflush = trees._tr_tally(s, 0, s.window[s.strstart]);
       
  7076 
       
  7077       s.lookahead--;
       
  7078       s.strstart++;
       
  7079     }
       
  7080     if (bflush) {
       
  7081       /*** FLUSH_BLOCK(s, 0); ***/
       
  7082       flush_block_only(s, false);
       
  7083       if (s.strm.avail_out === 0) {
       
  7084         return BS_NEED_MORE;
       
  7085       }
       
  7086       /***/
       
  7087     }
       
  7088   }
       
  7089   s.insert = 0;
       
  7090   if (flush === Z_FINISH) {
       
  7091     /*** FLUSH_BLOCK(s, 1); ***/
       
  7092     flush_block_only(s, true);
       
  7093     if (s.strm.avail_out === 0) {
       
  7094       return BS_FINISH_STARTED;
       
  7095     }
       
  7096     /***/
       
  7097     return BS_FINISH_DONE;
       
  7098   }
       
  7099   if (s.last_lit) {
       
  7100     /*** FLUSH_BLOCK(s, 0); ***/
       
  7101     flush_block_only(s, false);
       
  7102     if (s.strm.avail_out === 0) {
       
  7103       return BS_NEED_MORE;
       
  7104     }
       
  7105     /***/
       
  7106   }
       
  7107   return BS_BLOCK_DONE;
       
  7108 }
       
  7109 
       
  7110 /* ===========================================================================
       
  7111  * For Z_HUFFMAN_ONLY, do not look for matches.  Do not maintain a hash table.
       
  7112  * (It will be regenerated if this run of deflate switches away from Huffman.)
       
  7113  */
       
  7114 function deflate_huff(s, flush) {
       
  7115   var bflush;             /* set if current block must be flushed */
       
  7116 
       
  7117   for (;;) {
       
  7118     /* Make sure that we have a literal to write. */
       
  7119     if (s.lookahead === 0) {
       
  7120       fill_window(s);
       
  7121       if (s.lookahead === 0) {
       
  7122         if (flush === Z_NO_FLUSH) {
       
  7123           return BS_NEED_MORE;
       
  7124         }
       
  7125         break;      /* flush the current block */
       
  7126       }
       
  7127     }
       
  7128 
       
  7129     /* Output a literal byte */
       
  7130     s.match_length = 0;
       
  7131     //Tracevv((stderr,"%c", s->window[s->strstart]));
       
  7132     /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/
       
  7133     bflush = trees._tr_tally(s, 0, s.window[s.strstart]);
       
  7134     s.lookahead--;
       
  7135     s.strstart++;
       
  7136     if (bflush) {
       
  7137       /*** FLUSH_BLOCK(s, 0); ***/
       
  7138       flush_block_only(s, false);
       
  7139       if (s.strm.avail_out === 0) {
       
  7140         return BS_NEED_MORE;
       
  7141       }
       
  7142       /***/
       
  7143     }
       
  7144   }
       
  7145   s.insert = 0;
       
  7146   if (flush === Z_FINISH) {
       
  7147     /*** FLUSH_BLOCK(s, 1); ***/
       
  7148     flush_block_only(s, true);
       
  7149     if (s.strm.avail_out === 0) {
       
  7150       return BS_FINISH_STARTED;
       
  7151     }
       
  7152     /***/
       
  7153     return BS_FINISH_DONE;
       
  7154   }
       
  7155   if (s.last_lit) {
       
  7156     /*** FLUSH_BLOCK(s, 0); ***/
       
  7157     flush_block_only(s, false);
       
  7158     if (s.strm.avail_out === 0) {
       
  7159       return BS_NEED_MORE;
       
  7160     }
       
  7161     /***/
       
  7162   }
       
  7163   return BS_BLOCK_DONE;
       
  7164 }
       
  7165 
       
  7166 /* Values for max_lazy_match, good_match and max_chain_length, depending on
       
  7167  * the desired pack level (0..9). The values given below have been tuned to
       
  7168  * exclude worst case performance for pathological files. Better values may be
       
  7169  * found for specific files.
       
  7170  */
       
  7171 function Config(good_length, max_lazy, nice_length, max_chain, func) {
       
  7172   this.good_length = good_length;
       
  7173   this.max_lazy = max_lazy;
       
  7174   this.nice_length = nice_length;
       
  7175   this.max_chain = max_chain;
       
  7176   this.func = func;
       
  7177 }
       
  7178 
       
  7179 var configuration_table;
       
  7180 
       
  7181 configuration_table = [
       
  7182   /*      good lazy nice chain */
       
  7183   new Config(0, 0, 0, 0, deflate_stored),          /* 0 store only */
       
  7184   new Config(4, 4, 8, 4, deflate_fast),            /* 1 max speed, no lazy matches */
       
  7185   new Config(4, 5, 16, 8, deflate_fast),           /* 2 */
       
  7186   new Config(4, 6, 32, 32, deflate_fast),          /* 3 */
       
  7187 
       
  7188   new Config(4, 4, 16, 16, deflate_slow),          /* 4 lazy matches */
       
  7189   new Config(8, 16, 32, 32, deflate_slow),         /* 5 */
       
  7190   new Config(8, 16, 128, 128, deflate_slow),       /* 6 */
       
  7191   new Config(8, 32, 128, 256, deflate_slow),       /* 7 */
       
  7192   new Config(32, 128, 258, 1024, deflate_slow),    /* 8 */
       
  7193   new Config(32, 258, 258, 4096, deflate_slow)     /* 9 max compression */
       
  7194 ];
       
  7195 
       
  7196 
       
  7197 /* ===========================================================================
       
  7198  * Initialize the "longest match" routines for a new zlib stream
       
  7199  */
       
  7200 function lm_init(s) {
       
  7201   s.window_size = 2 * s.w_size;
       
  7202 
       
  7203   /*** CLEAR_HASH(s); ***/
       
  7204   zero(s.head); // Fill with NIL (= 0);
       
  7205 
       
  7206   /* Set the default configuration parameters:
       
  7207    */
       
  7208   s.max_lazy_match = configuration_table[s.level].max_lazy;
       
  7209   s.good_match = configuration_table[s.level].good_length;
       
  7210   s.nice_match = configuration_table[s.level].nice_length;
       
  7211   s.max_chain_length = configuration_table[s.level].max_chain;
       
  7212 
       
  7213   s.strstart = 0;
       
  7214   s.block_start = 0;
       
  7215   s.lookahead = 0;
       
  7216   s.insert = 0;
       
  7217   s.match_length = s.prev_length = MIN_MATCH - 1;
       
  7218   s.match_available = 0;
       
  7219   s.ins_h = 0;
       
  7220 }
       
  7221 
       
  7222 
       
  7223 function DeflateState() {
       
  7224   this.strm = null;            /* pointer back to this zlib stream */
       
  7225   this.status = 0;            /* as the name implies */
       
  7226   this.pending_buf = null;      /* output still pending */
       
  7227   this.pending_buf_size = 0;  /* size of pending_buf */
       
  7228   this.pending_out = 0;       /* next pending byte to output to the stream */
       
  7229   this.pending = 0;           /* nb of bytes in the pending buffer */
       
  7230   this.wrap = 0;              /* bit 0 true for zlib, bit 1 true for gzip */
       
  7231   this.gzhead = null;         /* gzip header information to write */
       
  7232   this.gzindex = 0;           /* where in extra, name, or comment */
       
  7233   this.method = Z_DEFLATED; /* can only be DEFLATED */
       
  7234   this.last_flush = -1;   /* value of flush param for previous deflate call */
       
  7235 
       
  7236   this.w_size = 0;  /* LZ77 window size (32K by default) */
       
  7237   this.w_bits = 0;  /* log2(w_size)  (8..16) */
       
  7238   this.w_mask = 0;  /* w_size - 1 */
       
  7239 
       
  7240   this.window = null;
       
  7241   /* Sliding window. Input bytes are read into the second half of the window,
       
  7242    * and move to the first half later to keep a dictionary of at least wSize
       
  7243    * bytes. With this organization, matches are limited to a distance of
       
  7244    * wSize-MAX_MATCH bytes, but this ensures that IO is always
       
  7245    * performed with a length multiple of the block size.
       
  7246    */
       
  7247 
       
  7248   this.window_size = 0;
       
  7249   /* Actual size of window: 2*wSize, except when the user input buffer
       
  7250    * is directly used as sliding window.
       
  7251    */
       
  7252 
       
  7253   this.prev = null;
       
  7254   /* Link to older string with same hash index. To limit the size of this
       
  7255    * array to 64K, this link is maintained only for the last 32K strings.
       
  7256    * An index in this array is thus a window index modulo 32K.
       
  7257    */
       
  7258 
       
  7259   this.head = null;   /* Heads of the hash chains or NIL. */
       
  7260 
       
  7261   this.ins_h = 0;       /* hash index of string to be inserted */
       
  7262   this.hash_size = 0;   /* number of elements in hash table */
       
  7263   this.hash_bits = 0;   /* log2(hash_size) */
       
  7264   this.hash_mask = 0;   /* hash_size-1 */
       
  7265 
       
  7266   this.hash_shift = 0;
       
  7267   /* Number of bits by which ins_h must be shifted at each input
       
  7268    * step. It must be such that after MIN_MATCH steps, the oldest
       
  7269    * byte no longer takes part in the hash key, that is:
       
  7270    *   hash_shift * MIN_MATCH >= hash_bits
       
  7271    */
       
  7272 
       
  7273   this.block_start = 0;
       
  7274   /* Window position at the beginning of the current output block. Gets
       
  7275    * negative when the window is moved backwards.
       
  7276    */
       
  7277 
       
  7278   this.match_length = 0;      /* length of best match */
       
  7279   this.prev_match = 0;        /* previous match */
       
  7280   this.match_available = 0;   /* set if previous match exists */
       
  7281   this.strstart = 0;          /* start of string to insert */
       
  7282   this.match_start = 0;       /* start of matching string */
       
  7283   this.lookahead = 0;         /* number of valid bytes ahead in window */
       
  7284 
       
  7285   this.prev_length = 0;
       
  7286   /* Length of the best match at previous step. Matches not greater than this
       
  7287    * are discarded. This is used in the lazy match evaluation.
       
  7288    */
       
  7289 
       
  7290   this.max_chain_length = 0;
       
  7291   /* To speed up deflation, hash chains are never searched beyond this
       
  7292    * length.  A higher limit improves compression ratio but degrades the
       
  7293    * speed.
       
  7294    */
       
  7295 
       
  7296   this.max_lazy_match = 0;
       
  7297   /* Attempt to find a better match only when the current match is strictly
       
  7298    * smaller than this value. This mechanism is used only for compression
       
  7299    * levels >= 4.
       
  7300    */
       
  7301   // That's alias to max_lazy_match, don't use directly
       
  7302   //this.max_insert_length = 0;
       
  7303   /* Insert new strings in the hash table only if the match length is not
       
  7304    * greater than this length. This saves time but degrades compression.
       
  7305    * max_insert_length is used only for compression levels <= 3.
       
  7306    */
       
  7307 
       
  7308   this.level = 0;     /* compression level (1..9) */
       
  7309   this.strategy = 0;  /* favor or force Huffman coding*/
       
  7310 
       
  7311   this.good_match = 0;
       
  7312   /* Use a faster search when the previous match is longer than this */
       
  7313 
       
  7314   this.nice_match = 0; /* Stop searching when current match exceeds this */
       
  7315 
       
  7316               /* used by trees.c: */
       
  7317 
       
  7318   /* Didn't use ct_data typedef below to suppress compiler warning */
       
  7319 
       
  7320   // struct ct_data_s dyn_ltree[HEAP_SIZE];   /* literal and length tree */
       
  7321   // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */
       
  7322   // struct ct_data_s bl_tree[2*BL_CODES+1];  /* Huffman tree for bit lengths */
       
  7323 
       
  7324   // Use flat array of DOUBLE size, with interleaved fata,
       
  7325   // because JS does not support effective
       
  7326   this.dyn_ltree  = new utils.Buf16(HEAP_SIZE * 2);
       
  7327   this.dyn_dtree  = new utils.Buf16((2 * D_CODES + 1) * 2);
       
  7328   this.bl_tree    = new utils.Buf16((2 * BL_CODES + 1) * 2);
       
  7329   zero(this.dyn_ltree);
       
  7330   zero(this.dyn_dtree);
       
  7331   zero(this.bl_tree);
       
  7332 
       
  7333   this.l_desc   = null;         /* desc. for literal tree */
       
  7334   this.d_desc   = null;         /* desc. for distance tree */
       
  7335   this.bl_desc  = null;         /* desc. for bit length tree */
       
  7336 
       
  7337   //ush bl_count[MAX_BITS+1];
       
  7338   this.bl_count = new utils.Buf16(MAX_BITS + 1);
       
  7339   /* number of codes at each bit length for an optimal tree */
       
  7340 
       
  7341   //int heap[2*L_CODES+1];      /* heap used to build the Huffman trees */
       
  7342   this.heap = new utils.Buf16(2 * L_CODES + 1);  /* heap used to build the Huffman trees */
       
  7343   zero(this.heap);
       
  7344 
       
  7345   this.heap_len = 0;               /* number of elements in the heap */
       
  7346   this.heap_max = 0;               /* element of largest frequency */
       
  7347   /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.
       
  7348    * The same heap array is used to build all trees.
       
  7349    */
       
  7350 
       
  7351   this.depth = new utils.Buf16(2 * L_CODES + 1); //uch depth[2*L_CODES+1];
       
  7352   zero(this.depth);
       
  7353   /* Depth of each subtree used as tie breaker for trees of equal frequency
       
  7354    */
       
  7355 
       
  7356   this.l_buf = 0;          /* buffer index for literals or lengths */
       
  7357 
       
  7358   this.lit_bufsize = 0;
       
  7359   /* Size of match buffer for literals/lengths.  There are 4 reasons for
       
  7360    * limiting lit_bufsize to 64K:
       
  7361    *   - frequencies can be kept in 16 bit counters
       
  7362    *   - if compression is not successful for the first block, all input
       
  7363    *     data is still in the window so we can still emit a stored block even
       
  7364    *     when input comes from standard input.  (This can also be done for
       
  7365    *     all blocks if lit_bufsize is not greater than 32K.)
       
  7366    *   - if compression is not successful for a file smaller than 64K, we can
       
  7367    *     even emit a stored file instead of a stored block (saving 5 bytes).
       
  7368    *     This is applicable only for zip (not gzip or zlib).
       
  7369    *   - creating new Huffman trees less frequently may not provide fast
       
  7370    *     adaptation to changes in the input data statistics. (Take for
       
  7371    *     example a binary file with poorly compressible code followed by
       
  7372    *     a highly compressible string table.) Smaller buffer sizes give
       
  7373    *     fast adaptation but have of course the overhead of transmitting
       
  7374    *     trees more frequently.
       
  7375    *   - I can't count above 4
       
  7376    */
       
  7377 
       
  7378   this.last_lit = 0;      /* running index in l_buf */
       
  7379 
       
  7380   this.d_buf = 0;
       
  7381   /* Buffer index for distances. To simplify the code, d_buf and l_buf have
       
  7382    * the same number of elements. To use different lengths, an extra flag
       
  7383    * array would be necessary.
       
  7384    */
       
  7385 
       
  7386   this.opt_len = 0;       /* bit length of current block with optimal trees */
       
  7387   this.static_len = 0;    /* bit length of current block with static trees */
       
  7388   this.matches = 0;       /* number of string matches in current block */
       
  7389   this.insert = 0;        /* bytes at end of window left to insert */
       
  7390 
       
  7391 
       
  7392   this.bi_buf = 0;
       
  7393   /* Output buffer. bits are inserted starting at the bottom (least
       
  7394    * significant bits).
       
  7395    */
       
  7396   this.bi_valid = 0;
       
  7397   /* Number of valid bits in bi_buf.  All bits above the last valid bit
       
  7398    * are always zero.
       
  7399    */
       
  7400 
       
  7401   // Used for window memory init. We safely ignore it for JS. That makes
       
  7402   // sense only for pointers and memory check tools.
       
  7403   //this.high_water = 0;
       
  7404   /* High water mark offset in window for initialized bytes -- bytes above
       
  7405    * this are set to zero in order to avoid memory check warnings when
       
  7406    * longest match routines access bytes past the input.  This is then
       
  7407    * updated to the new high water mark.
       
  7408    */
       
  7409 }
       
  7410 
       
  7411 
       
  7412 function deflateResetKeep(strm) {
       
  7413   var s;
       
  7414 
       
  7415   if (!strm || !strm.state) {
       
  7416     return err(strm, Z_STREAM_ERROR);
       
  7417   }
       
  7418 
       
  7419   strm.total_in = strm.total_out = 0;
       
  7420   strm.data_type = Z_UNKNOWN;
       
  7421 
       
  7422   s = strm.state;
       
  7423   s.pending = 0;
       
  7424   s.pending_out = 0;
       
  7425 
       
  7426   if (s.wrap < 0) {
       
  7427     s.wrap = -s.wrap;
       
  7428     /* was made negative by deflate(..., Z_FINISH); */
       
  7429   }
       
  7430   s.status = (s.wrap ? INIT_STATE : BUSY_STATE);
       
  7431   strm.adler = (s.wrap === 2) ?
       
  7432     0  // crc32(0, Z_NULL, 0)
       
  7433   :
       
  7434     1; // adler32(0, Z_NULL, 0)
       
  7435   s.last_flush = Z_NO_FLUSH;
       
  7436   trees._tr_init(s);
       
  7437   return Z_OK;
       
  7438 }
       
  7439 
       
  7440 
       
  7441 function deflateReset(strm) {
       
  7442   var ret = deflateResetKeep(strm);
       
  7443   if (ret === Z_OK) {
       
  7444     lm_init(strm.state);
       
  7445   }
       
  7446   return ret;
       
  7447 }
       
  7448 
       
  7449 
       
  7450 function deflateSetHeader(strm, head) {
       
  7451   if (!strm || !strm.state) { return Z_STREAM_ERROR; }
       
  7452   if (strm.state.wrap !== 2) { return Z_STREAM_ERROR; }
       
  7453   strm.state.gzhead = head;
       
  7454   return Z_OK;
       
  7455 }
       
  7456 
       
  7457 
       
  7458 function deflateInit2(strm, level, method, windowBits, memLevel, strategy) {
       
  7459   if (!strm) { // === Z_NULL
       
  7460     return Z_STREAM_ERROR;
       
  7461   }
       
  7462   var wrap = 1;
       
  7463 
       
  7464   if (level === Z_DEFAULT_COMPRESSION) {
       
  7465     level = 6;
       
  7466   }
       
  7467 
       
  7468   if (windowBits < 0) { /* suppress zlib wrapper */
       
  7469     wrap = 0;
       
  7470     windowBits = -windowBits;
       
  7471   }
       
  7472 
       
  7473   else if (windowBits > 15) {
       
  7474     wrap = 2;           /* write gzip wrapper instead */
       
  7475     windowBits -= 16;
       
  7476   }
       
  7477 
       
  7478 
       
  7479   if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED ||
       
  7480     windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||
       
  7481     strategy < 0 || strategy > Z_FIXED) {
       
  7482     return err(strm, Z_STREAM_ERROR);
       
  7483   }
       
  7484 
       
  7485 
       
  7486   if (windowBits === 8) {
       
  7487     windowBits = 9;
       
  7488   }
       
  7489   /* until 256-byte window bug fixed */
       
  7490 
       
  7491   var s = new DeflateState();
       
  7492 
       
  7493   strm.state = s;
       
  7494   s.strm = strm;
       
  7495 
       
  7496   s.wrap = wrap;
       
  7497   s.gzhead = null;
       
  7498   s.w_bits = windowBits;
       
  7499   s.w_size = 1 << s.w_bits;
       
  7500   s.w_mask = s.w_size - 1;
       
  7501 
       
  7502   s.hash_bits = memLevel + 7;
       
  7503   s.hash_size = 1 << s.hash_bits;
       
  7504   s.hash_mask = s.hash_size - 1;
       
  7505   s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);
       
  7506 
       
  7507   s.window = new utils.Buf8(s.w_size * 2);
       
  7508   s.head = new utils.Buf16(s.hash_size);
       
  7509   s.prev = new utils.Buf16(s.w_size);
       
  7510 
       
  7511   // Don't need mem init magic for JS.
       
  7512   //s.high_water = 0;  /* nothing written to s->window yet */
       
  7513 
       
  7514   s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */
       
  7515 
       
  7516   s.pending_buf_size = s.lit_bufsize * 4;
       
  7517 
       
  7518   //overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);
       
  7519   //s->pending_buf = (uchf *) overlay;
       
  7520   s.pending_buf = new utils.Buf8(s.pending_buf_size);
       
  7521 
       
  7522   // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)
       
  7523   //s->d_buf = overlay + s->lit_bufsize/sizeof(ush);
       
  7524   s.d_buf = 1 * s.lit_bufsize;
       
  7525 
       
  7526   //s->l_buf = s->pending_buf + (1+sizeof(ush))*s->lit_bufsize;
       
  7527   s.l_buf = (1 + 2) * s.lit_bufsize;
       
  7528 
       
  7529   s.level = level;
       
  7530   s.strategy = strategy;
       
  7531   s.method = method;
       
  7532 
       
  7533   return deflateReset(strm);
       
  7534 }
       
  7535 
       
  7536 function deflateInit(strm, level) {
       
  7537   return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY);
       
  7538 }
       
  7539 
       
  7540 
       
  7541 function deflate(strm, flush) {
       
  7542   var old_flush, s;
       
  7543   var beg, val; // for gzip header write only
       
  7544 
       
  7545   if (!strm || !strm.state ||
       
  7546     flush > Z_BLOCK || flush < 0) {
       
  7547     return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR;
       
  7548   }
       
  7549 
       
  7550   s = strm.state;
       
  7551 
       
  7552   if (!strm.output ||
       
  7553       (!strm.input && strm.avail_in !== 0) ||
       
  7554       (s.status === FINISH_STATE && flush !== Z_FINISH)) {
       
  7555     return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR : Z_STREAM_ERROR);
       
  7556   }
       
  7557 
       
  7558   s.strm = strm; /* just in case */
       
  7559   old_flush = s.last_flush;
       
  7560   s.last_flush = flush;
       
  7561 
       
  7562   /* Write the header */
       
  7563   if (s.status === INIT_STATE) {
       
  7564 
       
  7565     if (s.wrap === 2) { // GZIP header
       
  7566       strm.adler = 0;  //crc32(0L, Z_NULL, 0);
       
  7567       put_byte(s, 31);
       
  7568       put_byte(s, 139);
       
  7569       put_byte(s, 8);
       
  7570       if (!s.gzhead) { // s->gzhead == Z_NULL
       
  7571         put_byte(s, 0);
       
  7572         put_byte(s, 0);
       
  7573         put_byte(s, 0);
       
  7574         put_byte(s, 0);
       
  7575         put_byte(s, 0);
       
  7576         put_byte(s, s.level === 9 ? 2 :
       
  7577                     (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?
       
  7578                      4 : 0));
       
  7579         put_byte(s, OS_CODE);
       
  7580         s.status = BUSY_STATE;
       
  7581       }
       
  7582       else {
       
  7583         put_byte(s, (s.gzhead.text ? 1 : 0) +
       
  7584                     (s.gzhead.hcrc ? 2 : 0) +
       
  7585                     (!s.gzhead.extra ? 0 : 4) +
       
  7586                     (!s.gzhead.name ? 0 : 8) +
       
  7587                     (!s.gzhead.comment ? 0 : 16)
       
  7588                 );
       
  7589         put_byte(s, s.gzhead.time & 0xff);
       
  7590         put_byte(s, (s.gzhead.time >> 8) & 0xff);
       
  7591         put_byte(s, (s.gzhead.time >> 16) & 0xff);
       
  7592         put_byte(s, (s.gzhead.time >> 24) & 0xff);
       
  7593         put_byte(s, s.level === 9 ? 2 :
       
  7594                     (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?
       
  7595                      4 : 0));
       
  7596         put_byte(s, s.gzhead.os & 0xff);
       
  7597         if (s.gzhead.extra && s.gzhead.extra.length) {
       
  7598           put_byte(s, s.gzhead.extra.length & 0xff);
       
  7599           put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);
       
  7600         }
       
  7601         if (s.gzhead.hcrc) {
       
  7602           strm.adler = crc32(strm.adler, s.pending_buf, s.pending, 0);
       
  7603         }
       
  7604         s.gzindex = 0;
       
  7605         s.status = EXTRA_STATE;
       
  7606       }
       
  7607     }
       
  7608     else // DEFLATE header
       
  7609     {
       
  7610       var header = (Z_DEFLATED + ((s.w_bits - 8) << 4)) << 8;
       
  7611       var level_flags = -1;
       
  7612 
       
  7613       if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {
       
  7614         level_flags = 0;
       
  7615       } else if (s.level < 6) {
       
  7616         level_flags = 1;
       
  7617       } else if (s.level === 6) {
       
  7618         level_flags = 2;
       
  7619       } else {
       
  7620         level_flags = 3;
       
  7621       }
       
  7622       header |= (level_flags << 6);
       
  7623       if (s.strstart !== 0) { header |= PRESET_DICT; }
       
  7624       header += 31 - (header % 31);
       
  7625 
       
  7626       s.status = BUSY_STATE;
       
  7627       putShortMSB(s, header);
       
  7628 
       
  7629       /* Save the adler32 of the preset dictionary: */
       
  7630       if (s.strstart !== 0) {
       
  7631         putShortMSB(s, strm.adler >>> 16);
       
  7632         putShortMSB(s, strm.adler & 0xffff);
       
  7633       }
       
  7634       strm.adler = 1; // adler32(0L, Z_NULL, 0);
       
  7635     }
       
  7636   }
       
  7637 
       
  7638 //#ifdef GZIP
       
  7639   if (s.status === EXTRA_STATE) {
       
  7640     if (s.gzhead.extra/* != Z_NULL*/) {
       
  7641       beg = s.pending;  /* start of bytes to update crc */
       
  7642 
       
  7643       while (s.gzindex < (s.gzhead.extra.length & 0xffff)) {
       
  7644         if (s.pending === s.pending_buf_size) {
       
  7645           if (s.gzhead.hcrc && s.pending > beg) {
       
  7646             strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7647           }
       
  7648           flush_pending(strm);
       
  7649           beg = s.pending;
       
  7650           if (s.pending === s.pending_buf_size) {
       
  7651             break;
       
  7652           }
       
  7653         }
       
  7654         put_byte(s, s.gzhead.extra[s.gzindex] & 0xff);
       
  7655         s.gzindex++;
       
  7656       }
       
  7657       if (s.gzhead.hcrc && s.pending > beg) {
       
  7658         strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7659       }
       
  7660       if (s.gzindex === s.gzhead.extra.length) {
       
  7661         s.gzindex = 0;
       
  7662         s.status = NAME_STATE;
       
  7663       }
       
  7664     }
       
  7665     else {
       
  7666       s.status = NAME_STATE;
       
  7667     }
       
  7668   }
       
  7669   if (s.status === NAME_STATE) {
       
  7670     if (s.gzhead.name/* != Z_NULL*/) {
       
  7671       beg = s.pending;  /* start of bytes to update crc */
       
  7672       //int val;
       
  7673 
       
  7674       do {
       
  7675         if (s.pending === s.pending_buf_size) {
       
  7676           if (s.gzhead.hcrc && s.pending > beg) {
       
  7677             strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7678           }
       
  7679           flush_pending(strm);
       
  7680           beg = s.pending;
       
  7681           if (s.pending === s.pending_buf_size) {
       
  7682             val = 1;
       
  7683             break;
       
  7684           }
       
  7685         }
       
  7686         // JS specific: little magic to add zero terminator to end of string
       
  7687         if (s.gzindex < s.gzhead.name.length) {
       
  7688           val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;
       
  7689         } else {
       
  7690           val = 0;
       
  7691         }
       
  7692         put_byte(s, val);
       
  7693       } while (val !== 0);
       
  7694 
       
  7695       if (s.gzhead.hcrc && s.pending > beg) {
       
  7696         strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7697       }
       
  7698       if (val === 0) {
       
  7699         s.gzindex = 0;
       
  7700         s.status = COMMENT_STATE;
       
  7701       }
       
  7702     }
       
  7703     else {
       
  7704       s.status = COMMENT_STATE;
       
  7705     }
       
  7706   }
       
  7707   if (s.status === COMMENT_STATE) {
       
  7708     if (s.gzhead.comment/* != Z_NULL*/) {
       
  7709       beg = s.pending;  /* start of bytes to update crc */
       
  7710       //int val;
       
  7711 
       
  7712       do {
       
  7713         if (s.pending === s.pending_buf_size) {
       
  7714           if (s.gzhead.hcrc && s.pending > beg) {
       
  7715             strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7716           }
       
  7717           flush_pending(strm);
       
  7718           beg = s.pending;
       
  7719           if (s.pending === s.pending_buf_size) {
       
  7720             val = 1;
       
  7721             break;
       
  7722           }
       
  7723         }
       
  7724         // JS specific: little magic to add zero terminator to end of string
       
  7725         if (s.gzindex < s.gzhead.comment.length) {
       
  7726           val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;
       
  7727         } else {
       
  7728           val = 0;
       
  7729         }
       
  7730         put_byte(s, val);
       
  7731       } while (val !== 0);
       
  7732 
       
  7733       if (s.gzhead.hcrc && s.pending > beg) {
       
  7734         strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);
       
  7735       }
       
  7736       if (val === 0) {
       
  7737         s.status = HCRC_STATE;
       
  7738       }
       
  7739     }
       
  7740     else {
       
  7741       s.status = HCRC_STATE;
       
  7742     }
       
  7743   }
       
  7744   if (s.status === HCRC_STATE) {
       
  7745     if (s.gzhead.hcrc) {
       
  7746       if (s.pending + 2 > s.pending_buf_size) {
       
  7747         flush_pending(strm);
       
  7748       }
       
  7749       if (s.pending + 2 <= s.pending_buf_size) {
       
  7750         put_byte(s, strm.adler & 0xff);
       
  7751         put_byte(s, (strm.adler >> 8) & 0xff);
       
  7752         strm.adler = 0; //crc32(0L, Z_NULL, 0);
       
  7753         s.status = BUSY_STATE;
       
  7754       }
       
  7755     }
       
  7756     else {
       
  7757       s.status = BUSY_STATE;
       
  7758     }
       
  7759   }
       
  7760 //#endif
       
  7761 
       
  7762   /* Flush as much pending output as possible */
       
  7763   if (s.pending !== 0) {
       
  7764     flush_pending(strm);
       
  7765     if (strm.avail_out === 0) {
       
  7766       /* Since avail_out is 0, deflate will be called again with
       
  7767        * more output space, but possibly with both pending and
       
  7768        * avail_in equal to zero. There won't be anything to do,
       
  7769        * but this is not an error situation so make sure we
       
  7770        * return OK instead of BUF_ERROR at next call of deflate:
       
  7771        */
       
  7772       s.last_flush = -1;
       
  7773       return Z_OK;
       
  7774     }
       
  7775 
       
  7776     /* Make sure there is something to do and avoid duplicate consecutive
       
  7777      * flushes. For repeated and useless calls with Z_FINISH, we keep
       
  7778      * returning Z_STREAM_END instead of Z_BUF_ERROR.
       
  7779      */
       
  7780   } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&
       
  7781     flush !== Z_FINISH) {
       
  7782     return err(strm, Z_BUF_ERROR);
       
  7783   }
       
  7784 
       
  7785   /* User must not provide more input after the first FINISH: */
       
  7786   if (s.status === FINISH_STATE && strm.avail_in !== 0) {
       
  7787     return err(strm, Z_BUF_ERROR);
       
  7788   }
       
  7789 
       
  7790   /* Start a new block or continue the current one.
       
  7791    */
       
  7792   if (strm.avail_in !== 0 || s.lookahead !== 0 ||
       
  7793     (flush !== Z_NO_FLUSH && s.status !== FINISH_STATE)) {
       
  7794     var bstate = (s.strategy === Z_HUFFMAN_ONLY) ? deflate_huff(s, flush) :
       
  7795       (s.strategy === Z_RLE ? deflate_rle(s, flush) :
       
  7796         configuration_table[s.level].func(s, flush));
       
  7797 
       
  7798     if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {
       
  7799       s.status = FINISH_STATE;
       
  7800     }
       
  7801     if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {
       
  7802       if (strm.avail_out === 0) {
       
  7803         s.last_flush = -1;
       
  7804         /* avoid BUF_ERROR next call, see above */
       
  7805       }
       
  7806       return Z_OK;
       
  7807       /* If flush != Z_NO_FLUSH && avail_out == 0, the next call
       
  7808        * of deflate should use the same flush parameter to make sure
       
  7809        * that the flush is complete. So we don't have to output an
       
  7810        * empty block here, this will be done at next call. This also
       
  7811        * ensures that for a very small output buffer, we emit at most
       
  7812        * one empty block.
       
  7813        */
       
  7814     }
       
  7815     if (bstate === BS_BLOCK_DONE) {
       
  7816       if (flush === Z_PARTIAL_FLUSH) {
       
  7817         trees._tr_align(s);
       
  7818       }
       
  7819       else if (flush !== Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */
       
  7820 
       
  7821         trees._tr_stored_block(s, 0, 0, false);
       
  7822         /* For a full flush, this empty block will be recognized
       
  7823          * as a special marker by inflate_sync().
       
  7824          */
       
  7825         if (flush === Z_FULL_FLUSH) {
       
  7826           /*** CLEAR_HASH(s); ***/             /* forget history */
       
  7827           zero(s.head); // Fill with NIL (= 0);
       
  7828 
       
  7829           if (s.lookahead === 0) {
       
  7830             s.strstart = 0;
       
  7831             s.block_start = 0;
       
  7832             s.insert = 0;
       
  7833           }
       
  7834         }
       
  7835       }
       
  7836       flush_pending(strm);
       
  7837       if (strm.avail_out === 0) {
       
  7838         s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */
       
  7839         return Z_OK;
       
  7840       }
       
  7841     }
       
  7842   }
       
  7843   //Assert(strm->avail_out > 0, "bug2");
       
  7844   //if (strm.avail_out <= 0) { throw new Error("bug2");}
       
  7845 
       
  7846   if (flush !== Z_FINISH) { return Z_OK; }
       
  7847   if (s.wrap <= 0) { return Z_STREAM_END; }
       
  7848 
       
  7849   /* Write the trailer */
       
  7850   if (s.wrap === 2) {
       
  7851     put_byte(s, strm.adler & 0xff);
       
  7852     put_byte(s, (strm.adler >> 8) & 0xff);
       
  7853     put_byte(s, (strm.adler >> 16) & 0xff);
       
  7854     put_byte(s, (strm.adler >> 24) & 0xff);
       
  7855     put_byte(s, strm.total_in & 0xff);
       
  7856     put_byte(s, (strm.total_in >> 8) & 0xff);
       
  7857     put_byte(s, (strm.total_in >> 16) & 0xff);
       
  7858     put_byte(s, (strm.total_in >> 24) & 0xff);
       
  7859   }
       
  7860   else
       
  7861   {
       
  7862     putShortMSB(s, strm.adler >>> 16);
       
  7863     putShortMSB(s, strm.adler & 0xffff);
       
  7864   }
       
  7865 
       
  7866   flush_pending(strm);
       
  7867   /* If avail_out is zero, the application will call deflate again
       
  7868    * to flush the rest.
       
  7869    */
       
  7870   if (s.wrap > 0) { s.wrap = -s.wrap; }
       
  7871   /* write the trailer only once! */
       
  7872   return s.pending !== 0 ? Z_OK : Z_STREAM_END;
       
  7873 }
       
  7874 
       
  7875 function deflateEnd(strm) {
       
  7876   var status;
       
  7877 
       
  7878   if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {
       
  7879     return Z_STREAM_ERROR;
       
  7880   }
       
  7881 
       
  7882   status = strm.state.status;
       
  7883   if (status !== INIT_STATE &&
       
  7884     status !== EXTRA_STATE &&
       
  7885     status !== NAME_STATE &&
       
  7886     status !== COMMENT_STATE &&
       
  7887     status !== HCRC_STATE &&
       
  7888     status !== BUSY_STATE &&
       
  7889     status !== FINISH_STATE
       
  7890   ) {
       
  7891     return err(strm, Z_STREAM_ERROR);
       
  7892   }
       
  7893 
       
  7894   strm.state = null;
       
  7895 
       
  7896   return status === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK;
       
  7897 }
       
  7898 
       
  7899 
       
  7900 /* =========================================================================
       
  7901  * Initializes the compression dictionary from the given byte
       
  7902  * sequence without producing any compressed output.
       
  7903  */
       
  7904 function deflateSetDictionary(strm, dictionary) {
       
  7905   var dictLength = dictionary.length;
       
  7906 
       
  7907   var s;
       
  7908   var str, n;
       
  7909   var wrap;
       
  7910   var avail;
       
  7911   var next;
       
  7912   var input;
       
  7913   var tmpDict;
       
  7914 
       
  7915   if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {
       
  7916     return Z_STREAM_ERROR;
       
  7917   }
       
  7918 
       
  7919   s = strm.state;
       
  7920   wrap = s.wrap;
       
  7921 
       
  7922   if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {
       
  7923     return Z_STREAM_ERROR;
       
  7924   }
       
  7925 
       
  7926   /* when using zlib wrappers, compute Adler-32 for provided dictionary */
       
  7927   if (wrap === 1) {
       
  7928     /* adler32(strm->adler, dictionary, dictLength); */
       
  7929     strm.adler = adler32(strm.adler, dictionary, dictLength, 0);
       
  7930   }
       
  7931 
       
  7932   s.wrap = 0;   /* avoid computing Adler-32 in read_buf */
       
  7933 
       
  7934   /* if dictionary would fill window, just replace the history */
       
  7935   if (dictLength >= s.w_size) {
       
  7936     if (wrap === 0) {            /* already empty otherwise */
       
  7937       /*** CLEAR_HASH(s); ***/
       
  7938       zero(s.head); // Fill with NIL (= 0);
       
  7939       s.strstart = 0;
       
  7940       s.block_start = 0;
       
  7941       s.insert = 0;
       
  7942     }
       
  7943     /* use the tail */
       
  7944     // dictionary = dictionary.slice(dictLength - s.w_size);
       
  7945     tmpDict = new utils.Buf8(s.w_size);
       
  7946     utils.arraySet(tmpDict, dictionary, dictLength - s.w_size, s.w_size, 0);
       
  7947     dictionary = tmpDict;
       
  7948     dictLength = s.w_size;
       
  7949   }
       
  7950   /* insert dictionary into window and hash */
       
  7951   avail = strm.avail_in;
       
  7952   next = strm.next_in;
       
  7953   input = strm.input;
       
  7954   strm.avail_in = dictLength;
       
  7955   strm.next_in = 0;
       
  7956   strm.input = dictionary;
       
  7957   fill_window(s);
       
  7958   while (s.lookahead >= MIN_MATCH) {
       
  7959     str = s.strstart;
       
  7960     n = s.lookahead - (MIN_MATCH - 1);
       
  7961     do {
       
  7962       /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */
       
  7963       s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;
       
  7964 
       
  7965       s.prev[str & s.w_mask] = s.head[s.ins_h];
       
  7966 
       
  7967       s.head[s.ins_h] = str;
       
  7968       str++;
       
  7969     } while (--n);
       
  7970     s.strstart = str;
       
  7971     s.lookahead = MIN_MATCH - 1;
       
  7972     fill_window(s);
       
  7973   }
       
  7974   s.strstart += s.lookahead;
       
  7975   s.block_start = s.strstart;
       
  7976   s.insert = s.lookahead;
       
  7977   s.lookahead = 0;
       
  7978   s.match_length = s.prev_length = MIN_MATCH - 1;
       
  7979   s.match_available = 0;
       
  7980   strm.next_in = next;
       
  7981   strm.input = input;
       
  7982   strm.avail_in = avail;
       
  7983   s.wrap = wrap;
       
  7984   return Z_OK;
       
  7985 }
       
  7986 
       
  7987 
       
  7988 exports.deflateInit = deflateInit;
       
  7989 exports.deflateInit2 = deflateInit2;
       
  7990 exports.deflateReset = deflateReset;
       
  7991 exports.deflateResetKeep = deflateResetKeep;
       
  7992 exports.deflateSetHeader = deflateSetHeader;
       
  7993 exports.deflate = deflate;
       
  7994 exports.deflateEnd = deflateEnd;
       
  7995 exports.deflateSetDictionary = deflateSetDictionary;
       
  7996 exports.deflateInfo = 'pako deflate (from Nodeca project)';
       
  7997 
       
  7998 /* Not implemented
       
  7999 exports.deflateBound = deflateBound;
       
  8000 exports.deflateCopy = deflateCopy;
       
  8001 exports.deflateParams = deflateParams;
       
  8002 exports.deflatePending = deflatePending;
       
  8003 exports.deflatePrime = deflatePrime;
       
  8004 exports.deflateTune = deflateTune;
       
  8005 */
       
  8006 
       
  8007 },{"../utils/common":62,"./adler32":64,"./crc32":66,"./messages":72,"./trees":73}],68:[function(require,module,exports){
       
  8008 'use strict';
       
  8009 
       
  8010 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  8011 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  8012 //
       
  8013 // This software is provided 'as-is', without any express or implied
       
  8014 // warranty. In no event will the authors be held liable for any damages
       
  8015 // arising from the use of this software.
       
  8016 //
       
  8017 // Permission is granted to anyone to use this software for any purpose,
       
  8018 // including commercial applications, and to alter it and redistribute it
       
  8019 // freely, subject to the following restrictions:
       
  8020 //
       
  8021 // 1. The origin of this software must not be misrepresented; you must not
       
  8022 //   claim that you wrote the original software. If you use this software
       
  8023 //   in a product, an acknowledgment in the product documentation would be
       
  8024 //   appreciated but is not required.
       
  8025 // 2. Altered source versions must be plainly marked as such, and must not be
       
  8026 //   misrepresented as being the original software.
       
  8027 // 3. This notice may not be removed or altered from any source distribution.
       
  8028 
       
  8029 function GZheader() {
       
  8030   /* true if compressed data believed to be text */
       
  8031   this.text       = 0;
       
  8032   /* modification time */
       
  8033   this.time       = 0;
       
  8034   /* extra flags (not used when writing a gzip file) */
       
  8035   this.xflags     = 0;
       
  8036   /* operating system */
       
  8037   this.os         = 0;
       
  8038   /* pointer to extra field or Z_NULL if none */
       
  8039   this.extra      = null;
       
  8040   /* extra field length (valid if extra != Z_NULL) */
       
  8041   this.extra_len  = 0; // Actually, we don't need it in JS,
       
  8042                        // but leave for few code modifications
       
  8043 
       
  8044   //
       
  8045   // Setup limits is not necessary because in js we should not preallocate memory
       
  8046   // for inflate use constant limit in 65536 bytes
       
  8047   //
       
  8048 
       
  8049   /* space at extra (only when reading header) */
       
  8050   // this.extra_max  = 0;
       
  8051   /* pointer to zero-terminated file name or Z_NULL */
       
  8052   this.name       = '';
       
  8053   /* space at name (only when reading header) */
       
  8054   // this.name_max   = 0;
       
  8055   /* pointer to zero-terminated comment or Z_NULL */
       
  8056   this.comment    = '';
       
  8057   /* space at comment (only when reading header) */
       
  8058   // this.comm_max   = 0;
       
  8059   /* true if there was or will be a header crc */
       
  8060   this.hcrc       = 0;
       
  8061   /* true when done reading gzip header (not used when writing a gzip file) */
       
  8062   this.done       = false;
       
  8063 }
       
  8064 
       
  8065 module.exports = GZheader;
       
  8066 
       
  8067 },{}],69:[function(require,module,exports){
       
  8068 'use strict';
       
  8069 
       
  8070 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  8071 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  8072 //
       
  8073 // This software is provided 'as-is', without any express or implied
       
  8074 // warranty. In no event will the authors be held liable for any damages
       
  8075 // arising from the use of this software.
       
  8076 //
       
  8077 // Permission is granted to anyone to use this software for any purpose,
       
  8078 // including commercial applications, and to alter it and redistribute it
       
  8079 // freely, subject to the following restrictions:
       
  8080 //
       
  8081 // 1. The origin of this software must not be misrepresented; you must not
       
  8082 //   claim that you wrote the original software. If you use this software
       
  8083 //   in a product, an acknowledgment in the product documentation would be
       
  8084 //   appreciated but is not required.
       
  8085 // 2. Altered source versions must be plainly marked as such, and must not be
       
  8086 //   misrepresented as being the original software.
       
  8087 // 3. This notice may not be removed or altered from any source distribution.
       
  8088 
       
  8089 // See state defs from inflate.js
       
  8090 var BAD = 30;       /* got a data error -- remain here until reset */
       
  8091 var TYPE = 12;      /* i: waiting for type bits, including last-flag bit */
       
  8092 
       
  8093 /*
       
  8094    Decode literal, length, and distance codes and write out the resulting
       
  8095    literal and match bytes until either not enough input or output is
       
  8096    available, an end-of-block is encountered, or a data error is encountered.
       
  8097    When large enough input and output buffers are supplied to inflate(), for
       
  8098    example, a 16K input buffer and a 64K output buffer, more than 95% of the
       
  8099    inflate execution time is spent in this routine.
       
  8100 
       
  8101    Entry assumptions:
       
  8102 
       
  8103         state.mode === LEN
       
  8104         strm.avail_in >= 6
       
  8105         strm.avail_out >= 258
       
  8106         start >= strm.avail_out
       
  8107         state.bits < 8
       
  8108 
       
  8109    On return, state.mode is one of:
       
  8110 
       
  8111         LEN -- ran out of enough output space or enough available input
       
  8112         TYPE -- reached end of block code, inflate() to interpret next block
       
  8113         BAD -- error in block data
       
  8114 
       
  8115    Notes:
       
  8116 
       
  8117     - The maximum input bits used by a length/distance pair is 15 bits for the
       
  8118       length code, 5 bits for the length extra, 15 bits for the distance code,
       
  8119       and 13 bits for the distance extra.  This totals 48 bits, or six bytes.
       
  8120       Therefore if strm.avail_in >= 6, then there is enough input to avoid
       
  8121       checking for available input while decoding.
       
  8122 
       
  8123     - The maximum bytes that a single length/distance pair can output is 258
       
  8124       bytes, which is the maximum length that can be coded.  inflate_fast()
       
  8125       requires strm.avail_out >= 258 for each loop to avoid checking for
       
  8126       output space.
       
  8127  */
       
  8128 module.exports = function inflate_fast(strm, start) {
       
  8129   var state;
       
  8130   var _in;                    /* local strm.input */
       
  8131   var last;                   /* have enough input while in < last */
       
  8132   var _out;                   /* local strm.output */
       
  8133   var beg;                    /* inflate()'s initial strm.output */
       
  8134   var end;                    /* while out < end, enough space available */
       
  8135 //#ifdef INFLATE_STRICT
       
  8136   var dmax;                   /* maximum distance from zlib header */
       
  8137 //#endif
       
  8138   var wsize;                  /* window size or zero if not using window */
       
  8139   var whave;                  /* valid bytes in the window */
       
  8140   var wnext;                  /* window write index */
       
  8141   // Use `s_window` instead `window`, avoid conflict with instrumentation tools
       
  8142   var s_window;               /* allocated sliding window, if wsize != 0 */
       
  8143   var hold;                   /* local strm.hold */
       
  8144   var bits;                   /* local strm.bits */
       
  8145   var lcode;                  /* local strm.lencode */
       
  8146   var dcode;                  /* local strm.distcode */
       
  8147   var lmask;                  /* mask for first level of length codes */
       
  8148   var dmask;                  /* mask for first level of distance codes */
       
  8149   var here;                   /* retrieved table entry */
       
  8150   var op;                     /* code bits, operation, extra bits, or */
       
  8151                               /*  window position, window bytes to copy */
       
  8152   var len;                    /* match length, unused bytes */
       
  8153   var dist;                   /* match distance */
       
  8154   var from;                   /* where to copy match from */
       
  8155   var from_source;
       
  8156 
       
  8157 
       
  8158   var input, output; // JS specific, because we have no pointers
       
  8159 
       
  8160   /* copy state to local variables */
       
  8161   state = strm.state;
       
  8162   //here = state.here;
       
  8163   _in = strm.next_in;
       
  8164   input = strm.input;
       
  8165   last = _in + (strm.avail_in - 5);
       
  8166   _out = strm.next_out;
       
  8167   output = strm.output;
       
  8168   beg = _out - (start - strm.avail_out);
       
  8169   end = _out + (strm.avail_out - 257);
       
  8170 //#ifdef INFLATE_STRICT
       
  8171   dmax = state.dmax;
       
  8172 //#endif
       
  8173   wsize = state.wsize;
       
  8174   whave = state.whave;
       
  8175   wnext = state.wnext;
       
  8176   s_window = state.window;
       
  8177   hold = state.hold;
       
  8178   bits = state.bits;
       
  8179   lcode = state.lencode;
       
  8180   dcode = state.distcode;
       
  8181   lmask = (1 << state.lenbits) - 1;
       
  8182   dmask = (1 << state.distbits) - 1;
       
  8183 
       
  8184 
       
  8185   /* decode literals and length/distances until end-of-block or not enough
       
  8186      input data or output space */
       
  8187 
       
  8188   top:
       
  8189   do {
       
  8190     if (bits < 15) {
       
  8191       hold += input[_in++] << bits;
       
  8192       bits += 8;
       
  8193       hold += input[_in++] << bits;
       
  8194       bits += 8;
       
  8195     }
       
  8196 
       
  8197     here = lcode[hold & lmask];
       
  8198 
       
  8199     dolen:
       
  8200     for (;;) { // Goto emulation
       
  8201       op = here >>> 24/*here.bits*/;
       
  8202       hold >>>= op;
       
  8203       bits -= op;
       
  8204       op = (here >>> 16) & 0xff/*here.op*/;
       
  8205       if (op === 0) {                          /* literal */
       
  8206         //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?
       
  8207         //        "inflate:         literal '%c'\n" :
       
  8208         //        "inflate:         literal 0x%02x\n", here.val));
       
  8209         output[_out++] = here & 0xffff/*here.val*/;
       
  8210       }
       
  8211       else if (op & 16) {                     /* length base */
       
  8212         len = here & 0xffff/*here.val*/;
       
  8213         op &= 15;                           /* number of extra bits */
       
  8214         if (op) {
       
  8215           if (bits < op) {
       
  8216             hold += input[_in++] << bits;
       
  8217             bits += 8;
       
  8218           }
       
  8219           len += hold & ((1 << op) - 1);
       
  8220           hold >>>= op;
       
  8221           bits -= op;
       
  8222         }
       
  8223         //Tracevv((stderr, "inflate:         length %u\n", len));
       
  8224         if (bits < 15) {
       
  8225           hold += input[_in++] << bits;
       
  8226           bits += 8;
       
  8227           hold += input[_in++] << bits;
       
  8228           bits += 8;
       
  8229         }
       
  8230         here = dcode[hold & dmask];
       
  8231 
       
  8232         dodist:
       
  8233         for (;;) { // goto emulation
       
  8234           op = here >>> 24/*here.bits*/;
       
  8235           hold >>>= op;
       
  8236           bits -= op;
       
  8237           op = (here >>> 16) & 0xff/*here.op*/;
       
  8238 
       
  8239           if (op & 16) {                      /* distance base */
       
  8240             dist = here & 0xffff/*here.val*/;
       
  8241             op &= 15;                       /* number of extra bits */
       
  8242             if (bits < op) {
       
  8243               hold += input[_in++] << bits;
       
  8244               bits += 8;
       
  8245               if (bits < op) {
       
  8246                 hold += input[_in++] << bits;
       
  8247                 bits += 8;
       
  8248               }
       
  8249             }
       
  8250             dist += hold & ((1 << op) - 1);
       
  8251 //#ifdef INFLATE_STRICT
       
  8252             if (dist > dmax) {
       
  8253               strm.msg = 'invalid distance too far back';
       
  8254               state.mode = BAD;
       
  8255               break top;
       
  8256             }
       
  8257 //#endif
       
  8258             hold >>>= op;
       
  8259             bits -= op;
       
  8260             //Tracevv((stderr, "inflate:         distance %u\n", dist));
       
  8261             op = _out - beg;                /* max distance in output */
       
  8262             if (dist > op) {                /* see if copy from window */
       
  8263               op = dist - op;               /* distance back in window */
       
  8264               if (op > whave) {
       
  8265                 if (state.sane) {
       
  8266                   strm.msg = 'invalid distance too far back';
       
  8267                   state.mode = BAD;
       
  8268                   break top;
       
  8269                 }
       
  8270 
       
  8271 // (!) This block is disabled in zlib defailts,
       
  8272 // don't enable it for binary compatibility
       
  8273 //#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR
       
  8274 //                if (len <= op - whave) {
       
  8275 //                  do {
       
  8276 //                    output[_out++] = 0;
       
  8277 //                  } while (--len);
       
  8278 //                  continue top;
       
  8279 //                }
       
  8280 //                len -= op - whave;
       
  8281 //                do {
       
  8282 //                  output[_out++] = 0;
       
  8283 //                } while (--op > whave);
       
  8284 //                if (op === 0) {
       
  8285 //                  from = _out - dist;
       
  8286 //                  do {
       
  8287 //                    output[_out++] = output[from++];
       
  8288 //                  } while (--len);
       
  8289 //                  continue top;
       
  8290 //                }
       
  8291 //#endif
       
  8292               }
       
  8293               from = 0; // window index
       
  8294               from_source = s_window;
       
  8295               if (wnext === 0) {           /* very common case */
       
  8296                 from += wsize - op;
       
  8297                 if (op < len) {         /* some from window */
       
  8298                   len -= op;
       
  8299                   do {
       
  8300                     output[_out++] = s_window[from++];
       
  8301                   } while (--op);
       
  8302                   from = _out - dist;  /* rest from output */
       
  8303                   from_source = output;
       
  8304                 }
       
  8305               }
       
  8306               else if (wnext < op) {      /* wrap around window */
       
  8307                 from += wsize + wnext - op;
       
  8308                 op -= wnext;
       
  8309                 if (op < len) {         /* some from end of window */
       
  8310                   len -= op;
       
  8311                   do {
       
  8312                     output[_out++] = s_window[from++];
       
  8313                   } while (--op);
       
  8314                   from = 0;
       
  8315                   if (wnext < len) {  /* some from start of window */
       
  8316                     op = wnext;
       
  8317                     len -= op;
       
  8318                     do {
       
  8319                       output[_out++] = s_window[from++];
       
  8320                     } while (--op);
       
  8321                     from = _out - dist;      /* rest from output */
       
  8322                     from_source = output;
       
  8323                   }
       
  8324                 }
       
  8325               }
       
  8326               else {                      /* contiguous in window */
       
  8327                 from += wnext - op;
       
  8328                 if (op < len) {         /* some from window */
       
  8329                   len -= op;
       
  8330                   do {
       
  8331                     output[_out++] = s_window[from++];
       
  8332                   } while (--op);
       
  8333                   from = _out - dist;  /* rest from output */
       
  8334                   from_source = output;
       
  8335                 }
       
  8336               }
       
  8337               while (len > 2) {
       
  8338                 output[_out++] = from_source[from++];
       
  8339                 output[_out++] = from_source[from++];
       
  8340                 output[_out++] = from_source[from++];
       
  8341                 len -= 3;
       
  8342               }
       
  8343               if (len) {
       
  8344                 output[_out++] = from_source[from++];
       
  8345                 if (len > 1) {
       
  8346                   output[_out++] = from_source[from++];
       
  8347                 }
       
  8348               }
       
  8349             }
       
  8350             else {
       
  8351               from = _out - dist;          /* copy direct from output */
       
  8352               do {                        /* minimum length is three */
       
  8353                 output[_out++] = output[from++];
       
  8354                 output[_out++] = output[from++];
       
  8355                 output[_out++] = output[from++];
       
  8356                 len -= 3;
       
  8357               } while (len > 2);
       
  8358               if (len) {
       
  8359                 output[_out++] = output[from++];
       
  8360                 if (len > 1) {
       
  8361                   output[_out++] = output[from++];
       
  8362                 }
       
  8363               }
       
  8364             }
       
  8365           }
       
  8366           else if ((op & 64) === 0) {          /* 2nd level distance code */
       
  8367             here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];
       
  8368             continue dodist;
       
  8369           }
       
  8370           else {
       
  8371             strm.msg = 'invalid distance code';
       
  8372             state.mode = BAD;
       
  8373             break top;
       
  8374           }
       
  8375 
       
  8376           break; // need to emulate goto via "continue"
       
  8377         }
       
  8378       }
       
  8379       else if ((op & 64) === 0) {              /* 2nd level length code */
       
  8380         here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];
       
  8381         continue dolen;
       
  8382       }
       
  8383       else if (op & 32) {                     /* end-of-block */
       
  8384         //Tracevv((stderr, "inflate:         end of block\n"));
       
  8385         state.mode = TYPE;
       
  8386         break top;
       
  8387       }
       
  8388       else {
       
  8389         strm.msg = 'invalid literal/length code';
       
  8390         state.mode = BAD;
       
  8391         break top;
       
  8392       }
       
  8393 
       
  8394       break; // need to emulate goto via "continue"
       
  8395     }
       
  8396   } while (_in < last && _out < end);
       
  8397 
       
  8398   /* return unused bytes (on entry, bits < 8, so in won't go too far back) */
       
  8399   len = bits >> 3;
       
  8400   _in -= len;
       
  8401   bits -= len << 3;
       
  8402   hold &= (1 << bits) - 1;
       
  8403 
       
  8404   /* update state and return */
       
  8405   strm.next_in = _in;
       
  8406   strm.next_out = _out;
       
  8407   strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));
       
  8408   strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));
       
  8409   state.hold = hold;
       
  8410   state.bits = bits;
       
  8411   return;
       
  8412 };
       
  8413 
       
  8414 },{}],70:[function(require,module,exports){
       
  8415 'use strict';
       
  8416 
       
  8417 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  8418 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  8419 //
       
  8420 // This software is provided 'as-is', without any express or implied
       
  8421 // warranty. In no event will the authors be held liable for any damages
       
  8422 // arising from the use of this software.
       
  8423 //
       
  8424 // Permission is granted to anyone to use this software for any purpose,
       
  8425 // including commercial applications, and to alter it and redistribute it
       
  8426 // freely, subject to the following restrictions:
       
  8427 //
       
  8428 // 1. The origin of this software must not be misrepresented; you must not
       
  8429 //   claim that you wrote the original software. If you use this software
       
  8430 //   in a product, an acknowledgment in the product documentation would be
       
  8431 //   appreciated but is not required.
       
  8432 // 2. Altered source versions must be plainly marked as such, and must not be
       
  8433 //   misrepresented as being the original software.
       
  8434 // 3. This notice may not be removed or altered from any source distribution.
       
  8435 
       
  8436 var utils         = require('../utils/common');
       
  8437 var adler32       = require('./adler32');
       
  8438 var crc32         = require('./crc32');
       
  8439 var inflate_fast  = require('./inffast');
       
  8440 var inflate_table = require('./inftrees');
       
  8441 
       
  8442 var CODES = 0;
       
  8443 var LENS = 1;
       
  8444 var DISTS = 2;
       
  8445 
       
  8446 /* Public constants ==========================================================*/
       
  8447 /* ===========================================================================*/
       
  8448 
       
  8449 
       
  8450 /* Allowed flush values; see deflate() and inflate() below for details */
       
  8451 //var Z_NO_FLUSH      = 0;
       
  8452 //var Z_PARTIAL_FLUSH = 1;
       
  8453 //var Z_SYNC_FLUSH    = 2;
       
  8454 //var Z_FULL_FLUSH    = 3;
       
  8455 var Z_FINISH        = 4;
       
  8456 var Z_BLOCK         = 5;
       
  8457 var Z_TREES         = 6;
       
  8458 
       
  8459 
       
  8460 /* Return codes for the compression/decompression functions. Negative values
       
  8461  * are errors, positive values are used for special but normal events.
       
  8462  */
       
  8463 var Z_OK            = 0;
       
  8464 var Z_STREAM_END    = 1;
       
  8465 var Z_NEED_DICT     = 2;
       
  8466 //var Z_ERRNO         = -1;
       
  8467 var Z_STREAM_ERROR  = -2;
       
  8468 var Z_DATA_ERROR    = -3;
       
  8469 var Z_MEM_ERROR     = -4;
       
  8470 var Z_BUF_ERROR     = -5;
       
  8471 //var Z_VERSION_ERROR = -6;
       
  8472 
       
  8473 /* The deflate compression method */
       
  8474 var Z_DEFLATED  = 8;
       
  8475 
       
  8476 
       
  8477 /* STATES ====================================================================*/
       
  8478 /* ===========================================================================*/
       
  8479 
       
  8480 
       
  8481 var    HEAD = 1;       /* i: waiting for magic header */
       
  8482 var    FLAGS = 2;      /* i: waiting for method and flags (gzip) */
       
  8483 var    TIME = 3;       /* i: waiting for modification time (gzip) */
       
  8484 var    OS = 4;         /* i: waiting for extra flags and operating system (gzip) */
       
  8485 var    EXLEN = 5;      /* i: waiting for extra length (gzip) */
       
  8486 var    EXTRA = 6;      /* i: waiting for extra bytes (gzip) */
       
  8487 var    NAME = 7;       /* i: waiting for end of file name (gzip) */
       
  8488 var    COMMENT = 8;    /* i: waiting for end of comment (gzip) */
       
  8489 var    HCRC = 9;       /* i: waiting for header crc (gzip) */
       
  8490 var    DICTID = 10;    /* i: waiting for dictionary check value */
       
  8491 var    DICT = 11;      /* waiting for inflateSetDictionary() call */
       
  8492 var        TYPE = 12;      /* i: waiting for type bits, including last-flag bit */
       
  8493 var        TYPEDO = 13;    /* i: same, but skip check to exit inflate on new block */
       
  8494 var        STORED = 14;    /* i: waiting for stored size (length and complement) */
       
  8495 var        COPY_ = 15;     /* i/o: same as COPY below, but only first time in */
       
  8496 var        COPY = 16;      /* i/o: waiting for input or output to copy stored block */
       
  8497 var        TABLE = 17;     /* i: waiting for dynamic block table lengths */
       
  8498 var        LENLENS = 18;   /* i: waiting for code length code lengths */
       
  8499 var        CODELENS = 19;  /* i: waiting for length/lit and distance code lengths */
       
  8500 var            LEN_ = 20;      /* i: same as LEN below, but only first time in */
       
  8501 var            LEN = 21;       /* i: waiting for length/lit/eob code */
       
  8502 var            LENEXT = 22;    /* i: waiting for length extra bits */
       
  8503 var            DIST = 23;      /* i: waiting for distance code */
       
  8504 var            DISTEXT = 24;   /* i: waiting for distance extra bits */
       
  8505 var            MATCH = 25;     /* o: waiting for output space to copy string */
       
  8506 var            LIT = 26;       /* o: waiting for output space to write literal */
       
  8507 var    CHECK = 27;     /* i: waiting for 32-bit check value */
       
  8508 var    LENGTH = 28;    /* i: waiting for 32-bit length (gzip) */
       
  8509 var    DONE = 29;      /* finished check, done -- remain here until reset */
       
  8510 var    BAD = 30;       /* got a data error -- remain here until reset */
       
  8511 var    MEM = 31;       /* got an inflate() memory error -- remain here until reset */
       
  8512 var    SYNC = 32;      /* looking for synchronization bytes to restart inflate() */
       
  8513 
       
  8514 /* ===========================================================================*/
       
  8515 
       
  8516 
       
  8517 
       
  8518 var ENOUGH_LENS = 852;
       
  8519 var ENOUGH_DISTS = 592;
       
  8520 //var ENOUGH =  (ENOUGH_LENS+ENOUGH_DISTS);
       
  8521 
       
  8522 var MAX_WBITS = 15;
       
  8523 /* 32K LZ77 window */
       
  8524 var DEF_WBITS = MAX_WBITS;
       
  8525 
       
  8526 
       
  8527 function zswap32(q) {
       
  8528   return  (((q >>> 24) & 0xff) +
       
  8529           ((q >>> 8) & 0xff00) +
       
  8530           ((q & 0xff00) << 8) +
       
  8531           ((q & 0xff) << 24));
       
  8532 }
       
  8533 
       
  8534 
       
  8535 function InflateState() {
       
  8536   this.mode = 0;             /* current inflate mode */
       
  8537   this.last = false;          /* true if processing last block */
       
  8538   this.wrap = 0;              /* bit 0 true for zlib, bit 1 true for gzip */
       
  8539   this.havedict = false;      /* true if dictionary provided */
       
  8540   this.flags = 0;             /* gzip header method and flags (0 if zlib) */
       
  8541   this.dmax = 0;              /* zlib header max distance (INFLATE_STRICT) */
       
  8542   this.check = 0;             /* protected copy of check value */
       
  8543   this.total = 0;             /* protected copy of output count */
       
  8544   // TODO: may be {}
       
  8545   this.head = null;           /* where to save gzip header information */
       
  8546 
       
  8547   /* sliding window */
       
  8548   this.wbits = 0;             /* log base 2 of requested window size */
       
  8549   this.wsize = 0;             /* window size or zero if not using window */
       
  8550   this.whave = 0;             /* valid bytes in the window */
       
  8551   this.wnext = 0;             /* window write index */
       
  8552   this.window = null;         /* allocated sliding window, if needed */
       
  8553 
       
  8554   /* bit accumulator */
       
  8555   this.hold = 0;              /* input bit accumulator */
       
  8556   this.bits = 0;              /* number of bits in "in" */
       
  8557 
       
  8558   /* for string and stored block copying */
       
  8559   this.length = 0;            /* literal or length of data to copy */
       
  8560   this.offset = 0;            /* distance back to copy string from */
       
  8561 
       
  8562   /* for table and code decoding */
       
  8563   this.extra = 0;             /* extra bits needed */
       
  8564 
       
  8565   /* fixed and dynamic code tables */
       
  8566   this.lencode = null;          /* starting table for length/literal codes */
       
  8567   this.distcode = null;         /* starting table for distance codes */
       
  8568   this.lenbits = 0;           /* index bits for lencode */
       
  8569   this.distbits = 0;          /* index bits for distcode */
       
  8570 
       
  8571   /* dynamic table building */
       
  8572   this.ncode = 0;             /* number of code length code lengths */
       
  8573   this.nlen = 0;              /* number of length code lengths */
       
  8574   this.ndist = 0;             /* number of distance code lengths */
       
  8575   this.have = 0;              /* number of code lengths in lens[] */
       
  8576   this.next = null;              /* next available space in codes[] */
       
  8577 
       
  8578   this.lens = new utils.Buf16(320); /* temporary storage for code lengths */
       
  8579   this.work = new utils.Buf16(288); /* work area for code table building */
       
  8580 
       
  8581   /*
       
  8582    because we don't have pointers in js, we use lencode and distcode directly
       
  8583    as buffers so we don't need codes
       
  8584   */
       
  8585   //this.codes = new utils.Buf32(ENOUGH);       /* space for code tables */
       
  8586   this.lendyn = null;              /* dynamic table for length/literal codes (JS specific) */
       
  8587   this.distdyn = null;             /* dynamic table for distance codes (JS specific) */
       
  8588   this.sane = 0;                   /* if false, allow invalid distance too far */
       
  8589   this.back = 0;                   /* bits back of last unprocessed length/lit */
       
  8590   this.was = 0;                    /* initial length of match */
       
  8591 }
       
  8592 
       
  8593 function inflateResetKeep(strm) {
       
  8594   var state;
       
  8595 
       
  8596   if (!strm || !strm.state) { return Z_STREAM_ERROR; }
       
  8597   state = strm.state;
       
  8598   strm.total_in = strm.total_out = state.total = 0;
       
  8599   strm.msg = ''; /*Z_NULL*/
       
  8600   if (state.wrap) {       /* to support ill-conceived Java test suite */
       
  8601     strm.adler = state.wrap & 1;
       
  8602   }
       
  8603   state.mode = HEAD;
       
  8604   state.last = 0;
       
  8605   state.havedict = 0;
       
  8606   state.dmax = 32768;
       
  8607   state.head = null/*Z_NULL*/;
       
  8608   state.hold = 0;
       
  8609   state.bits = 0;
       
  8610   //state.lencode = state.distcode = state.next = state.codes;
       
  8611   state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);
       
  8612   state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);
       
  8613 
       
  8614   state.sane = 1;
       
  8615   state.back = -1;
       
  8616   //Tracev((stderr, "inflate: reset\n"));
       
  8617   return Z_OK;
       
  8618 }
       
  8619 
       
  8620 function inflateReset(strm) {
       
  8621   var state;
       
  8622 
       
  8623   if (!strm || !strm.state) { return Z_STREAM_ERROR; }
       
  8624   state = strm.state;
       
  8625   state.wsize = 0;
       
  8626   state.whave = 0;
       
  8627   state.wnext = 0;
       
  8628   return inflateResetKeep(strm);
       
  8629 
       
  8630 }
       
  8631 
       
  8632 function inflateReset2(strm, windowBits) {
       
  8633   var wrap;
       
  8634   var state;
       
  8635 
       
  8636   /* get the state */
       
  8637   if (!strm || !strm.state) { return Z_STREAM_ERROR; }
       
  8638   state = strm.state;
       
  8639 
       
  8640   /* extract wrap request from windowBits parameter */
       
  8641   if (windowBits < 0) {
       
  8642     wrap = 0;
       
  8643     windowBits = -windowBits;
       
  8644   }
       
  8645   else {
       
  8646     wrap = (windowBits >> 4) + 1;
       
  8647     if (windowBits < 48) {
       
  8648       windowBits &= 15;
       
  8649     }
       
  8650   }
       
  8651 
       
  8652   /* set number of window bits, free window if different */
       
  8653   if (windowBits && (windowBits < 8 || windowBits > 15)) {
       
  8654     return Z_STREAM_ERROR;
       
  8655   }
       
  8656   if (state.window !== null && state.wbits !== windowBits) {
       
  8657     state.window = null;
       
  8658   }
       
  8659 
       
  8660   /* update state and reset the rest of it */
       
  8661   state.wrap = wrap;
       
  8662   state.wbits = windowBits;
       
  8663   return inflateReset(strm);
       
  8664 }
       
  8665 
       
  8666 function inflateInit2(strm, windowBits) {
       
  8667   var ret;
       
  8668   var state;
       
  8669 
       
  8670   if (!strm) { return Z_STREAM_ERROR; }
       
  8671   //strm.msg = Z_NULL;                 /* in case we return an error */
       
  8672 
       
  8673   state = new InflateState();
       
  8674 
       
  8675   //if (state === Z_NULL) return Z_MEM_ERROR;
       
  8676   //Tracev((stderr, "inflate: allocated\n"));
       
  8677   strm.state = state;
       
  8678   state.window = null/*Z_NULL*/;
       
  8679   ret = inflateReset2(strm, windowBits);
       
  8680   if (ret !== Z_OK) {
       
  8681     strm.state = null/*Z_NULL*/;
       
  8682   }
       
  8683   return ret;
       
  8684 }
       
  8685 
       
  8686 function inflateInit(strm) {
       
  8687   return inflateInit2(strm, DEF_WBITS);
       
  8688 }
       
  8689 
       
  8690 
       
  8691 /*
       
  8692  Return state with length and distance decoding tables and index sizes set to
       
  8693  fixed code decoding.  Normally this returns fixed tables from inffixed.h.
       
  8694  If BUILDFIXED is defined, then instead this routine builds the tables the
       
  8695  first time it's called, and returns those tables the first time and
       
  8696  thereafter.  This reduces the size of the code by about 2K bytes, in
       
  8697  exchange for a little execution time.  However, BUILDFIXED should not be
       
  8698  used for threaded applications, since the rewriting of the tables and virgin
       
  8699  may not be thread-safe.
       
  8700  */
       
  8701 var virgin = true;
       
  8702 
       
  8703 var lenfix, distfix; // We have no pointers in JS, so keep tables separate
       
  8704 
       
  8705 function fixedtables(state) {
       
  8706   /* build fixed huffman tables if first call (may not be thread safe) */
       
  8707   if (virgin) {
       
  8708     var sym;
       
  8709 
       
  8710     lenfix = new utils.Buf32(512);
       
  8711     distfix = new utils.Buf32(32);
       
  8712 
       
  8713     /* literal/length table */
       
  8714     sym = 0;
       
  8715     while (sym < 144) { state.lens[sym++] = 8; }
       
  8716     while (sym < 256) { state.lens[sym++] = 9; }
       
  8717     while (sym < 280) { state.lens[sym++] = 7; }
       
  8718     while (sym < 288) { state.lens[sym++] = 8; }
       
  8719 
       
  8720     inflate_table(LENS,  state.lens, 0, 288, lenfix,   0, state.work, { bits: 9 });
       
  8721 
       
  8722     /* distance table */
       
  8723     sym = 0;
       
  8724     while (sym < 32) { state.lens[sym++] = 5; }
       
  8725 
       
  8726     inflate_table(DISTS, state.lens, 0, 32,   distfix, 0, state.work, { bits: 5 });
       
  8727 
       
  8728     /* do this just once */
       
  8729     virgin = false;
       
  8730   }
       
  8731 
       
  8732   state.lencode = lenfix;
       
  8733   state.lenbits = 9;
       
  8734   state.distcode = distfix;
       
  8735   state.distbits = 5;
       
  8736 }
       
  8737 
       
  8738 
       
  8739 /*
       
  8740  Update the window with the last wsize (normally 32K) bytes written before
       
  8741  returning.  If window does not exist yet, create it.  This is only called
       
  8742  when a window is already in use, or when output has been written during this
       
  8743  inflate call, but the end of the deflate stream has not been reached yet.
       
  8744  It is also called to create a window for dictionary data when a dictionary
       
  8745  is loaded.
       
  8746 
       
  8747  Providing output buffers larger than 32K to inflate() should provide a speed
       
  8748  advantage, since only the last 32K of output is copied to the sliding window
       
  8749  upon return from inflate(), and since all distances after the first 32K of
       
  8750  output will fall in the output data, making match copies simpler and faster.
       
  8751  The advantage may be dependent on the size of the processor's data caches.
       
  8752  */
       
  8753 function updatewindow(strm, src, end, copy) {
       
  8754   var dist;
       
  8755   var state = strm.state;
       
  8756 
       
  8757   /* if it hasn't been done already, allocate space for the window */
       
  8758   if (state.window === null) {
       
  8759     state.wsize = 1 << state.wbits;
       
  8760     state.wnext = 0;
       
  8761     state.whave = 0;
       
  8762 
       
  8763     state.window = new utils.Buf8(state.wsize);
       
  8764   }
       
  8765 
       
  8766   /* copy state->wsize or less output bytes into the circular window */
       
  8767   if (copy >= state.wsize) {
       
  8768     utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);
       
  8769     state.wnext = 0;
       
  8770     state.whave = state.wsize;
       
  8771   }
       
  8772   else {
       
  8773     dist = state.wsize - state.wnext;
       
  8774     if (dist > copy) {
       
  8775       dist = copy;
       
  8776     }
       
  8777     //zmemcpy(state->window + state->wnext, end - copy, dist);
       
  8778     utils.arraySet(state.window, src, end - copy, dist, state.wnext);
       
  8779     copy -= dist;
       
  8780     if (copy) {
       
  8781       //zmemcpy(state->window, end - copy, copy);
       
  8782       utils.arraySet(state.window, src, end - copy, copy, 0);
       
  8783       state.wnext = copy;
       
  8784       state.whave = state.wsize;
       
  8785     }
       
  8786     else {
       
  8787       state.wnext += dist;
       
  8788       if (state.wnext === state.wsize) { state.wnext = 0; }
       
  8789       if (state.whave < state.wsize) { state.whave += dist; }
       
  8790     }
       
  8791   }
       
  8792   return 0;
       
  8793 }
       
  8794 
       
  8795 function inflate(strm, flush) {
       
  8796   var state;
       
  8797   var input, output;          // input/output buffers
       
  8798   var next;                   /* next input INDEX */
       
  8799   var put;                    /* next output INDEX */
       
  8800   var have, left;             /* available input and output */
       
  8801   var hold;                   /* bit buffer */
       
  8802   var bits;                   /* bits in bit buffer */
       
  8803   var _in, _out;              /* save starting available input and output */
       
  8804   var copy;                   /* number of stored or match bytes to copy */
       
  8805   var from;                   /* where to copy match bytes from */
       
  8806   var from_source;
       
  8807   var here = 0;               /* current decoding table entry */
       
  8808   var here_bits, here_op, here_val; // paked "here" denormalized (JS specific)
       
  8809   //var last;                   /* parent table entry */
       
  8810   var last_bits, last_op, last_val; // paked "last" denormalized (JS specific)
       
  8811   var len;                    /* length to copy for repeats, bits to drop */
       
  8812   var ret;                    /* return code */
       
  8813   var hbuf = new utils.Buf8(4);    /* buffer for gzip header crc calculation */
       
  8814   var opts;
       
  8815 
       
  8816   var n; // temporary var for NEED_BITS
       
  8817 
       
  8818   var order = /* permutation of code lengths */
       
  8819     [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];
       
  8820 
       
  8821 
       
  8822   if (!strm || !strm.state || !strm.output ||
       
  8823       (!strm.input && strm.avail_in !== 0)) {
       
  8824     return Z_STREAM_ERROR;
       
  8825   }
       
  8826 
       
  8827   state = strm.state;
       
  8828   if (state.mode === TYPE) { state.mode = TYPEDO; }    /* skip check */
       
  8829 
       
  8830 
       
  8831   //--- LOAD() ---
       
  8832   put = strm.next_out;
       
  8833   output = strm.output;
       
  8834   left = strm.avail_out;
       
  8835   next = strm.next_in;
       
  8836   input = strm.input;
       
  8837   have = strm.avail_in;
       
  8838   hold = state.hold;
       
  8839   bits = state.bits;
       
  8840   //---
       
  8841 
       
  8842   _in = have;
       
  8843   _out = left;
       
  8844   ret = Z_OK;
       
  8845 
       
  8846   inf_leave: // goto emulation
       
  8847   for (;;) {
       
  8848     switch (state.mode) {
       
  8849     case HEAD:
       
  8850       if (state.wrap === 0) {
       
  8851         state.mode = TYPEDO;
       
  8852         break;
       
  8853       }
       
  8854       //=== NEEDBITS(16);
       
  8855       while (bits < 16) {
       
  8856         if (have === 0) { break inf_leave; }
       
  8857         have--;
       
  8858         hold += input[next++] << bits;
       
  8859         bits += 8;
       
  8860       }
       
  8861       //===//
       
  8862       if ((state.wrap & 2) && hold === 0x8b1f) {  /* gzip header */
       
  8863         state.check = 0/*crc32(0L, Z_NULL, 0)*/;
       
  8864         //=== CRC2(state.check, hold);
       
  8865         hbuf[0] = hold & 0xff;
       
  8866         hbuf[1] = (hold >>> 8) & 0xff;
       
  8867         state.check = crc32(state.check, hbuf, 2, 0);
       
  8868         //===//
       
  8869 
       
  8870         //=== INITBITS();
       
  8871         hold = 0;
       
  8872         bits = 0;
       
  8873         //===//
       
  8874         state.mode = FLAGS;
       
  8875         break;
       
  8876       }
       
  8877       state.flags = 0;           /* expect zlib header */
       
  8878       if (state.head) {
       
  8879         state.head.done = false;
       
  8880       }
       
  8881       if (!(state.wrap & 1) ||   /* check if zlib header allowed */
       
  8882         (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {
       
  8883         strm.msg = 'incorrect header check';
       
  8884         state.mode = BAD;
       
  8885         break;
       
  8886       }
       
  8887       if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {
       
  8888         strm.msg = 'unknown compression method';
       
  8889         state.mode = BAD;
       
  8890         break;
       
  8891       }
       
  8892       //--- DROPBITS(4) ---//
       
  8893       hold >>>= 4;
       
  8894       bits -= 4;
       
  8895       //---//
       
  8896       len = (hold & 0x0f)/*BITS(4)*/ + 8;
       
  8897       if (state.wbits === 0) {
       
  8898         state.wbits = len;
       
  8899       }
       
  8900       else if (len > state.wbits) {
       
  8901         strm.msg = 'invalid window size';
       
  8902         state.mode = BAD;
       
  8903         break;
       
  8904       }
       
  8905       state.dmax = 1 << len;
       
  8906       //Tracev((stderr, "inflate:   zlib header ok\n"));
       
  8907       strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;
       
  8908       state.mode = hold & 0x200 ? DICTID : TYPE;
       
  8909       //=== INITBITS();
       
  8910       hold = 0;
       
  8911       bits = 0;
       
  8912       //===//
       
  8913       break;
       
  8914     case FLAGS:
       
  8915       //=== NEEDBITS(16); */
       
  8916       while (bits < 16) {
       
  8917         if (have === 0) { break inf_leave; }
       
  8918         have--;
       
  8919         hold += input[next++] << bits;
       
  8920         bits += 8;
       
  8921       }
       
  8922       //===//
       
  8923       state.flags = hold;
       
  8924       if ((state.flags & 0xff) !== Z_DEFLATED) {
       
  8925         strm.msg = 'unknown compression method';
       
  8926         state.mode = BAD;
       
  8927         break;
       
  8928       }
       
  8929       if (state.flags & 0xe000) {
       
  8930         strm.msg = 'unknown header flags set';
       
  8931         state.mode = BAD;
       
  8932         break;
       
  8933       }
       
  8934       if (state.head) {
       
  8935         state.head.text = ((hold >> 8) & 1);
       
  8936       }
       
  8937       if (state.flags & 0x0200) {
       
  8938         //=== CRC2(state.check, hold);
       
  8939         hbuf[0] = hold & 0xff;
       
  8940         hbuf[1] = (hold >>> 8) & 0xff;
       
  8941         state.check = crc32(state.check, hbuf, 2, 0);
       
  8942         //===//
       
  8943       }
       
  8944       //=== INITBITS();
       
  8945       hold = 0;
       
  8946       bits = 0;
       
  8947       //===//
       
  8948       state.mode = TIME;
       
  8949       /* falls through */
       
  8950     case TIME:
       
  8951       //=== NEEDBITS(32); */
       
  8952       while (bits < 32) {
       
  8953         if (have === 0) { break inf_leave; }
       
  8954         have--;
       
  8955         hold += input[next++] << bits;
       
  8956         bits += 8;
       
  8957       }
       
  8958       //===//
       
  8959       if (state.head) {
       
  8960         state.head.time = hold;
       
  8961       }
       
  8962       if (state.flags & 0x0200) {
       
  8963         //=== CRC4(state.check, hold)
       
  8964         hbuf[0] = hold & 0xff;
       
  8965         hbuf[1] = (hold >>> 8) & 0xff;
       
  8966         hbuf[2] = (hold >>> 16) & 0xff;
       
  8967         hbuf[3] = (hold >>> 24) & 0xff;
       
  8968         state.check = crc32(state.check, hbuf, 4, 0);
       
  8969         //===
       
  8970       }
       
  8971       //=== INITBITS();
       
  8972       hold = 0;
       
  8973       bits = 0;
       
  8974       //===//
       
  8975       state.mode = OS;
       
  8976       /* falls through */
       
  8977     case OS:
       
  8978       //=== NEEDBITS(16); */
       
  8979       while (bits < 16) {
       
  8980         if (have === 0) { break inf_leave; }
       
  8981         have--;
       
  8982         hold += input[next++] << bits;
       
  8983         bits += 8;
       
  8984       }
       
  8985       //===//
       
  8986       if (state.head) {
       
  8987         state.head.xflags = (hold & 0xff);
       
  8988         state.head.os = (hold >> 8);
       
  8989       }
       
  8990       if (state.flags & 0x0200) {
       
  8991         //=== CRC2(state.check, hold);
       
  8992         hbuf[0] = hold & 0xff;
       
  8993         hbuf[1] = (hold >>> 8) & 0xff;
       
  8994         state.check = crc32(state.check, hbuf, 2, 0);
       
  8995         //===//
       
  8996       }
       
  8997       //=== INITBITS();
       
  8998       hold = 0;
       
  8999       bits = 0;
       
  9000       //===//
       
  9001       state.mode = EXLEN;
       
  9002       /* falls through */
       
  9003     case EXLEN:
       
  9004       if (state.flags & 0x0400) {
       
  9005         //=== NEEDBITS(16); */
       
  9006         while (bits < 16) {
       
  9007           if (have === 0) { break inf_leave; }
       
  9008           have--;
       
  9009           hold += input[next++] << bits;
       
  9010           bits += 8;
       
  9011         }
       
  9012         //===//
       
  9013         state.length = hold;
       
  9014         if (state.head) {
       
  9015           state.head.extra_len = hold;
       
  9016         }
       
  9017         if (state.flags & 0x0200) {
       
  9018           //=== CRC2(state.check, hold);
       
  9019           hbuf[0] = hold & 0xff;
       
  9020           hbuf[1] = (hold >>> 8) & 0xff;
       
  9021           state.check = crc32(state.check, hbuf, 2, 0);
       
  9022           //===//
       
  9023         }
       
  9024         //=== INITBITS();
       
  9025         hold = 0;
       
  9026         bits = 0;
       
  9027         //===//
       
  9028       }
       
  9029       else if (state.head) {
       
  9030         state.head.extra = null/*Z_NULL*/;
       
  9031       }
       
  9032       state.mode = EXTRA;
       
  9033       /* falls through */
       
  9034     case EXTRA:
       
  9035       if (state.flags & 0x0400) {
       
  9036         copy = state.length;
       
  9037         if (copy > have) { copy = have; }
       
  9038         if (copy) {
       
  9039           if (state.head) {
       
  9040             len = state.head.extra_len - state.length;
       
  9041             if (!state.head.extra) {
       
  9042               // Use untyped array for more conveniend processing later
       
  9043               state.head.extra = new Array(state.head.extra_len);
       
  9044             }
       
  9045             utils.arraySet(
       
  9046               state.head.extra,
       
  9047               input,
       
  9048               next,
       
  9049               // extra field is limited to 65536 bytes
       
  9050               // - no need for additional size check
       
  9051               copy,
       
  9052               /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/
       
  9053               len
       
  9054             );
       
  9055             //zmemcpy(state.head.extra + len, next,
       
  9056             //        len + copy > state.head.extra_max ?
       
  9057             //        state.head.extra_max - len : copy);
       
  9058           }
       
  9059           if (state.flags & 0x0200) {
       
  9060             state.check = crc32(state.check, input, copy, next);
       
  9061           }
       
  9062           have -= copy;
       
  9063           next += copy;
       
  9064           state.length -= copy;
       
  9065         }
       
  9066         if (state.length) { break inf_leave; }
       
  9067       }
       
  9068       state.length = 0;
       
  9069       state.mode = NAME;
       
  9070       /* falls through */
       
  9071     case NAME:
       
  9072       if (state.flags & 0x0800) {
       
  9073         if (have === 0) { break inf_leave; }
       
  9074         copy = 0;
       
  9075         do {
       
  9076           // TODO: 2 or 1 bytes?
       
  9077           len = input[next + copy++];
       
  9078           /* use constant limit because in js we should not preallocate memory */
       
  9079           if (state.head && len &&
       
  9080               (state.length < 65536 /*state.head.name_max*/)) {
       
  9081             state.head.name += String.fromCharCode(len);
       
  9082           }
       
  9083         } while (len && copy < have);
       
  9084 
       
  9085         if (state.flags & 0x0200) {
       
  9086           state.check = crc32(state.check, input, copy, next);
       
  9087         }
       
  9088         have -= copy;
       
  9089         next += copy;
       
  9090         if (len) { break inf_leave; }
       
  9091       }
       
  9092       else if (state.head) {
       
  9093         state.head.name = null;
       
  9094       }
       
  9095       state.length = 0;
       
  9096       state.mode = COMMENT;
       
  9097       /* falls through */
       
  9098     case COMMENT:
       
  9099       if (state.flags & 0x1000) {
       
  9100         if (have === 0) { break inf_leave; }
       
  9101         copy = 0;
       
  9102         do {
       
  9103           len = input[next + copy++];
       
  9104           /* use constant limit because in js we should not preallocate memory */
       
  9105           if (state.head && len &&
       
  9106               (state.length < 65536 /*state.head.comm_max*/)) {
       
  9107             state.head.comment += String.fromCharCode(len);
       
  9108           }
       
  9109         } while (len && copy < have);
       
  9110         if (state.flags & 0x0200) {
       
  9111           state.check = crc32(state.check, input, copy, next);
       
  9112         }
       
  9113         have -= copy;
       
  9114         next += copy;
       
  9115         if (len) { break inf_leave; }
       
  9116       }
       
  9117       else if (state.head) {
       
  9118         state.head.comment = null;
       
  9119       }
       
  9120       state.mode = HCRC;
       
  9121       /* falls through */
       
  9122     case HCRC:
       
  9123       if (state.flags & 0x0200) {
       
  9124         //=== NEEDBITS(16); */
       
  9125         while (bits < 16) {
       
  9126           if (have === 0) { break inf_leave; }
       
  9127           have--;
       
  9128           hold += input[next++] << bits;
       
  9129           bits += 8;
       
  9130         }
       
  9131         //===//
       
  9132         if (hold !== (state.check & 0xffff)) {
       
  9133           strm.msg = 'header crc mismatch';
       
  9134           state.mode = BAD;
       
  9135           break;
       
  9136         }
       
  9137         //=== INITBITS();
       
  9138         hold = 0;
       
  9139         bits = 0;
       
  9140         //===//
       
  9141       }
       
  9142       if (state.head) {
       
  9143         state.head.hcrc = ((state.flags >> 9) & 1);
       
  9144         state.head.done = true;
       
  9145       }
       
  9146       strm.adler = state.check = 0;
       
  9147       state.mode = TYPE;
       
  9148       break;
       
  9149     case DICTID:
       
  9150       //=== NEEDBITS(32); */
       
  9151       while (bits < 32) {
       
  9152         if (have === 0) { break inf_leave; }
       
  9153         have--;
       
  9154         hold += input[next++] << bits;
       
  9155         bits += 8;
       
  9156       }
       
  9157       //===//
       
  9158       strm.adler = state.check = zswap32(hold);
       
  9159       //=== INITBITS();
       
  9160       hold = 0;
       
  9161       bits = 0;
       
  9162       //===//
       
  9163       state.mode = DICT;
       
  9164       /* falls through */
       
  9165     case DICT:
       
  9166       if (state.havedict === 0) {
       
  9167         //--- RESTORE() ---
       
  9168         strm.next_out = put;
       
  9169         strm.avail_out = left;
       
  9170         strm.next_in = next;
       
  9171         strm.avail_in = have;
       
  9172         state.hold = hold;
       
  9173         state.bits = bits;
       
  9174         //---
       
  9175         return Z_NEED_DICT;
       
  9176       }
       
  9177       strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;
       
  9178       state.mode = TYPE;
       
  9179       /* falls through */
       
  9180     case TYPE:
       
  9181       if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }
       
  9182       /* falls through */
       
  9183     case TYPEDO:
       
  9184       if (state.last) {
       
  9185         //--- BYTEBITS() ---//
       
  9186         hold >>>= bits & 7;
       
  9187         bits -= bits & 7;
       
  9188         //---//
       
  9189         state.mode = CHECK;
       
  9190         break;
       
  9191       }
       
  9192       //=== NEEDBITS(3); */
       
  9193       while (bits < 3) {
       
  9194         if (have === 0) { break inf_leave; }
       
  9195         have--;
       
  9196         hold += input[next++] << bits;
       
  9197         bits += 8;
       
  9198       }
       
  9199       //===//
       
  9200       state.last = (hold & 0x01)/*BITS(1)*/;
       
  9201       //--- DROPBITS(1) ---//
       
  9202       hold >>>= 1;
       
  9203       bits -= 1;
       
  9204       //---//
       
  9205 
       
  9206       switch ((hold & 0x03)/*BITS(2)*/) {
       
  9207       case 0:                             /* stored block */
       
  9208         //Tracev((stderr, "inflate:     stored block%s\n",
       
  9209         //        state.last ? " (last)" : ""));
       
  9210         state.mode = STORED;
       
  9211         break;
       
  9212       case 1:                             /* fixed block */
       
  9213         fixedtables(state);
       
  9214         //Tracev((stderr, "inflate:     fixed codes block%s\n",
       
  9215         //        state.last ? " (last)" : ""));
       
  9216         state.mode = LEN_;             /* decode codes */
       
  9217         if (flush === Z_TREES) {
       
  9218           //--- DROPBITS(2) ---//
       
  9219           hold >>>= 2;
       
  9220           bits -= 2;
       
  9221           //---//
       
  9222           break inf_leave;
       
  9223         }
       
  9224         break;
       
  9225       case 2:                             /* dynamic block */
       
  9226         //Tracev((stderr, "inflate:     dynamic codes block%s\n",
       
  9227         //        state.last ? " (last)" : ""));
       
  9228         state.mode = TABLE;
       
  9229         break;
       
  9230       case 3:
       
  9231         strm.msg = 'invalid block type';
       
  9232         state.mode = BAD;
       
  9233       }
       
  9234       //--- DROPBITS(2) ---//
       
  9235       hold >>>= 2;
       
  9236       bits -= 2;
       
  9237       //---//
       
  9238       break;
       
  9239     case STORED:
       
  9240       //--- BYTEBITS() ---// /* go to byte boundary */
       
  9241       hold >>>= bits & 7;
       
  9242       bits -= bits & 7;
       
  9243       //---//
       
  9244       //=== NEEDBITS(32); */
       
  9245       while (bits < 32) {
       
  9246         if (have === 0) { break inf_leave; }
       
  9247         have--;
       
  9248         hold += input[next++] << bits;
       
  9249         bits += 8;
       
  9250       }
       
  9251       //===//
       
  9252       if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {
       
  9253         strm.msg = 'invalid stored block lengths';
       
  9254         state.mode = BAD;
       
  9255         break;
       
  9256       }
       
  9257       state.length = hold & 0xffff;
       
  9258       //Tracev((stderr, "inflate:       stored length %u\n",
       
  9259       //        state.length));
       
  9260       //=== INITBITS();
       
  9261       hold = 0;
       
  9262       bits = 0;
       
  9263       //===//
       
  9264       state.mode = COPY_;
       
  9265       if (flush === Z_TREES) { break inf_leave; }
       
  9266       /* falls through */
       
  9267     case COPY_:
       
  9268       state.mode = COPY;
       
  9269       /* falls through */
       
  9270     case COPY:
       
  9271       copy = state.length;
       
  9272       if (copy) {
       
  9273         if (copy > have) { copy = have; }
       
  9274         if (copy > left) { copy = left; }
       
  9275         if (copy === 0) { break inf_leave; }
       
  9276         //--- zmemcpy(put, next, copy); ---
       
  9277         utils.arraySet(output, input, next, copy, put);
       
  9278         //---//
       
  9279         have -= copy;
       
  9280         next += copy;
       
  9281         left -= copy;
       
  9282         put += copy;
       
  9283         state.length -= copy;
       
  9284         break;
       
  9285       }
       
  9286       //Tracev((stderr, "inflate:       stored end\n"));
       
  9287       state.mode = TYPE;
       
  9288       break;
       
  9289     case TABLE:
       
  9290       //=== NEEDBITS(14); */
       
  9291       while (bits < 14) {
       
  9292         if (have === 0) { break inf_leave; }
       
  9293         have--;
       
  9294         hold += input[next++] << bits;
       
  9295         bits += 8;
       
  9296       }
       
  9297       //===//
       
  9298       state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;
       
  9299       //--- DROPBITS(5) ---//
       
  9300       hold >>>= 5;
       
  9301       bits -= 5;
       
  9302       //---//
       
  9303       state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;
       
  9304       //--- DROPBITS(5) ---//
       
  9305       hold >>>= 5;
       
  9306       bits -= 5;
       
  9307       //---//
       
  9308       state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;
       
  9309       //--- DROPBITS(4) ---//
       
  9310       hold >>>= 4;
       
  9311       bits -= 4;
       
  9312       //---//
       
  9313 //#ifndef PKZIP_BUG_WORKAROUND
       
  9314       if (state.nlen > 286 || state.ndist > 30) {
       
  9315         strm.msg = 'too many length or distance symbols';
       
  9316         state.mode = BAD;
       
  9317         break;
       
  9318       }
       
  9319 //#endif
       
  9320       //Tracev((stderr, "inflate:       table sizes ok\n"));
       
  9321       state.have = 0;
       
  9322       state.mode = LENLENS;
       
  9323       /* falls through */
       
  9324     case LENLENS:
       
  9325       while (state.have < state.ncode) {
       
  9326         //=== NEEDBITS(3);
       
  9327         while (bits < 3) {
       
  9328           if (have === 0) { break inf_leave; }
       
  9329           have--;
       
  9330           hold += input[next++] << bits;
       
  9331           bits += 8;
       
  9332         }
       
  9333         //===//
       
  9334         state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);
       
  9335         //--- DROPBITS(3) ---//
       
  9336         hold >>>= 3;
       
  9337         bits -= 3;
       
  9338         //---//
       
  9339       }
       
  9340       while (state.have < 19) {
       
  9341         state.lens[order[state.have++]] = 0;
       
  9342       }
       
  9343       // We have separate tables & no pointers. 2 commented lines below not needed.
       
  9344       //state.next = state.codes;
       
  9345       //state.lencode = state.next;
       
  9346       // Switch to use dynamic table
       
  9347       state.lencode = state.lendyn;
       
  9348       state.lenbits = 7;
       
  9349 
       
  9350       opts = { bits: state.lenbits };
       
  9351       ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);
       
  9352       state.lenbits = opts.bits;
       
  9353 
       
  9354       if (ret) {
       
  9355         strm.msg = 'invalid code lengths set';
       
  9356         state.mode = BAD;
       
  9357         break;
       
  9358       }
       
  9359       //Tracev((stderr, "inflate:       code lengths ok\n"));
       
  9360       state.have = 0;
       
  9361       state.mode = CODELENS;
       
  9362       /* falls through */
       
  9363     case CODELENS:
       
  9364       while (state.have < state.nlen + state.ndist) {
       
  9365         for (;;) {
       
  9366           here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/
       
  9367           here_bits = here >>> 24;
       
  9368           here_op = (here >>> 16) & 0xff;
       
  9369           here_val = here & 0xffff;
       
  9370 
       
  9371           if ((here_bits) <= bits) { break; }
       
  9372           //--- PULLBYTE() ---//
       
  9373           if (have === 0) { break inf_leave; }
       
  9374           have--;
       
  9375           hold += input[next++] << bits;
       
  9376           bits += 8;
       
  9377           //---//
       
  9378         }
       
  9379         if (here_val < 16) {
       
  9380           //--- DROPBITS(here.bits) ---//
       
  9381           hold >>>= here_bits;
       
  9382           bits -= here_bits;
       
  9383           //---//
       
  9384           state.lens[state.have++] = here_val;
       
  9385         }
       
  9386         else {
       
  9387           if (here_val === 16) {
       
  9388             //=== NEEDBITS(here.bits + 2);
       
  9389             n = here_bits + 2;
       
  9390             while (bits < n) {
       
  9391               if (have === 0) { break inf_leave; }
       
  9392               have--;
       
  9393               hold += input[next++] << bits;
       
  9394               bits += 8;
       
  9395             }
       
  9396             //===//
       
  9397             //--- DROPBITS(here.bits) ---//
       
  9398             hold >>>= here_bits;
       
  9399             bits -= here_bits;
       
  9400             //---//
       
  9401             if (state.have === 0) {
       
  9402               strm.msg = 'invalid bit length repeat';
       
  9403               state.mode = BAD;
       
  9404               break;
       
  9405             }
       
  9406             len = state.lens[state.have - 1];
       
  9407             copy = 3 + (hold & 0x03);//BITS(2);
       
  9408             //--- DROPBITS(2) ---//
       
  9409             hold >>>= 2;
       
  9410             bits -= 2;
       
  9411             //---//
       
  9412           }
       
  9413           else if (here_val === 17) {
       
  9414             //=== NEEDBITS(here.bits + 3);
       
  9415             n = here_bits + 3;
       
  9416             while (bits < n) {
       
  9417               if (have === 0) { break inf_leave; }
       
  9418               have--;
       
  9419               hold += input[next++] << bits;
       
  9420               bits += 8;
       
  9421             }
       
  9422             //===//
       
  9423             //--- DROPBITS(here.bits) ---//
       
  9424             hold >>>= here_bits;
       
  9425             bits -= here_bits;
       
  9426             //---//
       
  9427             len = 0;
       
  9428             copy = 3 + (hold & 0x07);//BITS(3);
       
  9429             //--- DROPBITS(3) ---//
       
  9430             hold >>>= 3;
       
  9431             bits -= 3;
       
  9432             //---//
       
  9433           }
       
  9434           else {
       
  9435             //=== NEEDBITS(here.bits + 7);
       
  9436             n = here_bits + 7;
       
  9437             while (bits < n) {
       
  9438               if (have === 0) { break inf_leave; }
       
  9439               have--;
       
  9440               hold += input[next++] << bits;
       
  9441               bits += 8;
       
  9442             }
       
  9443             //===//
       
  9444             //--- DROPBITS(here.bits) ---//
       
  9445             hold >>>= here_bits;
       
  9446             bits -= here_bits;
       
  9447             //---//
       
  9448             len = 0;
       
  9449             copy = 11 + (hold & 0x7f);//BITS(7);
       
  9450             //--- DROPBITS(7) ---//
       
  9451             hold >>>= 7;
       
  9452             bits -= 7;
       
  9453             //---//
       
  9454           }
       
  9455           if (state.have + copy > state.nlen + state.ndist) {
       
  9456             strm.msg = 'invalid bit length repeat';
       
  9457             state.mode = BAD;
       
  9458             break;
       
  9459           }
       
  9460           while (copy--) {
       
  9461             state.lens[state.have++] = len;
       
  9462           }
       
  9463         }
       
  9464       }
       
  9465 
       
  9466       /* handle error breaks in while */
       
  9467       if (state.mode === BAD) { break; }
       
  9468 
       
  9469       /* check for end-of-block code (better have one) */
       
  9470       if (state.lens[256] === 0) {
       
  9471         strm.msg = 'invalid code -- missing end-of-block';
       
  9472         state.mode = BAD;
       
  9473         break;
       
  9474       }
       
  9475 
       
  9476       /* build code tables -- note: do not change the lenbits or distbits
       
  9477          values here (9 and 6) without reading the comments in inftrees.h
       
  9478          concerning the ENOUGH constants, which depend on those values */
       
  9479       state.lenbits = 9;
       
  9480 
       
  9481       opts = { bits: state.lenbits };
       
  9482       ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);
       
  9483       // We have separate tables & no pointers. 2 commented lines below not needed.
       
  9484       // state.next_index = opts.table_index;
       
  9485       state.lenbits = opts.bits;
       
  9486       // state.lencode = state.next;
       
  9487 
       
  9488       if (ret) {
       
  9489         strm.msg = 'invalid literal/lengths set';
       
  9490         state.mode = BAD;
       
  9491         break;
       
  9492       }
       
  9493 
       
  9494       state.distbits = 6;
       
  9495       //state.distcode.copy(state.codes);
       
  9496       // Switch to use dynamic table
       
  9497       state.distcode = state.distdyn;
       
  9498       opts = { bits: state.distbits };
       
  9499       ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);
       
  9500       // We have separate tables & no pointers. 2 commented lines below not needed.
       
  9501       // state.next_index = opts.table_index;
       
  9502       state.distbits = opts.bits;
       
  9503       // state.distcode = state.next;
       
  9504 
       
  9505       if (ret) {
       
  9506         strm.msg = 'invalid distances set';
       
  9507         state.mode = BAD;
       
  9508         break;
       
  9509       }
       
  9510       //Tracev((stderr, 'inflate:       codes ok\n'));
       
  9511       state.mode = LEN_;
       
  9512       if (flush === Z_TREES) { break inf_leave; }
       
  9513       /* falls through */
       
  9514     case LEN_:
       
  9515       state.mode = LEN;
       
  9516       /* falls through */
       
  9517     case LEN:
       
  9518       if (have >= 6 && left >= 258) {
       
  9519         //--- RESTORE() ---
       
  9520         strm.next_out = put;
       
  9521         strm.avail_out = left;
       
  9522         strm.next_in = next;
       
  9523         strm.avail_in = have;
       
  9524         state.hold = hold;
       
  9525         state.bits = bits;
       
  9526         //---
       
  9527         inflate_fast(strm, _out);
       
  9528         //--- LOAD() ---
       
  9529         put = strm.next_out;
       
  9530         output = strm.output;
       
  9531         left = strm.avail_out;
       
  9532         next = strm.next_in;
       
  9533         input = strm.input;
       
  9534         have = strm.avail_in;
       
  9535         hold = state.hold;
       
  9536         bits = state.bits;
       
  9537         //---
       
  9538 
       
  9539         if (state.mode === TYPE) {
       
  9540           state.back = -1;
       
  9541         }
       
  9542         break;
       
  9543       }
       
  9544       state.back = 0;
       
  9545       for (;;) {
       
  9546         here = state.lencode[hold & ((1 << state.lenbits) - 1)];  /*BITS(state.lenbits)*/
       
  9547         here_bits = here >>> 24;
       
  9548         here_op = (here >>> 16) & 0xff;
       
  9549         here_val = here & 0xffff;
       
  9550 
       
  9551         if (here_bits <= bits) { break; }
       
  9552         //--- PULLBYTE() ---//
       
  9553         if (have === 0) { break inf_leave; }
       
  9554         have--;
       
  9555         hold += input[next++] << bits;
       
  9556         bits += 8;
       
  9557         //---//
       
  9558       }
       
  9559       if (here_op && (here_op & 0xf0) === 0) {
       
  9560         last_bits = here_bits;
       
  9561         last_op = here_op;
       
  9562         last_val = here_val;
       
  9563         for (;;) {
       
  9564           here = state.lencode[last_val +
       
  9565                   ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];
       
  9566           here_bits = here >>> 24;
       
  9567           here_op = (here >>> 16) & 0xff;
       
  9568           here_val = here & 0xffff;
       
  9569 
       
  9570           if ((last_bits + here_bits) <= bits) { break; }
       
  9571           //--- PULLBYTE() ---//
       
  9572           if (have === 0) { break inf_leave; }
       
  9573           have--;
       
  9574           hold += input[next++] << bits;
       
  9575           bits += 8;
       
  9576           //---//
       
  9577         }
       
  9578         //--- DROPBITS(last.bits) ---//
       
  9579         hold >>>= last_bits;
       
  9580         bits -= last_bits;
       
  9581         //---//
       
  9582         state.back += last_bits;
       
  9583       }
       
  9584       //--- DROPBITS(here.bits) ---//
       
  9585       hold >>>= here_bits;
       
  9586       bits -= here_bits;
       
  9587       //---//
       
  9588       state.back += here_bits;
       
  9589       state.length = here_val;
       
  9590       if (here_op === 0) {
       
  9591         //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?
       
  9592         //        "inflate:         literal '%c'\n" :
       
  9593         //        "inflate:         literal 0x%02x\n", here.val));
       
  9594         state.mode = LIT;
       
  9595         break;
       
  9596       }
       
  9597       if (here_op & 32) {
       
  9598         //Tracevv((stderr, "inflate:         end of block\n"));
       
  9599         state.back = -1;
       
  9600         state.mode = TYPE;
       
  9601         break;
       
  9602       }
       
  9603       if (here_op & 64) {
       
  9604         strm.msg = 'invalid literal/length code';
       
  9605         state.mode = BAD;
       
  9606         break;
       
  9607       }
       
  9608       state.extra = here_op & 15;
       
  9609       state.mode = LENEXT;
       
  9610       /* falls through */
       
  9611     case LENEXT:
       
  9612       if (state.extra) {
       
  9613         //=== NEEDBITS(state.extra);
       
  9614         n = state.extra;
       
  9615         while (bits < n) {
       
  9616           if (have === 0) { break inf_leave; }
       
  9617           have--;
       
  9618           hold += input[next++] << bits;
       
  9619           bits += 8;
       
  9620         }
       
  9621         //===//
       
  9622         state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;
       
  9623         //--- DROPBITS(state.extra) ---//
       
  9624         hold >>>= state.extra;
       
  9625         bits -= state.extra;
       
  9626         //---//
       
  9627         state.back += state.extra;
       
  9628       }
       
  9629       //Tracevv((stderr, "inflate:         length %u\n", state.length));
       
  9630       state.was = state.length;
       
  9631       state.mode = DIST;
       
  9632       /* falls through */
       
  9633     case DIST:
       
  9634       for (;;) {
       
  9635         here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/
       
  9636         here_bits = here >>> 24;
       
  9637         here_op = (here >>> 16) & 0xff;
       
  9638         here_val = here & 0xffff;
       
  9639 
       
  9640         if ((here_bits) <= bits) { break; }
       
  9641         //--- PULLBYTE() ---//
       
  9642         if (have === 0) { break inf_leave; }
       
  9643         have--;
       
  9644         hold += input[next++] << bits;
       
  9645         bits += 8;
       
  9646         //---//
       
  9647       }
       
  9648       if ((here_op & 0xf0) === 0) {
       
  9649         last_bits = here_bits;
       
  9650         last_op = here_op;
       
  9651         last_val = here_val;
       
  9652         for (;;) {
       
  9653           here = state.distcode[last_val +
       
  9654                   ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];
       
  9655           here_bits = here >>> 24;
       
  9656           here_op = (here >>> 16) & 0xff;
       
  9657           here_val = here & 0xffff;
       
  9658 
       
  9659           if ((last_bits + here_bits) <= bits) { break; }
       
  9660           //--- PULLBYTE() ---//
       
  9661           if (have === 0) { break inf_leave; }
       
  9662           have--;
       
  9663           hold += input[next++] << bits;
       
  9664           bits += 8;
       
  9665           //---//
       
  9666         }
       
  9667         //--- DROPBITS(last.bits) ---//
       
  9668         hold >>>= last_bits;
       
  9669         bits -= last_bits;
       
  9670         //---//
       
  9671         state.back += last_bits;
       
  9672       }
       
  9673       //--- DROPBITS(here.bits) ---//
       
  9674       hold >>>= here_bits;
       
  9675       bits -= here_bits;
       
  9676       //---//
       
  9677       state.back += here_bits;
       
  9678       if (here_op & 64) {
       
  9679         strm.msg = 'invalid distance code';
       
  9680         state.mode = BAD;
       
  9681         break;
       
  9682       }
       
  9683       state.offset = here_val;
       
  9684       state.extra = (here_op) & 15;
       
  9685       state.mode = DISTEXT;
       
  9686       /* falls through */
       
  9687     case DISTEXT:
       
  9688       if (state.extra) {
       
  9689         //=== NEEDBITS(state.extra);
       
  9690         n = state.extra;
       
  9691         while (bits < n) {
       
  9692           if (have === 0) { break inf_leave; }
       
  9693           have--;
       
  9694           hold += input[next++] << bits;
       
  9695           bits += 8;
       
  9696         }
       
  9697         //===//
       
  9698         state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;
       
  9699         //--- DROPBITS(state.extra) ---//
       
  9700         hold >>>= state.extra;
       
  9701         bits -= state.extra;
       
  9702         //---//
       
  9703         state.back += state.extra;
       
  9704       }
       
  9705 //#ifdef INFLATE_STRICT
       
  9706       if (state.offset > state.dmax) {
       
  9707         strm.msg = 'invalid distance too far back';
       
  9708         state.mode = BAD;
       
  9709         break;
       
  9710       }
       
  9711 //#endif
       
  9712       //Tracevv((stderr, "inflate:         distance %u\n", state.offset));
       
  9713       state.mode = MATCH;
       
  9714       /* falls through */
       
  9715     case MATCH:
       
  9716       if (left === 0) { break inf_leave; }
       
  9717       copy = _out - left;
       
  9718       if (state.offset > copy) {         /* copy from window */
       
  9719         copy = state.offset - copy;
       
  9720         if (copy > state.whave) {
       
  9721           if (state.sane) {
       
  9722             strm.msg = 'invalid distance too far back';
       
  9723             state.mode = BAD;
       
  9724             break;
       
  9725           }
       
  9726 // (!) This block is disabled in zlib defailts,
       
  9727 // don't enable it for binary compatibility
       
  9728 //#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR
       
  9729 //          Trace((stderr, "inflate.c too far\n"));
       
  9730 //          copy -= state.whave;
       
  9731 //          if (copy > state.length) { copy = state.length; }
       
  9732 //          if (copy > left) { copy = left; }
       
  9733 //          left -= copy;
       
  9734 //          state.length -= copy;
       
  9735 //          do {
       
  9736 //            output[put++] = 0;
       
  9737 //          } while (--copy);
       
  9738 //          if (state.length === 0) { state.mode = LEN; }
       
  9739 //          break;
       
  9740 //#endif
       
  9741         }
       
  9742         if (copy > state.wnext) {
       
  9743           copy -= state.wnext;
       
  9744           from = state.wsize - copy;
       
  9745         }
       
  9746         else {
       
  9747           from = state.wnext - copy;
       
  9748         }
       
  9749         if (copy > state.length) { copy = state.length; }
       
  9750         from_source = state.window;
       
  9751       }
       
  9752       else {                              /* copy from output */
       
  9753         from_source = output;
       
  9754         from = put - state.offset;
       
  9755         copy = state.length;
       
  9756       }
       
  9757       if (copy > left) { copy = left; }
       
  9758       left -= copy;
       
  9759       state.length -= copy;
       
  9760       do {
       
  9761         output[put++] = from_source[from++];
       
  9762       } while (--copy);
       
  9763       if (state.length === 0) { state.mode = LEN; }
       
  9764       break;
       
  9765     case LIT:
       
  9766       if (left === 0) { break inf_leave; }
       
  9767       output[put++] = state.length;
       
  9768       left--;
       
  9769       state.mode = LEN;
       
  9770       break;
       
  9771     case CHECK:
       
  9772       if (state.wrap) {
       
  9773         //=== NEEDBITS(32);
       
  9774         while (bits < 32) {
       
  9775           if (have === 0) { break inf_leave; }
       
  9776           have--;
       
  9777           // Use '|' insdead of '+' to make sure that result is signed
       
  9778           hold |= input[next++] << bits;
       
  9779           bits += 8;
       
  9780         }
       
  9781         //===//
       
  9782         _out -= left;
       
  9783         strm.total_out += _out;
       
  9784         state.total += _out;
       
  9785         if (_out) {
       
  9786           strm.adler = state.check =
       
  9787               /*UPDATE(state.check, put - _out, _out);*/
       
  9788               (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));
       
  9789 
       
  9790         }
       
  9791         _out = left;
       
  9792         // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too
       
  9793         if ((state.flags ? hold : zswap32(hold)) !== state.check) {
       
  9794           strm.msg = 'incorrect data check';
       
  9795           state.mode = BAD;
       
  9796           break;
       
  9797         }
       
  9798         //=== INITBITS();
       
  9799         hold = 0;
       
  9800         bits = 0;
       
  9801         //===//
       
  9802         //Tracev((stderr, "inflate:   check matches trailer\n"));
       
  9803       }
       
  9804       state.mode = LENGTH;
       
  9805       /* falls through */
       
  9806     case LENGTH:
       
  9807       if (state.wrap && state.flags) {
       
  9808         //=== NEEDBITS(32);
       
  9809         while (bits < 32) {
       
  9810           if (have === 0) { break inf_leave; }
       
  9811           have--;
       
  9812           hold += input[next++] << bits;
       
  9813           bits += 8;
       
  9814         }
       
  9815         //===//
       
  9816         if (hold !== (state.total & 0xffffffff)) {
       
  9817           strm.msg = 'incorrect length check';
       
  9818           state.mode = BAD;
       
  9819           break;
       
  9820         }
       
  9821         //=== INITBITS();
       
  9822         hold = 0;
       
  9823         bits = 0;
       
  9824         //===//
       
  9825         //Tracev((stderr, "inflate:   length matches trailer\n"));
       
  9826       }
       
  9827       state.mode = DONE;
       
  9828       /* falls through */
       
  9829     case DONE:
       
  9830       ret = Z_STREAM_END;
       
  9831       break inf_leave;
       
  9832     case BAD:
       
  9833       ret = Z_DATA_ERROR;
       
  9834       break inf_leave;
       
  9835     case MEM:
       
  9836       return Z_MEM_ERROR;
       
  9837     case SYNC:
       
  9838       /* falls through */
       
  9839     default:
       
  9840       return Z_STREAM_ERROR;
       
  9841     }
       
  9842   }
       
  9843 
       
  9844   // inf_leave <- here is real place for "goto inf_leave", emulated via "break inf_leave"
       
  9845 
       
  9846   /*
       
  9847      Return from inflate(), updating the total counts and the check value.
       
  9848      If there was no progress during the inflate() call, return a buffer
       
  9849      error.  Call updatewindow() to create and/or update the window state.
       
  9850      Note: a memory error from inflate() is non-recoverable.
       
  9851    */
       
  9852 
       
  9853   //--- RESTORE() ---
       
  9854   strm.next_out = put;
       
  9855   strm.avail_out = left;
       
  9856   strm.next_in = next;
       
  9857   strm.avail_in = have;
       
  9858   state.hold = hold;
       
  9859   state.bits = bits;
       
  9860   //---
       
  9861 
       
  9862   if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&
       
  9863                       (state.mode < CHECK || flush !== Z_FINISH))) {
       
  9864     if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {
       
  9865       state.mode = MEM;
       
  9866       return Z_MEM_ERROR;
       
  9867     }
       
  9868   }
       
  9869   _in -= strm.avail_in;
       
  9870   _out -= strm.avail_out;
       
  9871   strm.total_in += _in;
       
  9872   strm.total_out += _out;
       
  9873   state.total += _out;
       
  9874   if (state.wrap && _out) {
       
  9875     strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/
       
  9876       (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));
       
  9877   }
       
  9878   strm.data_type = state.bits + (state.last ? 64 : 0) +
       
  9879                     (state.mode === TYPE ? 128 : 0) +
       
  9880                     (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);
       
  9881   if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {
       
  9882     ret = Z_BUF_ERROR;
       
  9883   }
       
  9884   return ret;
       
  9885 }
       
  9886 
       
  9887 function inflateEnd(strm) {
       
  9888 
       
  9889   if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {
       
  9890     return Z_STREAM_ERROR;
       
  9891   }
       
  9892 
       
  9893   var state = strm.state;
       
  9894   if (state.window) {
       
  9895     state.window = null;
       
  9896   }
       
  9897   strm.state = null;
       
  9898   return Z_OK;
       
  9899 }
       
  9900 
       
  9901 function inflateGetHeader(strm, head) {
       
  9902   var state;
       
  9903 
       
  9904   /* check state */
       
  9905   if (!strm || !strm.state) { return Z_STREAM_ERROR; }
       
  9906   state = strm.state;
       
  9907   if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }
       
  9908 
       
  9909   /* save header structure */
       
  9910   state.head = head;
       
  9911   head.done = false;
       
  9912   return Z_OK;
       
  9913 }
       
  9914 
       
  9915 function inflateSetDictionary(strm, dictionary) {
       
  9916   var dictLength = dictionary.length;
       
  9917 
       
  9918   var state;
       
  9919   var dictid;
       
  9920   var ret;
       
  9921 
       
  9922   /* check state */
       
  9923   if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }
       
  9924   state = strm.state;
       
  9925 
       
  9926   if (state.wrap !== 0 && state.mode !== DICT) {
       
  9927     return Z_STREAM_ERROR;
       
  9928   }
       
  9929 
       
  9930   /* check for correct dictionary identifier */
       
  9931   if (state.mode === DICT) {
       
  9932     dictid = 1; /* adler32(0, null, 0)*/
       
  9933     /* dictid = adler32(dictid, dictionary, dictLength); */
       
  9934     dictid = adler32(dictid, dictionary, dictLength, 0);
       
  9935     if (dictid !== state.check) {
       
  9936       return Z_DATA_ERROR;
       
  9937     }
       
  9938   }
       
  9939   /* copy dictionary to window using updatewindow(), which will amend the
       
  9940    existing dictionary if appropriate */
       
  9941   ret = updatewindow(strm, dictionary, dictLength, dictLength);
       
  9942   if (ret) {
       
  9943     state.mode = MEM;
       
  9944     return Z_MEM_ERROR;
       
  9945   }
       
  9946   state.havedict = 1;
       
  9947   // Tracev((stderr, "inflate:   dictionary set\n"));
       
  9948   return Z_OK;
       
  9949 }
       
  9950 
       
  9951 exports.inflateReset = inflateReset;
       
  9952 exports.inflateReset2 = inflateReset2;
       
  9953 exports.inflateResetKeep = inflateResetKeep;
       
  9954 exports.inflateInit = inflateInit;
       
  9955 exports.inflateInit2 = inflateInit2;
       
  9956 exports.inflate = inflate;
       
  9957 exports.inflateEnd = inflateEnd;
       
  9958 exports.inflateGetHeader = inflateGetHeader;
       
  9959 exports.inflateSetDictionary = inflateSetDictionary;
       
  9960 exports.inflateInfo = 'pako inflate (from Nodeca project)';
       
  9961 
       
  9962 /* Not implemented
       
  9963 exports.inflateCopy = inflateCopy;
       
  9964 exports.inflateGetDictionary = inflateGetDictionary;
       
  9965 exports.inflateMark = inflateMark;
       
  9966 exports.inflatePrime = inflatePrime;
       
  9967 exports.inflateSync = inflateSync;
       
  9968 exports.inflateSyncPoint = inflateSyncPoint;
       
  9969 exports.inflateUndermine = inflateUndermine;
       
  9970 */
       
  9971 
       
  9972 },{"../utils/common":62,"./adler32":64,"./crc32":66,"./inffast":69,"./inftrees":71}],71:[function(require,module,exports){
       
  9973 'use strict';
       
  9974 
       
  9975 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
  9976 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
  9977 //
       
  9978 // This software is provided 'as-is', without any express or implied
       
  9979 // warranty. In no event will the authors be held liable for any damages
       
  9980 // arising from the use of this software.
       
  9981 //
       
  9982 // Permission is granted to anyone to use this software for any purpose,
       
  9983 // including commercial applications, and to alter it and redistribute it
       
  9984 // freely, subject to the following restrictions:
       
  9985 //
       
  9986 // 1. The origin of this software must not be misrepresented; you must not
       
  9987 //   claim that you wrote the original software. If you use this software
       
  9988 //   in a product, an acknowledgment in the product documentation would be
       
  9989 //   appreciated but is not required.
       
  9990 // 2. Altered source versions must be plainly marked as such, and must not be
       
  9991 //   misrepresented as being the original software.
       
  9992 // 3. This notice may not be removed or altered from any source distribution.
       
  9993 
       
  9994 var utils = require('../utils/common');
       
  9995 
       
  9996 var MAXBITS = 15;
       
  9997 var ENOUGH_LENS = 852;
       
  9998 var ENOUGH_DISTS = 592;
       
  9999 //var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);
       
 10000 
       
 10001 var CODES = 0;
       
 10002 var LENS = 1;
       
 10003 var DISTS = 2;
       
 10004 
       
 10005 var lbase = [ /* Length codes 257..285 base */
       
 10006   3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
       
 10007   35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0
       
 10008 ];
       
 10009 
       
 10010 var lext = [ /* Length codes 257..285 extra */
       
 10011   16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,
       
 10012   19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78
       
 10013 ];
       
 10014 
       
 10015 var dbase = [ /* Distance codes 0..29 base */
       
 10016   1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
       
 10017   257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
       
 10018   8193, 12289, 16385, 24577, 0, 0
       
 10019 ];
       
 10020 
       
 10021 var dext = [ /* Distance codes 0..29 extra */
       
 10022   16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,
       
 10023   23, 23, 24, 24, 25, 25, 26, 26, 27, 27,
       
 10024   28, 28, 29, 29, 64, 64
       
 10025 ];
       
 10026 
       
 10027 module.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)
       
 10028 {
       
 10029   var bits = opts.bits;
       
 10030       //here = opts.here; /* table entry for duplication */
       
 10031 
       
 10032   var len = 0;               /* a code's length in bits */
       
 10033   var sym = 0;               /* index of code symbols */
       
 10034   var min = 0, max = 0;          /* minimum and maximum code lengths */
       
 10035   var root = 0;              /* number of index bits for root table */
       
 10036   var curr = 0;              /* number of index bits for current table */
       
 10037   var drop = 0;              /* code bits to drop for sub-table */
       
 10038   var left = 0;                   /* number of prefix codes available */
       
 10039   var used = 0;              /* code entries in table used */
       
 10040   var huff = 0;              /* Huffman code */
       
 10041   var incr;              /* for incrementing code, index */
       
 10042   var fill;              /* index for replicating entries */
       
 10043   var low;               /* low bits for current root entry */
       
 10044   var mask;              /* mask for low root bits */
       
 10045   var next;             /* next available space in table */
       
 10046   var base = null;     /* base value table to use */
       
 10047   var base_index = 0;
       
 10048 //  var shoextra;    /* extra bits table to use */
       
 10049   var end;                    /* use base and extra for symbol > end */
       
 10050   var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1];    /* number of codes of each length */
       
 10051   var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1];     /* offsets in table for each length */
       
 10052   var extra = null;
       
 10053   var extra_index = 0;
       
 10054 
       
 10055   var here_bits, here_op, here_val;
       
 10056 
       
 10057   /*
       
 10058    Process a set of code lengths to create a canonical Huffman code.  The
       
 10059    code lengths are lens[0..codes-1].  Each length corresponds to the
       
 10060    symbols 0..codes-1.  The Huffman code is generated by first sorting the
       
 10061    symbols by length from short to long, and retaining the symbol order
       
 10062    for codes with equal lengths.  Then the code starts with all zero bits
       
 10063    for the first code of the shortest length, and the codes are integer
       
 10064    increments for the same length, and zeros are appended as the length
       
 10065    increases.  For the deflate format, these bits are stored backwards
       
 10066    from their more natural integer increment ordering, and so when the
       
 10067    decoding tables are built in the large loop below, the integer codes
       
 10068    are incremented backwards.
       
 10069 
       
 10070    This routine assumes, but does not check, that all of the entries in
       
 10071    lens[] are in the range 0..MAXBITS.  The caller must assure this.
       
 10072    1..MAXBITS is interpreted as that code length.  zero means that that
       
 10073    symbol does not occur in this code.
       
 10074 
       
 10075    The codes are sorted by computing a count of codes for each length,
       
 10076    creating from that a table of starting indices for each length in the
       
 10077    sorted table, and then entering the symbols in order in the sorted
       
 10078    table.  The sorted table is work[], with that space being provided by
       
 10079    the caller.
       
 10080 
       
 10081    The length counts are used for other purposes as well, i.e. finding
       
 10082    the minimum and maximum length codes, determining if there are any
       
 10083    codes at all, checking for a valid set of lengths, and looking ahead
       
 10084    at length counts to determine sub-table sizes when building the
       
 10085    decoding tables.
       
 10086    */
       
 10087 
       
 10088   /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */
       
 10089   for (len = 0; len <= MAXBITS; len++) {
       
 10090     count[len] = 0;
       
 10091   }
       
 10092   for (sym = 0; sym < codes; sym++) {
       
 10093     count[lens[lens_index + sym]]++;
       
 10094   }
       
 10095 
       
 10096   /* bound code lengths, force root to be within code lengths */
       
 10097   root = bits;
       
 10098   for (max = MAXBITS; max >= 1; max--) {
       
 10099     if (count[max] !== 0) { break; }
       
 10100   }
       
 10101   if (root > max) {
       
 10102     root = max;
       
 10103   }
       
 10104   if (max === 0) {                     /* no symbols to code at all */
       
 10105     //table.op[opts.table_index] = 64;  //here.op = (var char)64;    /* invalid code marker */
       
 10106     //table.bits[opts.table_index] = 1;   //here.bits = (var char)1;
       
 10107     //table.val[opts.table_index++] = 0;   //here.val = (var short)0;
       
 10108     table[table_index++] = (1 << 24) | (64 << 16) | 0;
       
 10109 
       
 10110 
       
 10111     //table.op[opts.table_index] = 64;
       
 10112     //table.bits[opts.table_index] = 1;
       
 10113     //table.val[opts.table_index++] = 0;
       
 10114     table[table_index++] = (1 << 24) | (64 << 16) | 0;
       
 10115 
       
 10116     opts.bits = 1;
       
 10117     return 0;     /* no symbols, but wait for decoding to report error */
       
 10118   }
       
 10119   for (min = 1; min < max; min++) {
       
 10120     if (count[min] !== 0) { break; }
       
 10121   }
       
 10122   if (root < min) {
       
 10123     root = min;
       
 10124   }
       
 10125 
       
 10126   /* check for an over-subscribed or incomplete set of lengths */
       
 10127   left = 1;
       
 10128   for (len = 1; len <= MAXBITS; len++) {
       
 10129     left <<= 1;
       
 10130     left -= count[len];
       
 10131     if (left < 0) {
       
 10132       return -1;
       
 10133     }        /* over-subscribed */
       
 10134   }
       
 10135   if (left > 0 && (type === CODES || max !== 1)) {
       
 10136     return -1;                      /* incomplete set */
       
 10137   }
       
 10138 
       
 10139   /* generate offsets into symbol table for each length for sorting */
       
 10140   offs[1] = 0;
       
 10141   for (len = 1; len < MAXBITS; len++) {
       
 10142     offs[len + 1] = offs[len] + count[len];
       
 10143   }
       
 10144 
       
 10145   /* sort symbols by length, by symbol order within each length */
       
 10146   for (sym = 0; sym < codes; sym++) {
       
 10147     if (lens[lens_index + sym] !== 0) {
       
 10148       work[offs[lens[lens_index + sym]]++] = sym;
       
 10149     }
       
 10150   }
       
 10151 
       
 10152   /*
       
 10153    Create and fill in decoding tables.  In this loop, the table being
       
 10154    filled is at next and has curr index bits.  The code being used is huff
       
 10155    with length len.  That code is converted to an index by dropping drop
       
 10156    bits off of the bottom.  For codes where len is less than drop + curr,
       
 10157    those top drop + curr - len bits are incremented through all values to
       
 10158    fill the table with replicated entries.
       
 10159 
       
 10160    root is the number of index bits for the root table.  When len exceeds
       
 10161    root, sub-tables are created pointed to by the root entry with an index
       
 10162    of the low root bits of huff.  This is saved in low to check for when a
       
 10163    new sub-table should be started.  drop is zero when the root table is
       
 10164    being filled, and drop is root when sub-tables are being filled.
       
 10165 
       
 10166    When a new sub-table is needed, it is necessary to look ahead in the
       
 10167    code lengths to determine what size sub-table is needed.  The length
       
 10168    counts are used for this, and so count[] is decremented as codes are
       
 10169    entered in the tables.
       
 10170 
       
 10171    used keeps track of how many table entries have been allocated from the
       
 10172    provided *table space.  It is checked for LENS and DIST tables against
       
 10173    the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in
       
 10174    the initial root table size constants.  See the comments in inftrees.h
       
 10175    for more information.
       
 10176 
       
 10177    sym increments through all symbols, and the loop terminates when
       
 10178    all codes of length max, i.e. all codes, have been processed.  This
       
 10179    routine permits incomplete codes, so another loop after this one fills
       
 10180    in the rest of the decoding tables with invalid code markers.
       
 10181    */
       
 10182 
       
 10183   /* set up for code type */
       
 10184   // poor man optimization - use if-else instead of switch,
       
 10185   // to avoid deopts in old v8
       
 10186   if (type === CODES) {
       
 10187     base = extra = work;    /* dummy value--not used */
       
 10188     end = 19;
       
 10189 
       
 10190   } else if (type === LENS) {
       
 10191     base = lbase;
       
 10192     base_index -= 257;
       
 10193     extra = lext;
       
 10194     extra_index -= 257;
       
 10195     end = 256;
       
 10196 
       
 10197   } else {                    /* DISTS */
       
 10198     base = dbase;
       
 10199     extra = dext;
       
 10200     end = -1;
       
 10201   }
       
 10202 
       
 10203   /* initialize opts for loop */
       
 10204   huff = 0;                   /* starting code */
       
 10205   sym = 0;                    /* starting code symbol */
       
 10206   len = min;                  /* starting code length */
       
 10207   next = table_index;              /* current table to fill in */
       
 10208   curr = root;                /* current table index bits */
       
 10209   drop = 0;                   /* current bits to drop from code for index */
       
 10210   low = -1;                   /* trigger new sub-table when len > root */
       
 10211   used = 1 << root;          /* use root table entries */
       
 10212   mask = used - 1;            /* mask for comparing low */
       
 10213 
       
 10214   /* check available table space */
       
 10215   if ((type === LENS && used > ENOUGH_LENS) ||
       
 10216     (type === DISTS && used > ENOUGH_DISTS)) {
       
 10217     return 1;
       
 10218   }
       
 10219 
       
 10220   /* process all codes and make table entries */
       
 10221   for (;;) {
       
 10222     /* create table entry */
       
 10223     here_bits = len - drop;
       
 10224     if (work[sym] < end) {
       
 10225       here_op = 0;
       
 10226       here_val = work[sym];
       
 10227     }
       
 10228     else if (work[sym] > end) {
       
 10229       here_op = extra[extra_index + work[sym]];
       
 10230       here_val = base[base_index + work[sym]];
       
 10231     }
       
 10232     else {
       
 10233       here_op = 32 + 64;         /* end of block */
       
 10234       here_val = 0;
       
 10235     }
       
 10236 
       
 10237     /* replicate for those indices with low len bits equal to huff */
       
 10238     incr = 1 << (len - drop);
       
 10239     fill = 1 << curr;
       
 10240     min = fill;                 /* save offset to next table */
       
 10241     do {
       
 10242       fill -= incr;
       
 10243       table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;
       
 10244     } while (fill !== 0);
       
 10245 
       
 10246     /* backwards increment the len-bit code huff */
       
 10247     incr = 1 << (len - 1);
       
 10248     while (huff & incr) {
       
 10249       incr >>= 1;
       
 10250     }
       
 10251     if (incr !== 0) {
       
 10252       huff &= incr - 1;
       
 10253       huff += incr;
       
 10254     } else {
       
 10255       huff = 0;
       
 10256     }
       
 10257 
       
 10258     /* go to next symbol, update count, len */
       
 10259     sym++;
       
 10260     if (--count[len] === 0) {
       
 10261       if (len === max) { break; }
       
 10262       len = lens[lens_index + work[sym]];
       
 10263     }
       
 10264 
       
 10265     /* create new sub-table if needed */
       
 10266     if (len > root && (huff & mask) !== low) {
       
 10267       /* if first time, transition to sub-tables */
       
 10268       if (drop === 0) {
       
 10269         drop = root;
       
 10270       }
       
 10271 
       
 10272       /* increment past last table */
       
 10273       next += min;            /* here min is 1 << curr */
       
 10274 
       
 10275       /* determine length of next table */
       
 10276       curr = len - drop;
       
 10277       left = 1 << curr;
       
 10278       while (curr + drop < max) {
       
 10279         left -= count[curr + drop];
       
 10280         if (left <= 0) { break; }
       
 10281         curr++;
       
 10282         left <<= 1;
       
 10283       }
       
 10284 
       
 10285       /* check for enough space */
       
 10286       used += 1 << curr;
       
 10287       if ((type === LENS && used > ENOUGH_LENS) ||
       
 10288         (type === DISTS && used > ENOUGH_DISTS)) {
       
 10289         return 1;
       
 10290       }
       
 10291 
       
 10292       /* point entry in root table to sub-table */
       
 10293       low = huff & mask;
       
 10294       /*table.op[low] = curr;
       
 10295       table.bits[low] = root;
       
 10296       table.val[low] = next - opts.table_index;*/
       
 10297       table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;
       
 10298     }
       
 10299   }
       
 10300 
       
 10301   /* fill in remaining table entry if code is incomplete (guaranteed to have
       
 10302    at most one remaining entry, since if the code is incomplete, the
       
 10303    maximum code length that was allowed to get this far is one bit) */
       
 10304   if (huff !== 0) {
       
 10305     //table.op[next + huff] = 64;            /* invalid code marker */
       
 10306     //table.bits[next + huff] = len - drop;
       
 10307     //table.val[next + huff] = 0;
       
 10308     table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;
       
 10309   }
       
 10310 
       
 10311   /* set return parameters */
       
 10312   //opts.table_index += used;
       
 10313   opts.bits = root;
       
 10314   return 0;
       
 10315 };
       
 10316 
       
 10317 },{"../utils/common":62}],72:[function(require,module,exports){
       
 10318 'use strict';
       
 10319 
       
 10320 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
 10321 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
 10322 //
       
 10323 // This software is provided 'as-is', without any express or implied
       
 10324 // warranty. In no event will the authors be held liable for any damages
       
 10325 // arising from the use of this software.
       
 10326 //
       
 10327 // Permission is granted to anyone to use this software for any purpose,
       
 10328 // including commercial applications, and to alter it and redistribute it
       
 10329 // freely, subject to the following restrictions:
       
 10330 //
       
 10331 // 1. The origin of this software must not be misrepresented; you must not
       
 10332 //   claim that you wrote the original software. If you use this software
       
 10333 //   in a product, an acknowledgment in the product documentation would be
       
 10334 //   appreciated but is not required.
       
 10335 // 2. Altered source versions must be plainly marked as such, and must not be
       
 10336 //   misrepresented as being the original software.
       
 10337 // 3. This notice may not be removed or altered from any source distribution.
       
 10338 
       
 10339 module.exports = {
       
 10340   2:      'need dictionary',     /* Z_NEED_DICT       2  */
       
 10341   1:      'stream end',          /* Z_STREAM_END      1  */
       
 10342   0:      '',                    /* Z_OK              0  */
       
 10343   '-1':   'file error',          /* Z_ERRNO         (-1) */
       
 10344   '-2':   'stream error',        /* Z_STREAM_ERROR  (-2) */
       
 10345   '-3':   'data error',          /* Z_DATA_ERROR    (-3) */
       
 10346   '-4':   'insufficient memory', /* Z_MEM_ERROR     (-4) */
       
 10347   '-5':   'buffer error',        /* Z_BUF_ERROR     (-5) */
       
 10348   '-6':   'incompatible version' /* Z_VERSION_ERROR (-6) */
       
 10349 };
       
 10350 
       
 10351 },{}],73:[function(require,module,exports){
       
 10352 'use strict';
       
 10353 
       
 10354 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
 10355 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
 10356 //
       
 10357 // This software is provided 'as-is', without any express or implied
       
 10358 // warranty. In no event will the authors be held liable for any damages
       
 10359 // arising from the use of this software.
       
 10360 //
       
 10361 // Permission is granted to anyone to use this software for any purpose,
       
 10362 // including commercial applications, and to alter it and redistribute it
       
 10363 // freely, subject to the following restrictions:
       
 10364 //
       
 10365 // 1. The origin of this software must not be misrepresented; you must not
       
 10366 //   claim that you wrote the original software. If you use this software
       
 10367 //   in a product, an acknowledgment in the product documentation would be
       
 10368 //   appreciated but is not required.
       
 10369 // 2. Altered source versions must be plainly marked as such, and must not be
       
 10370 //   misrepresented as being the original software.
       
 10371 // 3. This notice may not be removed or altered from any source distribution.
       
 10372 
       
 10373 var utils = require('../utils/common');
       
 10374 
       
 10375 /* Public constants ==========================================================*/
       
 10376 /* ===========================================================================*/
       
 10377 
       
 10378 
       
 10379 //var Z_FILTERED          = 1;
       
 10380 //var Z_HUFFMAN_ONLY      = 2;
       
 10381 //var Z_RLE               = 3;
       
 10382 var Z_FIXED               = 4;
       
 10383 //var Z_DEFAULT_STRATEGY  = 0;
       
 10384 
       
 10385 /* Possible values of the data_type field (though see inflate()) */
       
 10386 var Z_BINARY              = 0;
       
 10387 var Z_TEXT                = 1;
       
 10388 //var Z_ASCII             = 1; // = Z_TEXT
       
 10389 var Z_UNKNOWN             = 2;
       
 10390 
       
 10391 /*============================================================================*/
       
 10392 
       
 10393 
       
 10394 function zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }
       
 10395 
       
 10396 // From zutil.h
       
 10397 
       
 10398 var STORED_BLOCK = 0;
       
 10399 var STATIC_TREES = 1;
       
 10400 var DYN_TREES    = 2;
       
 10401 /* The three kinds of block type */
       
 10402 
       
 10403 var MIN_MATCH    = 3;
       
 10404 var MAX_MATCH    = 258;
       
 10405 /* The minimum and maximum match lengths */
       
 10406 
       
 10407 // From deflate.h
       
 10408 /* ===========================================================================
       
 10409  * Internal compression state.
       
 10410  */
       
 10411 
       
 10412 var LENGTH_CODES  = 29;
       
 10413 /* number of length codes, not counting the special END_BLOCK code */
       
 10414 
       
 10415 var LITERALS      = 256;
       
 10416 /* number of literal bytes 0..255 */
       
 10417 
       
 10418 var L_CODES       = LITERALS + 1 + LENGTH_CODES;
       
 10419 /* number of Literal or Length codes, including the END_BLOCK code */
       
 10420 
       
 10421 var D_CODES       = 30;
       
 10422 /* number of distance codes */
       
 10423 
       
 10424 var BL_CODES      = 19;
       
 10425 /* number of codes used to transfer the bit lengths */
       
 10426 
       
 10427 var HEAP_SIZE     = 2 * L_CODES + 1;
       
 10428 /* maximum heap size */
       
 10429 
       
 10430 var MAX_BITS      = 15;
       
 10431 /* All codes must not exceed MAX_BITS bits */
       
 10432 
       
 10433 var Buf_size      = 16;
       
 10434 /* size of bit buffer in bi_buf */
       
 10435 
       
 10436 
       
 10437 /* ===========================================================================
       
 10438  * Constants
       
 10439  */
       
 10440 
       
 10441 var MAX_BL_BITS = 7;
       
 10442 /* Bit length codes must not exceed MAX_BL_BITS bits */
       
 10443 
       
 10444 var END_BLOCK   = 256;
       
 10445 /* end of block literal code */
       
 10446 
       
 10447 var REP_3_6     = 16;
       
 10448 /* repeat previous bit length 3-6 times (2 bits of repeat count) */
       
 10449 
       
 10450 var REPZ_3_10   = 17;
       
 10451 /* repeat a zero length 3-10 times  (3 bits of repeat count) */
       
 10452 
       
 10453 var REPZ_11_138 = 18;
       
 10454 /* repeat a zero length 11-138 times  (7 bits of repeat count) */
       
 10455 
       
 10456 /* eslint-disable comma-spacing,array-bracket-spacing */
       
 10457 var extra_lbits =   /* extra bits for each length code */
       
 10458   [0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0];
       
 10459 
       
 10460 var extra_dbits =   /* extra bits for each distance code */
       
 10461   [0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];
       
 10462 
       
 10463 var extra_blbits =  /* extra bits for each bit length code */
       
 10464   [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7];
       
 10465 
       
 10466 var bl_order =
       
 10467   [16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];
       
 10468 /* eslint-enable comma-spacing,array-bracket-spacing */
       
 10469 
       
 10470 /* The lengths of the bit length codes are sent in order of decreasing
       
 10471  * probability, to avoid transmitting the lengths for unused bit length codes.
       
 10472  */
       
 10473 
       
 10474 /* ===========================================================================
       
 10475  * Local data. These are initialized only once.
       
 10476  */
       
 10477 
       
 10478 // We pre-fill arrays with 0 to avoid uninitialized gaps
       
 10479 
       
 10480 var DIST_CODE_LEN = 512; /* see definition of array dist_code below */
       
 10481 
       
 10482 // !!!! Use flat array insdead of structure, Freq = i*2, Len = i*2+1
       
 10483 var static_ltree  = new Array((L_CODES + 2) * 2);
       
 10484 zero(static_ltree);
       
 10485 /* The static literal tree. Since the bit lengths are imposed, there is no
       
 10486  * need for the L_CODES extra codes used during heap construction. However
       
 10487  * The codes 286 and 287 are needed to build a canonical tree (see _tr_init
       
 10488  * below).
       
 10489  */
       
 10490 
       
 10491 var static_dtree  = new Array(D_CODES * 2);
       
 10492 zero(static_dtree);
       
 10493 /* The static distance tree. (Actually a trivial tree since all codes use
       
 10494  * 5 bits.)
       
 10495  */
       
 10496 
       
 10497 var _dist_code    = new Array(DIST_CODE_LEN);
       
 10498 zero(_dist_code);
       
 10499 /* Distance codes. The first 256 values correspond to the distances
       
 10500  * 3 .. 258, the last 256 values correspond to the top 8 bits of
       
 10501  * the 15 bit distances.
       
 10502  */
       
 10503 
       
 10504 var _length_code  = new Array(MAX_MATCH - MIN_MATCH + 1);
       
 10505 zero(_length_code);
       
 10506 /* length code for each normalized match length (0 == MIN_MATCH) */
       
 10507 
       
 10508 var base_length   = new Array(LENGTH_CODES);
       
 10509 zero(base_length);
       
 10510 /* First normalized length for each code (0 = MIN_MATCH) */
       
 10511 
       
 10512 var base_dist     = new Array(D_CODES);
       
 10513 zero(base_dist);
       
 10514 /* First normalized distance for each code (0 = distance of 1) */
       
 10515 
       
 10516 
       
 10517 function StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {
       
 10518 
       
 10519   this.static_tree  = static_tree;  /* static tree or NULL */
       
 10520   this.extra_bits   = extra_bits;   /* extra bits for each code or NULL */
       
 10521   this.extra_base   = extra_base;   /* base index for extra_bits */
       
 10522   this.elems        = elems;        /* max number of elements in the tree */
       
 10523   this.max_length   = max_length;   /* max bit length for the codes */
       
 10524 
       
 10525   // show if `static_tree` has data or dummy - needed for monomorphic objects
       
 10526   this.has_stree    = static_tree && static_tree.length;
       
 10527 }
       
 10528 
       
 10529 
       
 10530 var static_l_desc;
       
 10531 var static_d_desc;
       
 10532 var static_bl_desc;
       
 10533 
       
 10534 
       
 10535 function TreeDesc(dyn_tree, stat_desc) {
       
 10536   this.dyn_tree = dyn_tree;     /* the dynamic tree */
       
 10537   this.max_code = 0;            /* largest code with non zero frequency */
       
 10538   this.stat_desc = stat_desc;   /* the corresponding static tree */
       
 10539 }
       
 10540 
       
 10541 
       
 10542 
       
 10543 function d_code(dist) {
       
 10544   return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];
       
 10545 }
       
 10546 
       
 10547 
       
 10548 /* ===========================================================================
       
 10549  * Output a short LSB first on the stream.
       
 10550  * IN assertion: there is enough room in pendingBuf.
       
 10551  */
       
 10552 function put_short(s, w) {
       
 10553 //    put_byte(s, (uch)((w) & 0xff));
       
 10554 //    put_byte(s, (uch)((ush)(w) >> 8));
       
 10555   s.pending_buf[s.pending++] = (w) & 0xff;
       
 10556   s.pending_buf[s.pending++] = (w >>> 8) & 0xff;
       
 10557 }
       
 10558 
       
 10559 
       
 10560 /* ===========================================================================
       
 10561  * Send a value on a given number of bits.
       
 10562  * IN assertion: length <= 16 and value fits in length bits.
       
 10563  */
       
 10564 function send_bits(s, value, length) {
       
 10565   if (s.bi_valid > (Buf_size - length)) {
       
 10566     s.bi_buf |= (value << s.bi_valid) & 0xffff;
       
 10567     put_short(s, s.bi_buf);
       
 10568     s.bi_buf = value >> (Buf_size - s.bi_valid);
       
 10569     s.bi_valid += length - Buf_size;
       
 10570   } else {
       
 10571     s.bi_buf |= (value << s.bi_valid) & 0xffff;
       
 10572     s.bi_valid += length;
       
 10573   }
       
 10574 }
       
 10575 
       
 10576 
       
 10577 function send_code(s, c, tree) {
       
 10578   send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);
       
 10579 }
       
 10580 
       
 10581 
       
 10582 /* ===========================================================================
       
 10583  * Reverse the first len bits of a code, using straightforward code (a faster
       
 10584  * method would use a table)
       
 10585  * IN assertion: 1 <= len <= 15
       
 10586  */
       
 10587 function bi_reverse(code, len) {
       
 10588   var res = 0;
       
 10589   do {
       
 10590     res |= code & 1;
       
 10591     code >>>= 1;
       
 10592     res <<= 1;
       
 10593   } while (--len > 0);
       
 10594   return res >>> 1;
       
 10595 }
       
 10596 
       
 10597 
       
 10598 /* ===========================================================================
       
 10599  * Flush the bit buffer, keeping at most 7 bits in it.
       
 10600  */
       
 10601 function bi_flush(s) {
       
 10602   if (s.bi_valid === 16) {
       
 10603     put_short(s, s.bi_buf);
       
 10604     s.bi_buf = 0;
       
 10605     s.bi_valid = 0;
       
 10606 
       
 10607   } else if (s.bi_valid >= 8) {
       
 10608     s.pending_buf[s.pending++] = s.bi_buf & 0xff;
       
 10609     s.bi_buf >>= 8;
       
 10610     s.bi_valid -= 8;
       
 10611   }
       
 10612 }
       
 10613 
       
 10614 
       
 10615 /* ===========================================================================
       
 10616  * Compute the optimal bit lengths for a tree and update the total bit length
       
 10617  * for the current block.
       
 10618  * IN assertion: the fields freq and dad are set, heap[heap_max] and
       
 10619  *    above are the tree nodes sorted by increasing frequency.
       
 10620  * OUT assertions: the field len is set to the optimal bit length, the
       
 10621  *     array bl_count contains the frequencies for each bit length.
       
 10622  *     The length opt_len is updated; static_len is also updated if stree is
       
 10623  *     not null.
       
 10624  */
       
 10625 function gen_bitlen(s, desc)
       
 10626 //    deflate_state *s;
       
 10627 //    tree_desc *desc;    /* the tree descriptor */
       
 10628 {
       
 10629   var tree            = desc.dyn_tree;
       
 10630   var max_code        = desc.max_code;
       
 10631   var stree           = desc.stat_desc.static_tree;
       
 10632   var has_stree       = desc.stat_desc.has_stree;
       
 10633   var extra           = desc.stat_desc.extra_bits;
       
 10634   var base            = desc.stat_desc.extra_base;
       
 10635   var max_length      = desc.stat_desc.max_length;
       
 10636   var h;              /* heap index */
       
 10637   var n, m;           /* iterate over the tree elements */
       
 10638   var bits;           /* bit length */
       
 10639   var xbits;          /* extra bits */
       
 10640   var f;              /* frequency */
       
 10641   var overflow = 0;   /* number of elements with bit length too large */
       
 10642 
       
 10643   for (bits = 0; bits <= MAX_BITS; bits++) {
       
 10644     s.bl_count[bits] = 0;
       
 10645   }
       
 10646 
       
 10647   /* In a first pass, compute the optimal bit lengths (which may
       
 10648    * overflow in the case of the bit length tree).
       
 10649    */
       
 10650   tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */
       
 10651 
       
 10652   for (h = s.heap_max + 1; h < HEAP_SIZE; h++) {
       
 10653     n = s.heap[h];
       
 10654     bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;
       
 10655     if (bits > max_length) {
       
 10656       bits = max_length;
       
 10657       overflow++;
       
 10658     }
       
 10659     tree[n * 2 + 1]/*.Len*/ = bits;
       
 10660     /* We overwrite tree[n].Dad which is no longer needed */
       
 10661 
       
 10662     if (n > max_code) { continue; } /* not a leaf node */
       
 10663 
       
 10664     s.bl_count[bits]++;
       
 10665     xbits = 0;
       
 10666     if (n >= base) {
       
 10667       xbits = extra[n - base];
       
 10668     }
       
 10669     f = tree[n * 2]/*.Freq*/;
       
 10670     s.opt_len += f * (bits + xbits);
       
 10671     if (has_stree) {
       
 10672       s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);
       
 10673     }
       
 10674   }
       
 10675   if (overflow === 0) { return; }
       
 10676 
       
 10677   // Trace((stderr,"\nbit length overflow\n"));
       
 10678   /* This happens for example on obj2 and pic of the Calgary corpus */
       
 10679 
       
 10680   /* Find the first bit length which could increase: */
       
 10681   do {
       
 10682     bits = max_length - 1;
       
 10683     while (s.bl_count[bits] === 0) { bits--; }
       
 10684     s.bl_count[bits]--;      /* move one leaf down the tree */
       
 10685     s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */
       
 10686     s.bl_count[max_length]--;
       
 10687     /* The brother of the overflow item also moves one step up,
       
 10688      * but this does not affect bl_count[max_length]
       
 10689      */
       
 10690     overflow -= 2;
       
 10691   } while (overflow > 0);
       
 10692 
       
 10693   /* Now recompute all bit lengths, scanning in increasing frequency.
       
 10694    * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all
       
 10695    * lengths instead of fixing only the wrong ones. This idea is taken
       
 10696    * from 'ar' written by Haruhiko Okumura.)
       
 10697    */
       
 10698   for (bits = max_length; bits !== 0; bits--) {
       
 10699     n = s.bl_count[bits];
       
 10700     while (n !== 0) {
       
 10701       m = s.heap[--h];
       
 10702       if (m > max_code) { continue; }
       
 10703       if (tree[m * 2 + 1]/*.Len*/ !== bits) {
       
 10704         // Trace((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits));
       
 10705         s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;
       
 10706         tree[m * 2 + 1]/*.Len*/ = bits;
       
 10707       }
       
 10708       n--;
       
 10709     }
       
 10710   }
       
 10711 }
       
 10712 
       
 10713 
       
 10714 /* ===========================================================================
       
 10715  * Generate the codes for a given tree and bit counts (which need not be
       
 10716  * optimal).
       
 10717  * IN assertion: the array bl_count contains the bit length statistics for
       
 10718  * the given tree and the field len is set for all tree elements.
       
 10719  * OUT assertion: the field code is set for all tree elements of non
       
 10720  *     zero code length.
       
 10721  */
       
 10722 function gen_codes(tree, max_code, bl_count)
       
 10723 //    ct_data *tree;             /* the tree to decorate */
       
 10724 //    int max_code;              /* largest code with non zero frequency */
       
 10725 //    ushf *bl_count;            /* number of codes at each bit length */
       
 10726 {
       
 10727   var next_code = new Array(MAX_BITS + 1); /* next code value for each bit length */
       
 10728   var code = 0;              /* running code value */
       
 10729   var bits;                  /* bit index */
       
 10730   var n;                     /* code index */
       
 10731 
       
 10732   /* The distribution counts are first used to generate the code values
       
 10733    * without bit reversal.
       
 10734    */
       
 10735   for (bits = 1; bits <= MAX_BITS; bits++) {
       
 10736     next_code[bits] = code = (code + bl_count[bits - 1]) << 1;
       
 10737   }
       
 10738   /* Check that the bit counts in bl_count are consistent. The last code
       
 10739    * must be all ones.
       
 10740    */
       
 10741   //Assert (code + bl_count[MAX_BITS]-1 == (1<<MAX_BITS)-1,
       
 10742   //        "inconsistent bit counts");
       
 10743   //Tracev((stderr,"\ngen_codes: max_code %d ", max_code));
       
 10744 
       
 10745   for (n = 0;  n <= max_code; n++) {
       
 10746     var len = tree[n * 2 + 1]/*.Len*/;
       
 10747     if (len === 0) { continue; }
       
 10748     /* Now reverse the bits */
       
 10749     tree[n * 2]/*.Code*/ = bi_reverse(next_code[len]++, len);
       
 10750 
       
 10751     //Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ",
       
 10752     //     n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len]-1));
       
 10753   }
       
 10754 }
       
 10755 
       
 10756 
       
 10757 /* ===========================================================================
       
 10758  * Initialize the various 'constant' tables.
       
 10759  */
       
 10760 function tr_static_init() {
       
 10761   var n;        /* iterates over tree elements */
       
 10762   var bits;     /* bit counter */
       
 10763   var length;   /* length value */
       
 10764   var code;     /* code value */
       
 10765   var dist;     /* distance index */
       
 10766   var bl_count = new Array(MAX_BITS + 1);
       
 10767   /* number of codes at each bit length for an optimal tree */
       
 10768 
       
 10769   // do check in _tr_init()
       
 10770   //if (static_init_done) return;
       
 10771 
       
 10772   /* For some embedded targets, global variables are not initialized: */
       
 10773 /*#ifdef NO_INIT_GLOBAL_POINTERS
       
 10774   static_l_desc.static_tree = static_ltree;
       
 10775   static_l_desc.extra_bits = extra_lbits;
       
 10776   static_d_desc.static_tree = static_dtree;
       
 10777   static_d_desc.extra_bits = extra_dbits;
       
 10778   static_bl_desc.extra_bits = extra_blbits;
       
 10779 #endif*/
       
 10780 
       
 10781   /* Initialize the mapping length (0..255) -> length code (0..28) */
       
 10782   length = 0;
       
 10783   for (code = 0; code < LENGTH_CODES - 1; code++) {
       
 10784     base_length[code] = length;
       
 10785     for (n = 0; n < (1 << extra_lbits[code]); n++) {
       
 10786       _length_code[length++] = code;
       
 10787     }
       
 10788   }
       
 10789   //Assert (length == 256, "tr_static_init: length != 256");
       
 10790   /* Note that the length 255 (match length 258) can be represented
       
 10791    * in two different ways: code 284 + 5 bits or code 285, so we
       
 10792    * overwrite length_code[255] to use the best encoding:
       
 10793    */
       
 10794   _length_code[length - 1] = code;
       
 10795 
       
 10796   /* Initialize the mapping dist (0..32K) -> dist code (0..29) */
       
 10797   dist = 0;
       
 10798   for (code = 0; code < 16; code++) {
       
 10799     base_dist[code] = dist;
       
 10800     for (n = 0; n < (1 << extra_dbits[code]); n++) {
       
 10801       _dist_code[dist++] = code;
       
 10802     }
       
 10803   }
       
 10804   //Assert (dist == 256, "tr_static_init: dist != 256");
       
 10805   dist >>= 7; /* from now on, all distances are divided by 128 */
       
 10806   for (; code < D_CODES; code++) {
       
 10807     base_dist[code] = dist << 7;
       
 10808     for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {
       
 10809       _dist_code[256 + dist++] = code;
       
 10810     }
       
 10811   }
       
 10812   //Assert (dist == 256, "tr_static_init: 256+dist != 512");
       
 10813 
       
 10814   /* Construct the codes of the static literal tree */
       
 10815   for (bits = 0; bits <= MAX_BITS; bits++) {
       
 10816     bl_count[bits] = 0;
       
 10817   }
       
 10818 
       
 10819   n = 0;
       
 10820   while (n <= 143) {
       
 10821     static_ltree[n * 2 + 1]/*.Len*/ = 8;
       
 10822     n++;
       
 10823     bl_count[8]++;
       
 10824   }
       
 10825   while (n <= 255) {
       
 10826     static_ltree[n * 2 + 1]/*.Len*/ = 9;
       
 10827     n++;
       
 10828     bl_count[9]++;
       
 10829   }
       
 10830   while (n <= 279) {
       
 10831     static_ltree[n * 2 + 1]/*.Len*/ = 7;
       
 10832     n++;
       
 10833     bl_count[7]++;
       
 10834   }
       
 10835   while (n <= 287) {
       
 10836     static_ltree[n * 2 + 1]/*.Len*/ = 8;
       
 10837     n++;
       
 10838     bl_count[8]++;
       
 10839   }
       
 10840   /* Codes 286 and 287 do not exist, but we must include them in the
       
 10841    * tree construction to get a canonical Huffman tree (longest code
       
 10842    * all ones)
       
 10843    */
       
 10844   gen_codes(static_ltree, L_CODES + 1, bl_count);
       
 10845 
       
 10846   /* The static distance tree is trivial: */
       
 10847   for (n = 0; n < D_CODES; n++) {
       
 10848     static_dtree[n * 2 + 1]/*.Len*/ = 5;
       
 10849     static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);
       
 10850   }
       
 10851 
       
 10852   // Now data ready and we can init static trees
       
 10853   static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS);
       
 10854   static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0,          D_CODES, MAX_BITS);
       
 10855   static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0,         BL_CODES, MAX_BL_BITS);
       
 10856 
       
 10857   //static_init_done = true;
       
 10858 }
       
 10859 
       
 10860 
       
 10861 /* ===========================================================================
       
 10862  * Initialize a new block.
       
 10863  */
       
 10864 function init_block(s) {
       
 10865   var n; /* iterates over tree elements */
       
 10866 
       
 10867   /* Initialize the trees. */
       
 10868   for (n = 0; n < L_CODES;  n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }
       
 10869   for (n = 0; n < D_CODES;  n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }
       
 10870   for (n = 0; n < BL_CODES; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }
       
 10871 
       
 10872   s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;
       
 10873   s.opt_len = s.static_len = 0;
       
 10874   s.last_lit = s.matches = 0;
       
 10875 }
       
 10876 
       
 10877 
       
 10878 /* ===========================================================================
       
 10879  * Flush the bit buffer and align the output on a byte boundary
       
 10880  */
       
 10881 function bi_windup(s)
       
 10882 {
       
 10883   if (s.bi_valid > 8) {
       
 10884     put_short(s, s.bi_buf);
       
 10885   } else if (s.bi_valid > 0) {
       
 10886     //put_byte(s, (Byte)s->bi_buf);
       
 10887     s.pending_buf[s.pending++] = s.bi_buf;
       
 10888   }
       
 10889   s.bi_buf = 0;
       
 10890   s.bi_valid = 0;
       
 10891 }
       
 10892 
       
 10893 /* ===========================================================================
       
 10894  * Copy a stored block, storing first the length and its
       
 10895  * one's complement if requested.
       
 10896  */
       
 10897 function copy_block(s, buf, len, header)
       
 10898 //DeflateState *s;
       
 10899 //charf    *buf;    /* the input data */
       
 10900 //unsigned len;     /* its length */
       
 10901 //int      header;  /* true if block header must be written */
       
 10902 {
       
 10903   bi_windup(s);        /* align on byte boundary */
       
 10904 
       
 10905   if (header) {
       
 10906     put_short(s, len);
       
 10907     put_short(s, ~len);
       
 10908   }
       
 10909 //  while (len--) {
       
 10910 //    put_byte(s, *buf++);
       
 10911 //  }
       
 10912   utils.arraySet(s.pending_buf, s.window, buf, len, s.pending);
       
 10913   s.pending += len;
       
 10914 }
       
 10915 
       
 10916 /* ===========================================================================
       
 10917  * Compares to subtrees, using the tree depth as tie breaker when
       
 10918  * the subtrees have equal frequency. This minimizes the worst case length.
       
 10919  */
       
 10920 function smaller(tree, n, m, depth) {
       
 10921   var _n2 = n * 2;
       
 10922   var _m2 = m * 2;
       
 10923   return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||
       
 10924          (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));
       
 10925 }
       
 10926 
       
 10927 /* ===========================================================================
       
 10928  * Restore the heap property by moving down the tree starting at node k,
       
 10929  * exchanging a node with the smallest of its two sons if necessary, stopping
       
 10930  * when the heap property is re-established (each father smaller than its
       
 10931  * two sons).
       
 10932  */
       
 10933 function pqdownheap(s, tree, k)
       
 10934 //    deflate_state *s;
       
 10935 //    ct_data *tree;  /* the tree to restore */
       
 10936 //    int k;               /* node to move down */
       
 10937 {
       
 10938   var v = s.heap[k];
       
 10939   var j = k << 1;  /* left son of k */
       
 10940   while (j <= s.heap_len) {
       
 10941     /* Set j to the smallest of the two sons: */
       
 10942     if (j < s.heap_len &&
       
 10943       smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {
       
 10944       j++;
       
 10945     }
       
 10946     /* Exit if v is smaller than both sons */
       
 10947     if (smaller(tree, v, s.heap[j], s.depth)) { break; }
       
 10948 
       
 10949     /* Exchange v with the smallest son */
       
 10950     s.heap[k] = s.heap[j];
       
 10951     k = j;
       
 10952 
       
 10953     /* And continue down the tree, setting j to the left son of k */
       
 10954     j <<= 1;
       
 10955   }
       
 10956   s.heap[k] = v;
       
 10957 }
       
 10958 
       
 10959 
       
 10960 // inlined manually
       
 10961 // var SMALLEST = 1;
       
 10962 
       
 10963 /* ===========================================================================
       
 10964  * Send the block data compressed using the given Huffman trees
       
 10965  */
       
 10966 function compress_block(s, ltree, dtree)
       
 10967 //    deflate_state *s;
       
 10968 //    const ct_data *ltree; /* literal tree */
       
 10969 //    const ct_data *dtree; /* distance tree */
       
 10970 {
       
 10971   var dist;           /* distance of matched string */
       
 10972   var lc;             /* match length or unmatched char (if dist == 0) */
       
 10973   var lx = 0;         /* running index in l_buf */
       
 10974   var code;           /* the code to send */
       
 10975   var extra;          /* number of extra bits to send */
       
 10976 
       
 10977   if (s.last_lit !== 0) {
       
 10978     do {
       
 10979       dist = (s.pending_buf[s.d_buf + lx * 2] << 8) | (s.pending_buf[s.d_buf + lx * 2 + 1]);
       
 10980       lc = s.pending_buf[s.l_buf + lx];
       
 10981       lx++;
       
 10982 
       
 10983       if (dist === 0) {
       
 10984         send_code(s, lc, ltree); /* send a literal byte */
       
 10985         //Tracecv(isgraph(lc), (stderr," '%c' ", lc));
       
 10986       } else {
       
 10987         /* Here, lc is the match length - MIN_MATCH */
       
 10988         code = _length_code[lc];
       
 10989         send_code(s, code + LITERALS + 1, ltree); /* send the length code */
       
 10990         extra = extra_lbits[code];
       
 10991         if (extra !== 0) {
       
 10992           lc -= base_length[code];
       
 10993           send_bits(s, lc, extra);       /* send the extra length bits */
       
 10994         }
       
 10995         dist--; /* dist is now the match distance - 1 */
       
 10996         code = d_code(dist);
       
 10997         //Assert (code < D_CODES, "bad d_code");
       
 10998 
       
 10999         send_code(s, code, dtree);       /* send the distance code */
       
 11000         extra = extra_dbits[code];
       
 11001         if (extra !== 0) {
       
 11002           dist -= base_dist[code];
       
 11003           send_bits(s, dist, extra);   /* send the extra distance bits */
       
 11004         }
       
 11005       } /* literal or match pair ? */
       
 11006 
       
 11007       /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */
       
 11008       //Assert((uInt)(s->pending) < s->lit_bufsize + 2*lx,
       
 11009       //       "pendingBuf overflow");
       
 11010 
       
 11011     } while (lx < s.last_lit);
       
 11012   }
       
 11013 
       
 11014   send_code(s, END_BLOCK, ltree);
       
 11015 }
       
 11016 
       
 11017 
       
 11018 /* ===========================================================================
       
 11019  * Construct one Huffman tree and assigns the code bit strings and lengths.
       
 11020  * Update the total bit length for the current block.
       
 11021  * IN assertion: the field freq is set for all tree elements.
       
 11022  * OUT assertions: the fields len and code are set to the optimal bit length
       
 11023  *     and corresponding code. The length opt_len is updated; static_len is
       
 11024  *     also updated if stree is not null. The field max_code is set.
       
 11025  */
       
 11026 function build_tree(s, desc)
       
 11027 //    deflate_state *s;
       
 11028 //    tree_desc *desc; /* the tree descriptor */
       
 11029 {
       
 11030   var tree     = desc.dyn_tree;
       
 11031   var stree    = desc.stat_desc.static_tree;
       
 11032   var has_stree = desc.stat_desc.has_stree;
       
 11033   var elems    = desc.stat_desc.elems;
       
 11034   var n, m;          /* iterate over heap elements */
       
 11035   var max_code = -1; /* largest code with non zero frequency */
       
 11036   var node;          /* new node being created */
       
 11037 
       
 11038   /* Construct the initial heap, with least frequent element in
       
 11039    * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].
       
 11040    * heap[0] is not used.
       
 11041    */
       
 11042   s.heap_len = 0;
       
 11043   s.heap_max = HEAP_SIZE;
       
 11044 
       
 11045   for (n = 0; n < elems; n++) {
       
 11046     if (tree[n * 2]/*.Freq*/ !== 0) {
       
 11047       s.heap[++s.heap_len] = max_code = n;
       
 11048       s.depth[n] = 0;
       
 11049 
       
 11050     } else {
       
 11051       tree[n * 2 + 1]/*.Len*/ = 0;
       
 11052     }
       
 11053   }
       
 11054 
       
 11055   /* The pkzip format requires that at least one distance code exists,
       
 11056    * and that at least one bit should be sent even if there is only one
       
 11057    * possible code. So to avoid special checks later on we force at least
       
 11058    * two codes of non zero frequency.
       
 11059    */
       
 11060   while (s.heap_len < 2) {
       
 11061     node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);
       
 11062     tree[node * 2]/*.Freq*/ = 1;
       
 11063     s.depth[node] = 0;
       
 11064     s.opt_len--;
       
 11065 
       
 11066     if (has_stree) {
       
 11067       s.static_len -= stree[node * 2 + 1]/*.Len*/;
       
 11068     }
       
 11069     /* node is 0 or 1 so it does not have extra bits */
       
 11070   }
       
 11071   desc.max_code = max_code;
       
 11072 
       
 11073   /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,
       
 11074    * establish sub-heaps of increasing lengths:
       
 11075    */
       
 11076   for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }
       
 11077 
       
 11078   /* Construct the Huffman tree by repeatedly combining the least two
       
 11079    * frequent nodes.
       
 11080    */
       
 11081   node = elems;              /* next internal node of the tree */
       
 11082   do {
       
 11083     //pqremove(s, tree, n);  /* n = node of least frequency */
       
 11084     /*** pqremove ***/
       
 11085     n = s.heap[1/*SMALLEST*/];
       
 11086     s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];
       
 11087     pqdownheap(s, tree, 1/*SMALLEST*/);
       
 11088     /***/
       
 11089 
       
 11090     m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */
       
 11091 
       
 11092     s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */
       
 11093     s.heap[--s.heap_max] = m;
       
 11094 
       
 11095     /* Create a new node father of n and m */
       
 11096     tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;
       
 11097     s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;
       
 11098     tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;
       
 11099 
       
 11100     /* and insert the new node in the heap */
       
 11101     s.heap[1/*SMALLEST*/] = node++;
       
 11102     pqdownheap(s, tree, 1/*SMALLEST*/);
       
 11103 
       
 11104   } while (s.heap_len >= 2);
       
 11105 
       
 11106   s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];
       
 11107 
       
 11108   /* At this point, the fields freq and dad are set. We can now
       
 11109    * generate the bit lengths.
       
 11110    */
       
 11111   gen_bitlen(s, desc);
       
 11112 
       
 11113   /* The field len is now set, we can generate the bit codes */
       
 11114   gen_codes(tree, max_code, s.bl_count);
       
 11115 }
       
 11116 
       
 11117 
       
 11118 /* ===========================================================================
       
 11119  * Scan a literal or distance tree to determine the frequencies of the codes
       
 11120  * in the bit length tree.
       
 11121  */
       
 11122 function scan_tree(s, tree, max_code)
       
 11123 //    deflate_state *s;
       
 11124 //    ct_data *tree;   /* the tree to be scanned */
       
 11125 //    int max_code;    /* and its largest code of non zero frequency */
       
 11126 {
       
 11127   var n;                     /* iterates over all tree elements */
       
 11128   var prevlen = -1;          /* last emitted length */
       
 11129   var curlen;                /* length of current code */
       
 11130 
       
 11131   var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */
       
 11132 
       
 11133   var count = 0;             /* repeat count of the current code */
       
 11134   var max_count = 7;         /* max repeat count */
       
 11135   var min_count = 4;         /* min repeat count */
       
 11136 
       
 11137   if (nextlen === 0) {
       
 11138     max_count = 138;
       
 11139     min_count = 3;
       
 11140   }
       
 11141   tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */
       
 11142 
       
 11143   for (n = 0; n <= max_code; n++) {
       
 11144     curlen = nextlen;
       
 11145     nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;
       
 11146 
       
 11147     if (++count < max_count && curlen === nextlen) {
       
 11148       continue;
       
 11149 
       
 11150     } else if (count < min_count) {
       
 11151       s.bl_tree[curlen * 2]/*.Freq*/ += count;
       
 11152 
       
 11153     } else if (curlen !== 0) {
       
 11154 
       
 11155       if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }
       
 11156       s.bl_tree[REP_3_6 * 2]/*.Freq*/++;
       
 11157 
       
 11158     } else if (count <= 10) {
       
 11159       s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;
       
 11160 
       
 11161     } else {
       
 11162       s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;
       
 11163     }
       
 11164 
       
 11165     count = 0;
       
 11166     prevlen = curlen;
       
 11167 
       
 11168     if (nextlen === 0) {
       
 11169       max_count = 138;
       
 11170       min_count = 3;
       
 11171 
       
 11172     } else if (curlen === nextlen) {
       
 11173       max_count = 6;
       
 11174       min_count = 3;
       
 11175 
       
 11176     } else {
       
 11177       max_count = 7;
       
 11178       min_count = 4;
       
 11179     }
       
 11180   }
       
 11181 }
       
 11182 
       
 11183 
       
 11184 /* ===========================================================================
       
 11185  * Send a literal or distance tree in compressed form, using the codes in
       
 11186  * bl_tree.
       
 11187  */
       
 11188 function send_tree(s, tree, max_code)
       
 11189 //    deflate_state *s;
       
 11190 //    ct_data *tree; /* the tree to be scanned */
       
 11191 //    int max_code;       /* and its largest code of non zero frequency */
       
 11192 {
       
 11193   var n;                     /* iterates over all tree elements */
       
 11194   var prevlen = -1;          /* last emitted length */
       
 11195   var curlen;                /* length of current code */
       
 11196 
       
 11197   var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */
       
 11198 
       
 11199   var count = 0;             /* repeat count of the current code */
       
 11200   var max_count = 7;         /* max repeat count */
       
 11201   var min_count = 4;         /* min repeat count */
       
 11202 
       
 11203   /* tree[max_code+1].Len = -1; */  /* guard already set */
       
 11204   if (nextlen === 0) {
       
 11205     max_count = 138;
       
 11206     min_count = 3;
       
 11207   }
       
 11208 
       
 11209   for (n = 0; n <= max_code; n++) {
       
 11210     curlen = nextlen;
       
 11211     nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;
       
 11212 
       
 11213     if (++count < max_count && curlen === nextlen) {
       
 11214       continue;
       
 11215 
       
 11216     } else if (count < min_count) {
       
 11217       do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);
       
 11218 
       
 11219     } else if (curlen !== 0) {
       
 11220       if (curlen !== prevlen) {
       
 11221         send_code(s, curlen, s.bl_tree);
       
 11222         count--;
       
 11223       }
       
 11224       //Assert(count >= 3 && count <= 6, " 3_6?");
       
 11225       send_code(s, REP_3_6, s.bl_tree);
       
 11226       send_bits(s, count - 3, 2);
       
 11227 
       
 11228     } else if (count <= 10) {
       
 11229       send_code(s, REPZ_3_10, s.bl_tree);
       
 11230       send_bits(s, count - 3, 3);
       
 11231 
       
 11232     } else {
       
 11233       send_code(s, REPZ_11_138, s.bl_tree);
       
 11234       send_bits(s, count - 11, 7);
       
 11235     }
       
 11236 
       
 11237     count = 0;
       
 11238     prevlen = curlen;
       
 11239     if (nextlen === 0) {
       
 11240       max_count = 138;
       
 11241       min_count = 3;
       
 11242 
       
 11243     } else if (curlen === nextlen) {
       
 11244       max_count = 6;
       
 11245       min_count = 3;
       
 11246 
       
 11247     } else {
       
 11248       max_count = 7;
       
 11249       min_count = 4;
       
 11250     }
       
 11251   }
       
 11252 }
       
 11253 
       
 11254 
       
 11255 /* ===========================================================================
       
 11256  * Construct the Huffman tree for the bit lengths and return the index in
       
 11257  * bl_order of the last bit length code to send.
       
 11258  */
       
 11259 function build_bl_tree(s) {
       
 11260   var max_blindex;  /* index of last bit length code of non zero freq */
       
 11261 
       
 11262   /* Determine the bit length frequencies for literal and distance trees */
       
 11263   scan_tree(s, s.dyn_ltree, s.l_desc.max_code);
       
 11264   scan_tree(s, s.dyn_dtree, s.d_desc.max_code);
       
 11265 
       
 11266   /* Build the bit length tree: */
       
 11267   build_tree(s, s.bl_desc);
       
 11268   /* opt_len now includes the length of the tree representations, except
       
 11269    * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.
       
 11270    */
       
 11271 
       
 11272   /* Determine the number of bit length codes to send. The pkzip format
       
 11273    * requires that at least 4 bit length codes be sent. (appnote.txt says
       
 11274    * 3 but the actual value used is 4.)
       
 11275    */
       
 11276   for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) {
       
 11277     if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {
       
 11278       break;
       
 11279     }
       
 11280   }
       
 11281   /* Update opt_len to include the bit length tree and counts */
       
 11282   s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;
       
 11283   //Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld",
       
 11284   //        s->opt_len, s->static_len));
       
 11285 
       
 11286   return max_blindex;
       
 11287 }
       
 11288 
       
 11289 
       
 11290 /* ===========================================================================
       
 11291  * Send the header for a block using dynamic Huffman trees: the counts, the
       
 11292  * lengths of the bit length codes, the literal tree and the distance tree.
       
 11293  * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.
       
 11294  */
       
 11295 function send_all_trees(s, lcodes, dcodes, blcodes)
       
 11296 //    deflate_state *s;
       
 11297 //    int lcodes, dcodes, blcodes; /* number of codes for each tree */
       
 11298 {
       
 11299   var rank;                    /* index in bl_order */
       
 11300 
       
 11301   //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, "not enough codes");
       
 11302   //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,
       
 11303   //        "too many codes");
       
 11304   //Tracev((stderr, "\nbl counts: "));
       
 11305   send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */
       
 11306   send_bits(s, dcodes - 1,   5);
       
 11307   send_bits(s, blcodes - 4,  4); /* not -3 as stated in appnote.txt */
       
 11308   for (rank = 0; rank < blcodes; rank++) {
       
 11309     //Tracev((stderr, "\nbl code %2d ", bl_order[rank]));
       
 11310     send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);
       
 11311   }
       
 11312   //Tracev((stderr, "\nbl tree: sent %ld", s->bits_sent));
       
 11313 
       
 11314   send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */
       
 11315   //Tracev((stderr, "\nlit tree: sent %ld", s->bits_sent));
       
 11316 
       
 11317   send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */
       
 11318   //Tracev((stderr, "\ndist tree: sent %ld", s->bits_sent));
       
 11319 }
       
 11320 
       
 11321 
       
 11322 /* ===========================================================================
       
 11323  * Check if the data type is TEXT or BINARY, using the following algorithm:
       
 11324  * - TEXT if the two conditions below are satisfied:
       
 11325  *    a) There are no non-portable control characters belonging to the
       
 11326  *       "black list" (0..6, 14..25, 28..31).
       
 11327  *    b) There is at least one printable character belonging to the
       
 11328  *       "white list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).
       
 11329  * - BINARY otherwise.
       
 11330  * - The following partially-portable control characters form a
       
 11331  *   "gray list" that is ignored in this detection algorithm:
       
 11332  *   (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).
       
 11333  * IN assertion: the fields Freq of dyn_ltree are set.
       
 11334  */
       
 11335 function detect_data_type(s) {
       
 11336   /* black_mask is the bit mask of black-listed bytes
       
 11337    * set bits 0..6, 14..25, and 28..31
       
 11338    * 0xf3ffc07f = binary 11110011111111111100000001111111
       
 11339    */
       
 11340   var black_mask = 0xf3ffc07f;
       
 11341   var n;
       
 11342 
       
 11343   /* Check for non-textual ("black-listed") bytes. */
       
 11344   for (n = 0; n <= 31; n++, black_mask >>>= 1) {
       
 11345     if ((black_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {
       
 11346       return Z_BINARY;
       
 11347     }
       
 11348   }
       
 11349 
       
 11350   /* Check for textual ("white-listed") bytes. */
       
 11351   if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||
       
 11352       s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {
       
 11353     return Z_TEXT;
       
 11354   }
       
 11355   for (n = 32; n < LITERALS; n++) {
       
 11356     if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {
       
 11357       return Z_TEXT;
       
 11358     }
       
 11359   }
       
 11360 
       
 11361   /* There are no "black-listed" or "white-listed" bytes:
       
 11362    * this stream either is empty or has tolerated ("gray-listed") bytes only.
       
 11363    */
       
 11364   return Z_BINARY;
       
 11365 }
       
 11366 
       
 11367 
       
 11368 var static_init_done = false;
       
 11369 
       
 11370 /* ===========================================================================
       
 11371  * Initialize the tree data structures for a new zlib stream.
       
 11372  */
       
 11373 function _tr_init(s)
       
 11374 {
       
 11375 
       
 11376   if (!static_init_done) {
       
 11377     tr_static_init();
       
 11378     static_init_done = true;
       
 11379   }
       
 11380 
       
 11381   s.l_desc  = new TreeDesc(s.dyn_ltree, static_l_desc);
       
 11382   s.d_desc  = new TreeDesc(s.dyn_dtree, static_d_desc);
       
 11383   s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);
       
 11384 
       
 11385   s.bi_buf = 0;
       
 11386   s.bi_valid = 0;
       
 11387 
       
 11388   /* Initialize the first block of the first file: */
       
 11389   init_block(s);
       
 11390 }
       
 11391 
       
 11392 
       
 11393 /* ===========================================================================
       
 11394  * Send a stored block
       
 11395  */
       
 11396 function _tr_stored_block(s, buf, stored_len, last)
       
 11397 //DeflateState *s;
       
 11398 //charf *buf;       /* input block */
       
 11399 //ulg stored_len;   /* length of input block */
       
 11400 //int last;         /* one if this is the last block for a file */
       
 11401 {
       
 11402   send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3);    /* send block type */
       
 11403   copy_block(s, buf, stored_len, true); /* with header */
       
 11404 }
       
 11405 
       
 11406 
       
 11407 /* ===========================================================================
       
 11408  * Send one empty static block to give enough lookahead for inflate.
       
 11409  * This takes 10 bits, of which 7 may remain in the bit buffer.
       
 11410  */
       
 11411 function _tr_align(s) {
       
 11412   send_bits(s, STATIC_TREES << 1, 3);
       
 11413   send_code(s, END_BLOCK, static_ltree);
       
 11414   bi_flush(s);
       
 11415 }
       
 11416 
       
 11417 
       
 11418 /* ===========================================================================
       
 11419  * Determine the best encoding for the current block: dynamic trees, static
       
 11420  * trees or store, and output the encoded block to the zip file.
       
 11421  */
       
 11422 function _tr_flush_block(s, buf, stored_len, last)
       
 11423 //DeflateState *s;
       
 11424 //charf *buf;       /* input block, or NULL if too old */
       
 11425 //ulg stored_len;   /* length of input block */
       
 11426 //int last;         /* one if this is the last block for a file */
       
 11427 {
       
 11428   var opt_lenb, static_lenb;  /* opt_len and static_len in bytes */
       
 11429   var max_blindex = 0;        /* index of last bit length code of non zero freq */
       
 11430 
       
 11431   /* Build the Huffman trees unless a stored block is forced */
       
 11432   if (s.level > 0) {
       
 11433 
       
 11434     /* Check if the file is binary or text */
       
 11435     if (s.strm.data_type === Z_UNKNOWN) {
       
 11436       s.strm.data_type = detect_data_type(s);
       
 11437     }
       
 11438 
       
 11439     /* Construct the literal and distance trees */
       
 11440     build_tree(s, s.l_desc);
       
 11441     // Tracev((stderr, "\nlit data: dyn %ld, stat %ld", s->opt_len,
       
 11442     //        s->static_len));
       
 11443 
       
 11444     build_tree(s, s.d_desc);
       
 11445     // Tracev((stderr, "\ndist data: dyn %ld, stat %ld", s->opt_len,
       
 11446     //        s->static_len));
       
 11447     /* At this point, opt_len and static_len are the total bit lengths of
       
 11448      * the compressed block data, excluding the tree representations.
       
 11449      */
       
 11450 
       
 11451     /* Build the bit length tree for the above two trees, and get the index
       
 11452      * in bl_order of the last bit length code to send.
       
 11453      */
       
 11454     max_blindex = build_bl_tree(s);
       
 11455 
       
 11456     /* Determine the best encoding. Compute the block lengths in bytes. */
       
 11457     opt_lenb = (s.opt_len + 3 + 7) >>> 3;
       
 11458     static_lenb = (s.static_len + 3 + 7) >>> 3;
       
 11459 
       
 11460     // Tracev((stderr, "\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u ",
       
 11461     //        opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,
       
 11462     //        s->last_lit));
       
 11463 
       
 11464     if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }
       
 11465 
       
 11466   } else {
       
 11467     // Assert(buf != (char*)0, "lost buf");
       
 11468     opt_lenb = static_lenb = stored_len + 5; /* force a stored block */
       
 11469   }
       
 11470 
       
 11471   if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {
       
 11472     /* 4: two words for the lengths */
       
 11473 
       
 11474     /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.
       
 11475      * Otherwise we can't have processed more than WSIZE input bytes since
       
 11476      * the last block flush, because compression would have been
       
 11477      * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to
       
 11478      * transform a block into a stored block.
       
 11479      */
       
 11480     _tr_stored_block(s, buf, stored_len, last);
       
 11481 
       
 11482   } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) {
       
 11483 
       
 11484     send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);
       
 11485     compress_block(s, static_ltree, static_dtree);
       
 11486 
       
 11487   } else {
       
 11488     send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);
       
 11489     send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);
       
 11490     compress_block(s, s.dyn_ltree, s.dyn_dtree);
       
 11491   }
       
 11492   // Assert (s->compressed_len == s->bits_sent, "bad compressed size");
       
 11493   /* The above check is made mod 2^32, for files larger than 512 MB
       
 11494    * and uLong implemented on 32 bits.
       
 11495    */
       
 11496   init_block(s);
       
 11497 
       
 11498   if (last) {
       
 11499     bi_windup(s);
       
 11500   }
       
 11501   // Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3,
       
 11502   //       s->compressed_len-7*last));
       
 11503 }
       
 11504 
       
 11505 /* ===========================================================================
       
 11506  * Save the match info and tally the frequency counts. Return true if
       
 11507  * the current block must be flushed.
       
 11508  */
       
 11509 function _tr_tally(s, dist, lc)
       
 11510 //    deflate_state *s;
       
 11511 //    unsigned dist;  /* distance of matched string */
       
 11512 //    unsigned lc;    /* match length-MIN_MATCH or unmatched char (if dist==0) */
       
 11513 {
       
 11514   //var out_length, in_length, dcode;
       
 11515 
       
 11516   s.pending_buf[s.d_buf + s.last_lit * 2]     = (dist >>> 8) & 0xff;
       
 11517   s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 0xff;
       
 11518 
       
 11519   s.pending_buf[s.l_buf + s.last_lit] = lc & 0xff;
       
 11520   s.last_lit++;
       
 11521 
       
 11522   if (dist === 0) {
       
 11523     /* lc is the unmatched char */
       
 11524     s.dyn_ltree[lc * 2]/*.Freq*/++;
       
 11525   } else {
       
 11526     s.matches++;
       
 11527     /* Here, lc is the match length - MIN_MATCH */
       
 11528     dist--;             /* dist = match distance - 1 */
       
 11529     //Assert((ush)dist < (ush)MAX_DIST(s) &&
       
 11530     //       (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&
       
 11531     //       (ush)d_code(dist) < (ush)D_CODES,  "_tr_tally: bad match");
       
 11532 
       
 11533     s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]/*.Freq*/++;
       
 11534     s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;
       
 11535   }
       
 11536 
       
 11537 // (!) This block is disabled in zlib defailts,
       
 11538 // don't enable it for binary compatibility
       
 11539 
       
 11540 //#ifdef TRUNCATE_BLOCK
       
 11541 //  /* Try to guess if it is profitable to stop the current block here */
       
 11542 //  if ((s.last_lit & 0x1fff) === 0 && s.level > 2) {
       
 11543 //    /* Compute an upper bound for the compressed length */
       
 11544 //    out_length = s.last_lit*8;
       
 11545 //    in_length = s.strstart - s.block_start;
       
 11546 //
       
 11547 //    for (dcode = 0; dcode < D_CODES; dcode++) {
       
 11548 //      out_length += s.dyn_dtree[dcode*2]/*.Freq*/ * (5 + extra_dbits[dcode]);
       
 11549 //    }
       
 11550 //    out_length >>>= 3;
       
 11551 //    //Tracev((stderr,"\nlast_lit %u, in %ld, out ~%ld(%ld%%) ",
       
 11552 //    //       s->last_lit, in_length, out_length,
       
 11553 //    //       100L - out_length*100L/in_length));
       
 11554 //    if (s.matches < (s.last_lit>>1)/*int /2*/ && out_length < (in_length>>1)/*int /2*/) {
       
 11555 //      return true;
       
 11556 //    }
       
 11557 //  }
       
 11558 //#endif
       
 11559 
       
 11560   return (s.last_lit === s.lit_bufsize - 1);
       
 11561   /* We avoid equality with lit_bufsize because of wraparound at 64K
       
 11562    * on 16 bit machines and because stored blocks are restricted to
       
 11563    * 64K-1 bytes.
       
 11564    */
       
 11565 }
       
 11566 
       
 11567 exports._tr_init  = _tr_init;
       
 11568 exports._tr_stored_block = _tr_stored_block;
       
 11569 exports._tr_flush_block  = _tr_flush_block;
       
 11570 exports._tr_tally = _tr_tally;
       
 11571 exports._tr_align = _tr_align;
       
 11572 
       
 11573 },{"../utils/common":62}],74:[function(require,module,exports){
       
 11574 'use strict';
       
 11575 
       
 11576 // (C) 1995-2013 Jean-loup Gailly and Mark Adler
       
 11577 // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
       
 11578 //
       
 11579 // This software is provided 'as-is', without any express or implied
       
 11580 // warranty. In no event will the authors be held liable for any damages
       
 11581 // arising from the use of this software.
       
 11582 //
       
 11583 // Permission is granted to anyone to use this software for any purpose,
       
 11584 // including commercial applications, and to alter it and redistribute it
       
 11585 // freely, subject to the following restrictions:
       
 11586 //
       
 11587 // 1. The origin of this software must not be misrepresented; you must not
       
 11588 //   claim that you wrote the original software. If you use this software
       
 11589 //   in a product, an acknowledgment in the product documentation would be
       
 11590 //   appreciated but is not required.
       
 11591 // 2. Altered source versions must be plainly marked as such, and must not be
       
 11592 //   misrepresented as being the original software.
       
 11593 // 3. This notice may not be removed or altered from any source distribution.
       
 11594 
       
 11595 function ZStream() {
       
 11596   /* next input byte */
       
 11597   this.input = null; // JS specific, because we have no pointers
       
 11598   this.next_in = 0;
       
 11599   /* number of bytes available at input */
       
 11600   this.avail_in = 0;
       
 11601   /* total number of input bytes read so far */
       
 11602   this.total_in = 0;
       
 11603   /* next output byte should be put there */
       
 11604   this.output = null; // JS specific, because we have no pointers
       
 11605   this.next_out = 0;
       
 11606   /* remaining free space at output */
       
 11607   this.avail_out = 0;
       
 11608   /* total number of bytes output so far */
       
 11609   this.total_out = 0;
       
 11610   /* last error message, NULL if no error */
       
 11611   this.msg = ''/*Z_NULL*/;
       
 11612   /* not visible by applications */
       
 11613   this.state = null;
       
 11614   /* best guess about the data type: binary or text */
       
 11615   this.data_type = 2/*Z_UNKNOWN*/;
       
 11616   /* adler32 value of the uncompressed data */
       
 11617   this.adler = 0;
       
 11618 }
       
 11619 
       
 11620 module.exports = ZStream;
       
 11621 
       
 11622 },{}]},{},[10])(10)
       
 11623 });